/* ============================================================
   DESIGNER DEALER — shared stylesheet (gold & black)
   Used by index.html, shop.html, product.html, contact.html
   ============================================================ */

:root{
  --black:#0B0B0C; --black-soft:#141315; --black-card:#1A1819;
  --gold:#C9A24B; --gold-light:#EAD49A; --gold-deep:#8A6A28;
  --ivory:#F3EEE3; --muted:#9A9180; --line:rgba(201,162,75,0.22);
  --gold-grad:linear-gradient(135deg,#F0DDA0 0%,#C9A24B 45%,#9A7B2E 100%);
  --maxw:1240px; --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--black);color:var(--ivory);font-family:'Jost',system-ui,sans-serif;font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.gold-text{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:500;margin:0;line-height:1.1;}
.eyebrow{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:400;}

/* ---------- Announcement bar ---------- */
.announce{background:#000;border-bottom:1px solid var(--line);overflow:hidden;height:38px;position:relative;}
.announce .slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .6s var(--ease);font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-light);}
.announce .slide.on{opacity:1;}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(11,11,12,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:14px 28px;max-width:var(--maxw);margin:0 auto;}
.bar .left{display:flex;align-items:center;gap:18px;}
.bar .right{display:flex;align-items:center;gap:20px;justify-content:flex-end;}
.icon-btn{background:none;border:none;color:var(--ivory);display:inline-flex;padding:4px;border-radius:6px;transition:color .2s;}
.icon-btn:hover{color:var(--gold);}
.icon-btn svg{width:21px;height:21px;}
.cart-btn{position:relative;}
.cart-count{position:absolute;top:-6px;right:-8px;background:var(--gold-grad);color:#1a1306;font-size:.6rem;font-weight:600;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}
.brand{display:flex;flex-direction:column;align-items:center;}
.brand-logo{height:74px;width:auto;}

/* ---------- Primary nav ---------- */
nav.primary{border-top:1px solid var(--line);background:rgba(0,0,0,.4);}
.nav-list{display:flex;justify-content:center;gap:4px;max-width:var(--maxw);margin:0 auto;padding:0 28px;list-style:none;}
.nav-list>li{position:relative;}
.nav-list>li>a{display:block;padding:14px 16px;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory);transition:color .2s;}
.nav-list>li>a:hover,.nav-list>li>a.active{color:var(--gold);}
.nav-list>li>a .caret{font-size:.5rem;opacity:.6;margin-left:5px;}
.dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:var(--black-soft);border:1px solid var(--line);min-width:200px;padding:10px 0;opacity:0;visibility:hidden;transition:.22s var(--ease);box-shadow:0 24px 50px rgba(0,0,0,.55);z-index:50;}
.nav-list>li:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.dropdown a{display:block;padding:9px 22px;font-size:.78rem;letter-spacing:.08em;color:var(--muted);transition:.18s;}
.dropdown a:hover{color:var(--gold);background:rgba(201,162,75,.06);}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:15px 38px;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;border:1px solid var(--gold);color:var(--gold);background:transparent;transition:.25s var(--ease);}
.btn:hover{background:var(--gold-grad);color:#1a1306;border-color:transparent;}
.btn.solid{background:var(--gold-grad);color:#1a1306;border-color:transparent;}
.btn.solid:hover{filter:brightness(1.08);}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:74vh;display:flex;align-items:center;background:radial-gradient(120% 90% at 75% 18%,rgba(201,162,75,.16),transparent 55%),radial-gradient(80% 70% at 10% 90%,rgba(201,162,75,.08),transparent 60%),var(--black);border-bottom:1px solid var(--line);overflow:hidden;}
.hero::after{content:"";position:absolute;inset:22px;border:1px solid var(--line);pointer-events:none;}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:70px 28px;position:relative;z-index:2;width:100%;}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);font-weight:500;letter-spacing:.01em;margin:14px 0 0;}
.hero h1 em{font-style:italic;}
.hero p{max-width:440px;color:var(--muted);margin:20px 0 32px;font-size:1.02rem;}

/* ---------- Page banner (inner pages) ---------- */
.page-banner{position:relative;text-align:center;padding:64px 28px 56px;background:radial-gradient(90% 130% at 50% 0%,rgba(201,162,75,.12),transparent 60%),var(--black);border-bottom:1px solid var(--line);}
.page-banner h1{font-size:clamp(2.4rem,5vw,3.8rem);}
.page-banner .rule{width:56px;height:1px;background:var(--gold);margin:18px auto 0;}
.breadcrumb{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.breadcrumb a:hover{color:var(--gold);}

/* ---------- Sections ---------- */
section{padding:84px 0;}
.sec-head{text-align:center;margin-bottom:48px;}
.sec-head h2{font-size:clamp(2rem,4vw,3rem);margin-top:10px;}
.rule{width:56px;height:1px;background:var(--gold);margin:18px auto 0;}

/* ---------- Category tiles ---------- */
.tiles{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;}
.tile{position:relative;flex:0 1 calc((100% - 36px) / 3);aspect-ratio:4/5;border:1px solid var(--line);background:linear-gradient(160deg,var(--black-card),#0d0c0d);display:flex;align-items:flex-end;overflow:hidden;transition:.4s var(--ease);}
.tile::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 35%,rgba(201,162,75,.14),transparent 70%);transition:.5s var(--ease);z-index:1;}
.tile .tile-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75),transparent 55%);z-index:2;}
.tile:hover{border-color:var(--gold);transform:translateY(-4px);}
.tile:hover .tile-img{transform:scale(1.05);}
.tile .tile-img{transition:.5s var(--ease);}
.tile .label{position:relative;z-index:3;width:100%;padding:22px;display:flex;justify-content:space-between;align-items:flex-end;}
.tile .label h3{font-size:1.7rem;}
.tile .label span{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);}
.tile .arrow{font-size:1.1rem;color:var(--gold);}

/* ---------- Product grid & cards ---------- */
.products{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.card{border:1px solid var(--line);background:var(--black-soft);transition:.3s var(--ease);display:flex;flex-direction:column;}
.card:hover{border-color:var(--gold);transform:translateY(-4px);}
.card .ph{position:relative;aspect-ratio:1/1;background:radial-gradient(70% 60% at 50% 40%,rgba(201,162,75,.16),transparent 72%),linear-gradient(160deg,#19181a,#0e0d0e);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.card .ph .ph-label{font-family:'Cormorant Garamond',serif;font-style:italic;color:rgba(201,162,75,.5);font-size:.95rem;letter-spacing:.05em;}
.card .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.card .info{padding:18px 18px 22px;text-align:center;}
.card .info .cat{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px;}
.card .info .pname{font-family:'Jost';font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ivory);font-weight:400;}
.card .info .price{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--gold);margin-top:6px;}
.card .info .pcond{font-size:.66rem;letter-spacing:.06em;color:var(--muted);margin-top:8px;font-style:italic;}
.card .add{margin-top:14px;width:100%;padding:11px;background:transparent;border:1px solid var(--line);color:var(--ivory);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;transition:.22s;}
.card .add:hover{background:var(--gold-grad);color:#1a1306;border-color:transparent;}
.center-cta{text-align:center;margin-top:48px;}

/* ---------- Shop filter bar ---------- */
.filter-bar{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:44px;}
.filter-bar button{background:transparent;border:1px solid var(--line);color:var(--muted);padding:10px 22px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;transition:.2s;}
.filter-bar button:hover{color:var(--gold);}
.filter-bar button.active{background:var(--gold-grad);color:#1a1306;border-color:transparent;}
.empty-grid{text-align:center;color:var(--muted);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;padding:40px;}

/* ---------- Product detail ---------- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.pd-img{position:relative;aspect-ratio:1/1;border:1px solid var(--line);background:radial-gradient(70% 60% at 50% 40%,rgba(201,162,75,.16),transparent 72%),linear-gradient(160deg,#19181a,#0e0d0e);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.pd-img .ph-label{font-family:'Cormorant Garamond',serif;font-style:italic;color:rgba(201,162,75,.5);}
.pd-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.pd-info .cat{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.pd-info h1{font-size:clamp(2rem,4vw,3rem);margin:10px 0 14px;}
.pd-info .price{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--gold);margin-bottom:22px;}
.pd-info p.desc{color:var(--muted);margin-bottom:28px;max-width:440px;}
.pd-meta{border-top:1px solid var(--line);margin-bottom:28px;max-width:460px;}
.pd-meta .meta-row{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid var(--line);}
.pd-meta .meta-k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);}
.pd-meta .meta-v{font-size:.84rem;letter-spacing:.04em;text-align:right;}
.pd-info label{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;}
.pd-row{display:flex;gap:18px;margin-bottom:26px;flex-wrap:wrap;}
.pd-row .field{flex:1;min-width:120px;}
.pd select,.pd input[type=number]{width:100%;background:var(--black-soft);border:1px solid var(--line);color:var(--ivory);padding:13px 14px;font-family:inherit;}
.pd select:focus,.pd input:focus{outline:none;border-color:var(--gold);}
.pd-actions{display:flex;gap:14px;flex-wrap:wrap;}
.pd-note{color:var(--muted);font-size:.78rem;margin-top:20px;}
.pd-note a{color:var(--gold);}

/* ---------- Trust band ---------- */
.trust{background:var(--black-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.trust .t h3{font-size:1.3rem;margin-bottom:6px;}
.trust .t p{color:var(--muted);font-size:.82rem;margin:0;}
.trust .t .ic{color:var(--gold);margin-bottom:14px;}
.trust .t .ic svg{width:30px;height:30px;}

/* ---------- Newsletter ---------- */
.news{text-align:center;background:radial-gradient(90% 120% at 50% 0%,rgba(201,162,75,.1),transparent 60%),var(--black);}
.news h2{font-size:clamp(2rem,4vw,3rem);}
.news p{color:var(--muted);max-width:420px;margin:14px auto 30px;}
.news-form{display:flex;max-width:440px;margin:0 auto;}
.news-form input{flex:1;background:transparent;border:1px solid var(--line);border-right:none;color:var(--ivory);padding:15px 18px;font-family:inherit;letter-spacing:.05em;}
.news-form input::placeholder{color:var(--muted);}
.news-form input:focus{outline:none;border-color:var(--gold);}
.news-form button{background:var(--gold-grad);color:#1a1306;border:none;padding:0 30px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.contact-card{border:1px solid var(--line);background:var(--black-soft);padding:40px;text-align:center;}
.contact-card .ic{color:var(--gold);margin-bottom:18px;}
.contact-card .ic svg{width:40px;height:40px;}
.contact-card h3{font-size:1.7rem;margin-bottom:10px;}
.contact-card p{color:var(--muted);font-size:.9rem;margin:0 0 22px;}
.contact-handle{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--gold);margin-bottom:22px;}
.contact-form label{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:18px 0 8px;}
.contact-form input,.contact-form textarea{width:100%;background:var(--black-soft);border:1px solid var(--line);color:var(--ivory);padding:13px 14px;font-family:inherit;}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold);}
.contact-form textarea{min-height:130px;resize:vertical;}
.contact-form .btn{margin-top:24px;border:none;width:100%;}

/* ---------- Footer ---------- */
footer{background:#000;border-top:1px solid var(--line);padding:64px 0 32px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;}
.foot-logo{height:66px;width:auto;margin-bottom:4px;}
.foot-brand p{color:var(--muted);font-size:.84rem;max-width:260px;margin:16px 0 18px;}
.socials{display:flex;gap:14px;}
.socials a{color:var(--gold);border:1px solid var(--line);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.22s;}
.socials a:hover{background:var(--gold-grad);color:#1a1306;border-color:transparent;}
.socials svg{width:18px;height:18px;}
.foot-col h4{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;font-family:'Jost';font-weight:500;}
.foot-col a{display:block;color:var(--muted);font-size:.84rem;padding:6px 0;transition:.18s;}
.foot-col a:hover{color:var(--ivory);}
.foot-bottom{border-top:1px solid var(--line);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;}
.foot-bottom small{color:var(--muted);font-size:.74rem;letter-spacing:.06em;}
.pay{display:flex;gap:8px;flex-wrap:wrap;}
.pay span{font-size:.6rem;letter-spacing:.12em;color:var(--muted);border:1px solid var(--line);padding:5px 9px;border-radius:4px;text-transform:uppercase;}

/* ---------- Cart drawer ---------- */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:.3s;z-index:90;}
.overlay.open{opacity:1;visibility:visible;}
.drawer{position:fixed;top:0;right:0;height:100%;width:380px;max-width:88vw;background:var(--black-soft);border-left:1px solid var(--line);transform:translateX(100%);transition:.35s var(--ease);z-index:100;display:flex;flex-direction:column;}
.drawer.open{transform:translateX(0);}
.drawer .dhead{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--line);}
.drawer .dhead h3{font-size:1.3rem;}
.drawer .dbody{flex:1;padding:24px;overflow-y:auto;}
.drawer .empty{color:var(--muted);text-align:center;margin-top:40px;font-style:italic;font-family:'Cormorant Garamond',serif;font-size:1.1rem;}
.drawer .ditem{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);align-items:center;}
.drawer .ditem .thumb{width:54px;height:54px;background:linear-gradient(160deg,#1c1a1c,#0e0d0e);border:1px solid var(--line);flex:none;overflow:hidden;}
.drawer .ditem .thumb img{width:100%;height:100%;object-fit:cover;}
.drawer .ditem .nm{font-size:.78rem;letter-spacing:.08em;}
.drawer .ditem .qty{font-size:.66rem;color:var(--muted);}
.drawer .ditem .pr{color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:1.05rem;}
.drawer .ditem .rm{margin-left:auto;color:var(--muted);background:none;border:none;font-size:.95rem;}
.drawer .ditem .rm:hover{color:var(--gold);}
.drawer .dfoot{padding:22px 24px;border-top:1px solid var(--line);}
.drawer .totrow{display:flex;justify-content:space-between;margin-bottom:16px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;}
.drawer .totrow .tot{color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:1.4rem;}
.drawer .checkout{width:100%;padding:15px;background:var(--gold-grad);color:#1a1306;border:none;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;}
.drawer .note{color:var(--muted);font-size:.68rem;text-align:center;margin-top:12px;letter-spacing:.04em;}
.drawer .note a{color:var(--gold);}

/* ---------- Mobile menu ---------- */
.hamburger{display:none;}
.mobile-menu{position:fixed;inset:0;background:var(--black);z-index:95;transform:translateX(-100%);transition:.35s var(--ease);padding:90px 32px;overflow-y:auto;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{display:block;padding:15px 0;border-bottom:1px solid var(--line);font-size:1.1rem;letter-spacing:.14em;text-transform:uppercase;font-family:'Cormorant Garamond',serif;}
.mobile-menu .close{position:absolute;top:24px;right:28px;background:none;border:none;color:var(--gold);font-size:1.8rem;line-height:1;}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--black-soft);border:1px solid var(--gold);color:var(--ivory);padding:13px 26px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;z-index:120;opacity:0;transition:.3s var(--ease);pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .tile{flex-basis:calc((100% - 18px) / 2);}
  .products{grid-template-columns:repeat(2,1fr);}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:36px;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px;}
  .pd{grid-template-columns:1fr;gap:32px;}
  .contact-grid{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:680px){
  nav.primary{display:none;}
  .hamburger{display:inline-flex;}
  .bar{grid-template-columns:auto 1fr auto;}
  .brand-logo{height:50px;}
  section{padding:60px 0;}
  .hero{min-height:64vh;}
  .tile{flex-basis:100%;}
  .hero::after{inset:14px;}
  .foot-grid{grid-template-columns:1fr;}
  .foot-bottom{justify-content:center;text-align:center;}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important;}}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
