/* public/assets/style.css — Forever Design System */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --cream:#FAF7F2;--ivory:#F5F0E8;--blush:#E8C5B0;--rose:#C9897A;
  --mauve:#9E7B7B;--champagne:#D4B896;--gold:#B89A6A;--sage:#8A9E8A;
  --charcoal:#2C2825;--warm-grey:#6B635E;--light-grey:#E8E2DA;--white:#FFFDF9;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-sans:'Jost',system-ui,sans-serif;
  --radius:16px;--shadow:0 4px 24px rgba(44,40,37,.06);
  --shadow-lg:0 20px 60px rgba(44,40,37,.12);
}
html{scroll-behavior:smooth;}
body{font-family:var(--font-sans);background:var(--cream);color:var(--charcoal);overflow-x:hidden;font-weight:300;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:rgba(250,247,242,.94);backdrop-filter:blur(12px);border-bottom:1px solid rgba(212,184,150,.2);transition:height .3s,box-shadow .3s;}
nav.scrolled{height:60px;box-shadow:0 4px 30px rgba(44,40,37,.08);}
.nav-brand{font-family:var(--font-serif);font-size:28px;font-weight:400;letter-spacing:3px;color:var(--charcoal);text-decoration:none;font-style:italic;}
.nav-brand span{color:var(--gold);font-style:normal;}
.nav-links{display:flex;gap:32px;list-style:none;align-items:center;}
.nav-links a{font-size:12px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:var(--warm-grey);text-decoration:none;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform .3s ease;}
.nav-links a:hover{color:var(--charcoal);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{background:transparent;border:1px solid var(--champagne);color:var(--charcoal);font-family:var(--font-sans);font-size:11px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;padding:10px 24px;border-radius:40px;cursor:pointer;transition:all .3s;text-decoration:none;}
.nav-cta:hover{background:var(--charcoal);border-color:var(--charcoal);color:var(--cream);}
.nav-user{display:none;align-items:center;gap:16px;}
.nav-user-name{font-size:13px;color:var(--charcoal);font-weight:400;}
.nav-user a{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--warm-grey);text-decoration:none;transition:color .3s;}
.nav-user a:hover{color:var(--charcoal);}
.admin-link{display:none;color:var(--gold)!important;}
.nav-logout{background:none;border:none;font-family:var(--font-sans);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--warm-grey);cursor:pointer;transition:color .3s;}
.nav-logout:hover{color:var(--rose);}
@media(max-width:900px){nav{padding:0 20px;}.nav-links{display:none;}}

/* ── SHARED LAYOUT ── */
.page-wrap{padding-top:72px;}
section{padding:80px 48px;}
.inner{max-width:1200px;margin:0 auto;}
@media(max-width:900px){section{padding:60px 20px;}}

/* ── TYPOGRAPHY ── */
.eyebrow{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.eyebrow::before{content:'';display:inline-block;width:20px;height:1px;background:var(--gold);}
h1,h2.serif{font-family:var(--font-serif);font-weight:300;line-height:1.1;}
h1{font-size:clamp(44px,7vw,96px);}
h2.serif{font-size:clamp(32px,4vw,56px);}
h2.serif em{font-style:italic;color:var(--rose);}
.section-sub{font-size:15px;color:var(--warm-grey);font-weight:300;line-height:1.8;max-width:520px;}

/* ── BUTTONS ── */
.btn{display:inline-block;font-family:var(--font-sans);font-weight:400;letter-spacing:2px;text-transform:uppercase;border-radius:50px;cursor:pointer;transition:all .3s;text-decoration:none;border:none;}
.btn-dark{background:var(--charcoal);color:var(--cream);padding:14px 32px;font-size:12px;}
.btn-dark:hover{background:var(--rose);}
.btn-outline{background:transparent;color:var(--charcoal);border:1px solid var(--champagne);padding:13px 28px;font-size:11px;}
.btn-outline:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal);}
.btn-ghost{background:transparent;color:var(--warm-grey);padding:8px 0;font-size:11px;letter-spacing:1.5px;}
.btn-ghost:hover{color:var(--charcoal);}

/* ── CARDS ── */
.vendor-card{background:var(--white);border-radius:20px;overflow:hidden;border:1px solid rgba(212,184,150,.2);box-shadow:var(--shadow);cursor:pointer;transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s;}
.vendor-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);}
.card-img{position:relative;overflow:hidden;height:220px;}
.card-img-bg{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94);}
.vendor-card:hover .card-img-bg{transform:scale(1.06);}
.card-badge{position:absolute;top:14px;left:14px;background:var(--white);color:var(--charcoal);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:5px 12px;border-radius:30px;}
.card-badge.featured{background:var(--charcoal);color:var(--cream);}
.card-heart{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;border:none;transition:all .3s;}
.card-heart:hover{background:var(--rose);color:white;}
.card-body{padding:22px;}
.card-name{font-family:var(--font-serif);font-size:20px;font-weight:400;color:var(--charcoal);margin-bottom:5px;}
.card-city{font-size:12px;color:var(--warm-grey);margin-bottom:12px;}
.card-rating{display:flex;align-items:center;gap:7px;margin-bottom:14px;}
.stars{color:var(--gold);font-size:13px;}
.rating-score{font-weight:500;font-size:13px;}
.rating-count{font-size:11px;color:var(--warm-grey);}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--light-grey);}
.card-tags{display:flex;gap:5px;flex-wrap:wrap;}
.tag{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--warm-grey);background:var(--ivory);padding:4px 10px;border-radius:30px;border:1px solid var(--light-grey);}
.card-enquire{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);text-decoration:none;transition:color .3s;}
.card-enquire:hover{color:var(--rose);}

/* ── FILTER BAR ── */
.filter-bar{background:var(--white);border-bottom:1px solid var(--light-grey);padding:16px 48px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;position:sticky;top:72px;z-index:100;}
@media(max-width:900px){.filter-bar{padding:12px 20px;top:60px;}}
.filter-select{font-family:var(--font-sans);font-size:12px;font-weight:400;letter-spacing:1px;color:var(--charcoal);background:var(--ivory);border:1px solid var(--light-grey);border-radius:30px;padding:8px 16px;cursor:pointer;outline:none;transition:border-color .3s;}
.filter-select:focus{border-color:var(--champagne);}
.filter-search{flex:1;min-width:200px;font-family:var(--font-sans);font-size:13px;color:var(--charcoal);background:var(--ivory);border:1px solid var(--light-grey);border-radius:30px;padding:8px 18px;outline:none;transition:border-color .3s;}
.filter-search:focus{border-color:var(--champagne);}
.filter-count{font-size:12px;color:var(--warm-grey);margin-left:auto;white-space:nowrap;}

/* ── GRID ── */
.vendor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;}
@media(max-width:600px){.vendor-grid{grid-template-columns:1fr;}}

/* ── PAGINATION ── */
.pagination{display:flex;gap:8px;justify-content:center;align-items:center;padding:40px 0 20px;}
.page-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--light-grey);background:var(--white);font-family:var(--font-sans);font-size:13px;color:var(--warm-grey);cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;}
.page-btn.active,.page-btn:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal);}
.page-btn:disabled{opacity:.3;cursor:default;}

/* ── MODAL ── */
#auth-modal{display:none;position:fixed;inset:0;z-index:500;align-items:center;justify-content:center;}
.modal-backdrop{position:absolute;inset:0;background:rgba(44,40,37,.6);backdrop-filter:blur(4px);}
.modal-box{position:relative;background:var(--white);border-radius:24px;padding:44px 40px;width:420px;max-width:calc(100vw - 40px);box-shadow:0 40px 100px rgba(44,40,37,.25);}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:22px;color:var(--warm-grey);cursor:pointer;line-height:1;}
.modal-brand{font-family:var(--font-serif);font-size:26px;font-weight:400;letter-spacing:2px;text-align:center;margin-bottom:8px;font-style:italic;color:var(--charcoal);}
.modal-brand span{color:var(--gold);font-style:normal;}
.modal-tabs{display:flex;gap:0;margin:20px 0 24px;border-bottom:1px solid var(--light-grey);}
.modal-tab{flex:1;background:none;border:none;font-family:var(--font-sans);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--warm-grey);padding:10px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s;}
.modal-tab.active{color:var(--charcoal);border-bottom-color:var(--charcoal);}
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--warm-grey);margin-bottom:6px;}
.form-group input{width:100%;border:1px solid var(--light-grey);border-radius:10px;padding:12px 16px;font-family:var(--font-sans);font-size:14px;color:var(--charcoal);background:var(--ivory);outline:none;transition:border-color .3s;}
.form-group input:focus{border-color:var(--champagne);}
.form-error{font-size:13px;color:var(--rose);margin-bottom:10px;min-height:18px;}
.form-btn{width:100%;background:var(--charcoal);color:var(--cream);border:none;border-radius:50px;padding:14px;font-family:var(--font-sans);font-size:12px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .3s;}
.form-btn:hover{background:var(--rose);}
.modal-legal{font-size:11px;color:var(--warm-grey);text-align:center;margin-top:16px;}
.modal-legal a{color:var(--gold);text-decoration:none;}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}.rd4{transition-delay:.4s}.rd5{transition-delay:.5s}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:80px 20px;color:var(--warm-grey);}
.empty-state .es-icon{font-size:48px;margin-bottom:16px;opacity:.4;}
.empty-state h3{font-family:var(--font-serif);font-size:28px;font-weight:400;color:var(--charcoal);margin-bottom:8px;}
.empty-state p{font-size:14px;line-height:1.7;}

/* ── TOAST ── */
.toast{position:fixed;bottom:30px;right:30px;background:var(--charcoal);color:var(--cream);padding:14px 24px;border-radius:50px;font-size:13px;font-weight:400;box-shadow:var(--shadow-lg);z-index:999;animation:toastIn .3s ease;pointer-events:none;}
@keyframes toastIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
