/* C.L Khanna Jewellers — v4 · refined luxury */
:root{
  --ink:#15130e; --gold:#a8862f; --gold-soft:#cdb36e; --gold-deep:#86691f;
  --paper:#fffdf9; --ivory:#f8f4ec; --line:#e6dec9; --muted:#8a8172;
  --serif:'Cormorant Garamond',serif; --disp:'Marcellus',serif; --sans:'Jost',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:300;color:var(--ink);background:var(--paper);line-height:1.65}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:400}
.wrap{max-width:1300px;margin:0 auto;padding:0 4%}
.eyebrow{font-size:.68rem;letter-spacing:.46em;text-transform:uppercase;color:var(--gold-deep)}
.rule{width:50px;height:1px;background:var(--gold);margin:18px auto}

/* ---------- header ---------- */
header.site{background:var(--paper)}
.bar{display:flex;align-items:center;justify-content:space-between;padding:20px 4%;max-width:1400px;margin:0 auto}
.brand img{height:84px;width:auto}
.actions{display:flex;align-items:center;gap:22px}
.actions .ic{background:none;border:none;cursor:pointer;color:var(--ink);width:24px;height:24px;padding:0;transition:.3s}
.actions .ic svg{width:22px;height:22px;display:block}
.actions .ic:hover{color:var(--gold-deep)}
.country{font-size:.74rem;letter-spacing:.18em;color:var(--muted);border:1px solid var(--line);padding:5px 10px;cursor:default}
.burger{background:none;border:none;cursor:pointer;width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;padding:0}
.burger span{display:block;height:1.4px;width:100%;background:var(--ink);transition:.3s}
.burger:hover span{background:var(--gold-deep)}
.hairline{height:1px;background:var(--ink);opacity:.85}

/* drawer */
.drawer-veil{position:fixed;inset:0;background:rgba(21,19,14,.5);opacity:0;visibility:hidden;transition:.3s;z-index:110}
.drawer-veil.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:-360px;width:330px;max-width:90vw;height:100vh;background:var(--paper);z-index:120;transition:right .4s cubic-bezier(.22,.8,.3,1);overflow-y:auto;padding:66px 34px 44px;border-left:1px solid var(--line)}
.drawer.open{right:0}
.drawer .dx{position:absolute;top:16px;right:20px;background:none;border:none;font-size:1.6rem;color:var(--muted);cursor:pointer}
.drawer a{display:block}
.drawer .d-home,.drawer .d-cat{font-family:var(--disp);font-size:.82rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);padding:14px 0;border-bottom:1px solid #efe9da}
.drawer .d-cat:hover,.drawer .d-home:hover{color:var(--gold-deep)}
.drawer .d-sub{font-size:.74rem;letter-spacing:.16em;color:var(--muted);padding:8px 0 8px 20px}
.drawer .d-sub:hover{color:var(--gold-deep)}
.drawer .d-group{border-bottom:1px solid #efe9da;padding-bottom:10px}
.drawer .d-group .d-cat{border-bottom:none;padding-bottom:8px}
.drawer .d-appt{margin-top:30px;text-align:center;border:1px solid var(--gold);color:var(--gold-deep);padding:13px;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase}
.drawer .d-appt:hover{background:var(--gold);color:#fff}

/* search overlay */
.search-veil{position:fixed;inset:0;background:rgba(252,250,245,.98);z-index:125;display:none;justify-content:center;padding:14vh 6vw 6vh}
.search-veil.open{display:flex}
.search-box{width:100%;max-width:680px;position:relative}
.search-box .dx{position:absolute;top:-56px;right:0;background:none;border:none;font-size:2rem;color:var(--muted);cursor:pointer}
.search-box input{width:100%;border:none;border-bottom:1px solid var(--ink);background:none;padding:14px 4px;font-family:var(--serif);font-size:1.5rem;color:var(--ink);outline:none}
.search-box input::placeholder{color:#b6ad9c}
.sres{margin-top:26px;max-height:55vh;overflow-y:auto}
.sres a{display:flex;gap:18px;align-items:center;padding:12px 6px;border-bottom:1px solid var(--line);transition:.25s}
.sres a:hover{background:var(--ivory)}
.sres img{width:62px;height:62px;object-fit:contain;background:#fff;border:1px solid var(--line)}
.sres b{display:block;font-family:var(--disp);font-weight:400;font-size:1rem}
.sres small{color:var(--muted);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase}
.sres .nores{padding:18px 4px;font-family:var(--serif);color:var(--muted)}

/* ---------- hero slider — framed, zoomed out ---------- */
.slider{position:relative;height:82vh;min-height:520px;overflow:hidden;background:var(--ivory)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.3s ease;z-index:1}
.slide.on{opacity:1;z-index:2}
.slide .bg{position:absolute;inset:-40px;background-size:cover;background-position:center;filter:blur(34px) saturate(.86) brightness(1.04);opacity:.55}
.slide .frame{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;align-items:center;max-width:1300px;margin:0 auto;padding:0 4%;gap:4%}
.slide .txt{z-index:3}
.slide .txt h2{font-size:clamp(2rem,3.8vw,3.3rem);line-height:1.12;margin:14px 0 26px;max-width:16ch}
.slide .txt h2 em{font-family:var(--serif);font-style:italic;color:var(--gold-deep)}
.slide .pic{height:72vh;min-height:430px;display:flex;align-items:center;justify-content:center;z-index:3}
.slide .pic img{max-height:100%;max-width:100%;object-fit:contain;box-shadow:0 30px 80px rgba(60,48,20,.25);border:6px solid #fff}
.dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:12px}
.dots button{width:38px;height:2px;border:none;background:rgba(21,19,14,.22);cursor:pointer;transition:.3s}
.dots button.on{background:var(--gold)}

/* page head band */
.pagehead{background:var(--ivory);text-align:center;padding:52px 4% 44px;border-bottom:1px solid var(--line)}
.pagehead h1{font-size:clamp(1.8rem,3.4vw,2.6rem);letter-spacing:.06em}
.pagehead p{color:var(--muted);font-family:var(--serif);font-size:1.12rem;margin-top:8px}

/* buttons */
.btn{display:inline-block;padding:15px 36px;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;border:1px solid var(--gold);transition:.35s;cursor:pointer}
.btn.solid{background:var(--gold);color:#fff}
.btn.solid:hover{background:var(--gold-deep)}
.btn.ghost{color:var(--gold-deep)}
.btn.ghost:hover{background:rgba(168,134,47,.08)}
.cta-row{display:flex;gap:16px;margin-top:30px;flex-wrap:wrap}

section{padding:88px 0}
.sec-head{text-align:center;max-width:660px;margin:0 auto 54px}
.sec-head h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-top:14px;letter-spacing:.04em}

/* shop by collection */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tile{position:relative;overflow:hidden;height:520px;background:var(--ivory)}
.tile img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform 1.1s ease}
.tile:hover img{transform:scale(1.04)}
.tile .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(21,19,14,.72),rgba(21,19,14,0) 50%)}
.tile .label{position:absolute;bottom:28px;left:0;right:0;text-align:center;color:#fff}
.tile .label h3{font-size:1.35rem;letter-spacing:.12em}
.tile .label small{font-size:.64rem;letter-spacing:.38em;text-transform:uppercase;color:var(--gold-soft)}
.tile .label .shop{display:inline-block;margin-top:10px;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:#fff;border-bottom:1px solid var(--gold-soft);padding-bottom:3px}

/* product grid */
.subbar{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:44px}
.subbar button{background:none;border:1px solid var(--line);padding:10px 24px;font-family:var(--sans);font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:.3s}
.subbar button.active,.subbar button:hover{border-color:var(--gold);color:var(--gold-deep)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.card{display:block;border:1px solid var(--line);background:#fff;transition:.4s;text-align:center;overflow:hidden}
.card:hover{box-shadow:0 18px 50px rgba(120,95,40,.13);transform:translateY(-5px)}
.card .ph{aspect-ratio:1/1;overflow:hidden;background:#fff}
.card .ph img{width:100%;height:100%;object-fit:contain;transition:transform .7s}
.card:hover .ph img{transform:scale(1.05)}
.card .info{padding:20px 16px 24px;border-top:1px solid #f2ecdd}
.card .info h3{font-size:1.05rem;letter-spacing:.04em}
.card .info p{font-family:var(--serif);font-size:.97rem;color:var(--muted);margin:7px 0 13px;min-height:2.6em}
.card .rfp{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);border-bottom:1px solid var(--gold);padding-bottom:3px;transition:.3s}
.card:hover .rfp{color:var(--ink)}
.count{text-align:center;color:var(--muted);font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:30px}

/* customized banner */
.custom-band{background:var(--ink);color:var(--ivory);padding:0}
.custom-band .inner{display:grid;grid-template-columns:.95fr 1.05fr;align-items:stretch;max-width:1400px;margin:0 auto}
.custom-band .img{min-height:480px;overflow:hidden}
.custom-band .img img{width:100%;height:100%;object-fit:cover;object-position:top}
.custom-band .txt{padding:80px 7%;display:flex;flex-direction:column;justify-content:center}
.custom-band .eyebrow{color:var(--gold-soft)}
.custom-band h2{font-size:clamp(1.8rem,3vw,2.5rem);margin:14px 0 16px}
.custom-band p{font-family:var(--serif);font-size:1.18rem;color:#cfc6b4;max-width:50ch}
.custom-band .btn.ghost{color:var(--gold-soft)}

/* testimonials */
.testi{background:var(--ivory)}
.testi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.t-card{background:#fff;border:1px solid var(--line);padding:36px 30px}
.t-card:before{content:"“";font-family:var(--serif);font-size:3.6rem;color:var(--gold-soft);line-height:1;display:block;margin-bottom:8px}
.t-card p{font-family:var(--serif);font-size:1.05rem;color:#56503f;font-style:italic}
.t-card b{display:block;margin-top:20px;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}

/* connect blocks */
.connect{padding-top:0}
.connect-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.c-block{border:1px solid var(--line);background:#fff;text-align:center;padding:54px 30px;transition:.4s;display:block}
.c-block:hover{box-shadow:0 18px 50px rgba(120,95,40,.13);transform:translateY(-5px);border-color:var(--gold-soft)}
.c-block svg{width:34px;height:34px;margin:0 auto 18px;color:var(--gold-deep)}
.c-block h3{font-size:1.15rem;letter-spacing:.08em}
.c-block p{font-family:var(--serif);color:var(--muted);margin-top:8px;font-size:1rem}
.c-block span{display:inline-block;margin-top:16px;font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);border-bottom:1px solid var(--gold);padding-bottom:3px}

/* instagram */
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.ig-grid a{position:relative;overflow:hidden;aspect-ratio:1/1}
.ig-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s,filter .4s}
.ig-grid a:hover img{transform:scale(1.06);filter:brightness(.7)}
.ig-grid a:after{content:"";position:absolute;inset:0;opacity:0;transition:.4s;background:rgba(21,19,14,.18)}
.ig-grid a:hover:after{opacity:1}
.ig-cta{text-align:center;margin-top:36px}

/* lookbook */
.lookbook{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lookbook a{overflow:hidden;background:var(--ivory)}
.lookbook img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;transition:transform .8s}
.lookbook a:hover img{transform:scale(1.04)}

/* product detail */
.crumbs{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:36px}
.crumbs a:hover{color:var(--gold-deep)}
.crumbs span{color:var(--ink)}
.pd-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:start}
.pd-photo{border:1px solid var(--line);overflow:hidden;cursor:crosshair;background:#fff}
.pd-photo img{width:100%;aspect-ratio:1/1;object-fit:contain;transition:transform .25s ease}
.pd-info h1{font-size:clamp(1.7rem,3vw,2.4rem);margin:10px 0 12px}
.pd-desc{font-family:var(--serif);font-size:1.22rem;color:#56503f}
.pd-specs{margin:32px 0;border-top:1px solid var(--line)}
.pd-specs div{display:grid;grid-template-columns:185px 1fr;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.pd-specs b{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);font-weight:500;align-self:center}
.pd-specs span{font-size:.98rem;color:#4d4639}
.pd-note{margin-top:28px;font-family:var(--serif);color:var(--muted)}
.pd-note a{color:var(--gold-deep);border-bottom:1px solid var(--gold-soft)}

/* about / loc / policy */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.about-grid .img{position:relative}
.about-grid .img img{width:100%;height:560px;object-fit:cover;object-position:top}
.about-grid .img img{position:relative;z-index:1}
.about-grid .img:after{content:"";position:absolute;z-index:0;top:16px;left:16px;right:-16px;bottom:-16px;border:1px solid var(--gold-soft);pointer-events:none}
.about-grid p{margin-top:16px;font-family:var(--serif);font-size:1.14rem;color:#56503f}
.stats{display:flex;gap:48px;margin-top:40px;flex-wrap:wrap}
.stats b{display:block;font-family:var(--disp);font-size:2.1rem;color:var(--gold-deep);font-weight:400}
.stats span{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:stretch}
.vrow{display:flex;gap:16px;margin-top:26px;align-items:flex-start}
.vrow .ic{color:var(--gold);margin-top:2px}
.vrow b{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);display:block;margin-bottom:4px;font-weight:500}
.vrow p,.vrow a{color:#4d4639;font-size:1rem}
.map{min-height:440px;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;border:0;display:block}
.policy{max-width:820px;margin:0 auto}
.policy h2{font-size:1.3rem;margin:36px 0 10px}
.policy p,.policy li{color:#4d4639;font-size:1rem;margin-bottom:10px}
.policy ul{padding-left:22px}

/* footer */
footer{background:var(--ink);color:#a89e8b;padding:62px 0 36px;margin-top:44px}
footer .cols{display:grid;grid-template-columns:1fr 1fr 1.35fr .7fr;gap:44px;align-items:start}
footer h4{font-family:var(--disp);color:var(--gold-soft);font-weight:400;font-size:.9rem;letter-spacing:.26em;text-transform:uppercase;margin-bottom:18px}
footer a{display:block;padding:6px 0;font-size:.92rem;line-height:1.55}
footer a:hover{color:var(--gold-soft)}
footer .socials{display:flex;gap:16px}
footer .socials a{border:1px solid rgba(205,179,110,.4);width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;transition:.3s}
footer .socials a:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
footer .socials svg{width:19px;height:19px}
footer .base{border-top:1px solid rgba(255,255,255,.08);margin-top:44px;padding-top:24px;text-align:center;font-size:.72rem;letter-spacing:.16em}

/* whatsapp float */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:99;width:56px;height:56px;border-radius:50%;background:#1ebe5d;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(0,0,0,.3);transition:.3s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:29px;height:29px;fill:#fff}

/* modal */
.modal{position:fixed;inset:0;background:rgba(21,19,14,.6);z-index:130;display:none;align-items:center;justify-content:center;padding:5vh 4vw}
.modal.open{display:flex}
.modal .box{background:#fff;max-width:480px;width:100%;padding:44px 42px;position:relative;text-align:center;max-height:90vh;overflow-y:auto}
.modal .box:before{content:"";position:absolute;inset:9px;border:1px solid var(--gold-soft);pointer-events:none}
.modal h3{font-size:1.5rem;margin-bottom:6px}
.modal p.sub{font-family:var(--serif);color:var(--muted);margin-bottom:20px}
.modal label{display:block;text-align:left;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);margin:14px 0 6px}
.modal input,.modal select{width:100%;padding:12px 14px;border:1px solid var(--line);font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff}
.modal .send{margin-top:26px;width:100%}
.modal .x{position:absolute;top:10px;right:16px;background:none;border:none;font-size:1.4rem;color:var(--muted);cursor:pointer;z-index:2}

.rv{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
.rv.in{opacity:1;transform:none}

@media(max-width:1080px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .tiles{grid-template-columns:1fr}
  .tile{height:420px}
  .about-grid,.loc-grid,.pd-grid{grid-template-columns:1fr}
  .lookbook{grid-template-columns:repeat(2,1fr)}
  .testi-grid,.connect-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .custom-band .inner{grid-template-columns:1fr}
  .custom-band .img{min-height:340px}
  footer .cols{grid-template-columns:1fr 1fr}
  .slide .frame{grid-template-columns:1fr;align-content:end;padding-bottom:80px}
  .slide .pic{display:none}
  .slide .bg{filter:blur(0);opacity:1}
  .slide .txt{color:#fff;background:linear-gradient(to top,rgba(21,19,14,.55),transparent);padding:24px;margin:0 -24px}
  .slide .txt .eyebrow{color:var(--gold-soft)}
}
@media(max-width:760px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .brand img{height:60px}
  .country{display:none}
  .slider{height:64vh;min-height:420px}
  .testi-grid,.connect-grid{grid-template-columns:1fr}
  .ig-grid{grid-template-columns:repeat(2,1fr)}
  footer .cols{grid-template-columns:1fr;text-align:center}
  footer .socials{justify-content:center}
  .pd-specs div{grid-template-columns:1fr;gap:2px;padding:10px 0}
}
@media(max-width:480px){
  .grid{grid-template-columns:1fr}
  .lookbook{grid-template-columns:1fr}
}


/* ================= v4.1 overrides ================= */
/* header: burger left, logo absolute centre, icons right */
.bar{position:relative;justify-content:space-between;padding:24px 4%}
.bar .brand{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
.brand img{height:92px}

/* drawer slides from the left */
.drawer{left:-360px;right:auto;border-left:none;border-right:1px solid var(--line);transition:left .4s cubic-bezier(.22,.8,.3,1)}
.drawer.open{left:0;right:auto}

/* shop accordion inside drawer */
.drawer .d-group .d-sub{display:none}
.drawer .d-group.openg .d-sub{display:block}
.drawer .d-cat i{float:right;font-style:normal;color:var(--gold-deep)}
.drawer .d-strong{font-family:var(--disp);color:var(--ink);letter-spacing:.2em;text-transform:uppercase;font-size:.74rem;padding-top:12px}
.drawer .d-sub2{padding-left:34px}

/* custom creations — 4 steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(205,179,110,.35);margin-top:46px}
.step{padding:38px 30px;border-right:1px solid rgba(205,179,110,.35);text-align:center}
.step:last-child{border-right:none}
.step b{display:block;font-family:var(--serif);font-size:2rem;color:var(--gold-soft);font-weight:400;font-style:italic;margin-bottom:10px}
.step h3{font-size:1.02rem;letter-spacing:.1em;color:var(--ivory)}
.step p{font-family:var(--serif);font-size:.98rem;color:#b3a98f;margin-top:8px}

/* testimonial carousel */
.t-carousel{position:relative;max-width:760px;margin:0 auto;min-height:230px;text-align:center}
.t-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;padding:0 6%}
.t-slide.on{opacity:1}
.t-slide:before{content:"“";font-family:var(--serif);font-size:4.6rem;color:var(--gold-soft);line-height:1;display:block;margin-bottom:6px}
.t-slide p{font-family:var(--serif);font-size:1.35rem;font-style:italic;color:#4f4937;line-height:1.6}
.t-slide b{display:block;margin-top:22px;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}
.t-dots{display:flex;gap:11px;justify-content:center;margin-top:34px}
.t-dots button{width:30px;height:2px;border:none;background:rgba(21,19,14,.18);cursor:pointer;transition:.3s}
.t-dots button.on{background:var(--gold)}

/* editorial gallery on home — zoomed out 2:3 */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery a{overflow:hidden;background:var(--ivory)}
.gallery img{width:100%;aspect-ratio:2/3;object-fit:cover;object-position:center top;transition:transform 1s}
.gallery a:hover img{transform:scale(1.03)}
.lookbook img{aspect-ratio:2/3}

/* newsletter band in footer */
footer .news{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;border:1px solid rgba(205,179,110,.3);padding:36px 40px;margin-bottom:52px}
footer .news h4{margin-bottom:6px}
footer .news p{font-family:var(--serif);color:#b3a98f;font-size:1.05rem}
footer .news form{display:flex;gap:12px}
footer .news input{flex:1;background:none;border:1px solid rgba(205,179,110,.4);padding:13px 16px;color:var(--ivory);font-family:var(--sans);font-size:.95rem;outline:none}
footer .news input::placeholder{color:#8d8470}
footer .news .nl-thanks{font-family:var(--serif);color:var(--gold-soft);font-size:1.1rem;font-style:italic}
footer .ig-handle{margin-top:14px;color:var(--gold-soft);letter-spacing:.08em}
footer .base a{display:inline;padding:0}
footer .base a:hover{color:var(--gold-soft)}

@media(max-width:1080px){
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:nth-child(2n){border-right:none}
  .step{border-bottom:1px solid rgba(205,179,110,.35)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  footer .news{grid-template-columns:1fr}
}
@media(max-width:760px){
  .brand img{height:58px}
  .steps{grid-template-columns:1fr}
  .step{border-right:none}
  .gallery{grid-template-columns:1fr}
  footer .news form{flex-direction:column}
  .t-carousel{min-height:300px}
}


/* ================= v5 corrections ================= */
/* bigger logo, thinner lower hairline */
.brand img{height:118px}
.bar{padding:30px 4% 26px}
.hairline{height:1px;background:rgba(21,19,14,.45);margin-top:2px}

/* custom creations — light, matches the rest */
.custom-band{background:var(--ivory);color:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.custom-band .eyebrow{color:var(--gold-deep)}
.custom-band p{color:#6b6353}
.custom-band .steps{border:1px solid var(--line);background:#fff}
.custom-band .step{border-right:1px solid var(--line)}
.custom-band .step h3{color:var(--ink)}
.custom-band .step p{color:var(--muted)}
.custom-band .step b{color:var(--gold-deep)}
.custom-band .btn.ghost{color:var(--gold-deep)}

/* footer — line on top like header, 4 columns, centered copyright */
footer{margin-top:54px;padding-top:0}
footer .topline{height:1px;background:rgba(205,179,110,.5);margin-bottom:56px}
footer .cols{grid-template-columns:1fr 1fr 1.3fr .8fr}
footer .base{margin-top:46px}

@media(max-width:1080px){
  .custom-band .step{border-bottom:1px solid var(--line)}
}
@media(max-width:760px){
  .brand img{height:64px}
  .bar{padding:18px 4% 14px}
}


/* ================= v5.1 fine-tuning ================= */
/* logo clear of the line — line sits lower with breathing room */
.bar{padding:34px 4% 34px}
.hairline{margin-top:0}

/* smaller social icons in footer */
footer .socials a{width:32px;height:32px}
footer .socials svg{width:14px;height:14px}

/* custom creations steps — 2×2 so every step fits cleanly */
.custom-band .steps{grid-template-columns:repeat(2,1fr)}
.custom-band .step{border-bottom:1px solid var(--line);padding:30px 26px}
.custom-band .step:nth-child(2n){border-right:none}
.custom-band .step:nth-child(3),.custom-band .step:nth-child(4){border-bottom:none}
@media(max-width:760px){
  .custom-band .steps{grid-template-columns:1fr}
  .custom-band .step{border-right:none;border-bottom:1px solid var(--line)}
  .custom-band .step:last-child{border-bottom:none}
}


/* ================= v5.2 — logo clearance + footer ================= */
.bar{min-height:188px;padding:28px 4%}
.brand img{height:118px}
.hairline{height:1px;background:rgba(21,19,14,.25)}

/* footer rows with icons, khurana-style */
footer .git a{display:flex;gap:10px;align-items:flex-start}
footer .git svg{width:15px;height:15px;flex:none;margin-top:5px;color:var(--gold-soft)}
@media(max-width:760px){
  .bar{min-height:112px;padding:16px 4%}
  .brand img{height:64px}
  footer .git a{justify-content:center}
}


/* v5.3 — guaranteed clearance between logo and hairline */
.bar{min-height:200px}
.brand img{height:150px}  /* artwork same visual size; file now carries built-in padding */
@media(max-width:760px){
  .bar{min-height:118px}
  .brand img{height:84px}
}


/* v5.4 — footer typography smaller, icons locked */
footer a{font-size:.84rem;padding:5px 0}
footer h4{font-size:.8rem;margin-bottom:14px}
footer .git svg,footer .socials svg{max-width:15px;max-height:15px}
footer .socials a{width:30px;height:30px}
footer .base{font-size:.68rem}


/* ================= shop: cart + accounts ================= */
.actions .ic{position:relative}
.cartn{position:absolute;top:-7px;right:-9px;background:var(--gold);color:#fff;font-size:.58rem;min-width:15px;height:15px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 3px;font-family:var(--sans)}
.toast{position:fixed;bottom:96px;right:24px;z-index:150;background:var(--ink);color:var(--ivory);padding:13px 22px;font-size:.8rem;letter-spacing:.14em;opacity:0;transform:translateY(8px);transition:.35s;pointer-events:none}
.toast.show{opacity:1;transform:none}
.cart-row{display:grid;grid-template-columns:96px 1fr auto auto;gap:20px;align-items:center;border:1px solid var(--line);background:#fff;padding:16px 20px;margin-bottom:14px}
.cart-row img{width:96px;height:96px;object-fit:contain;background:#fff;border:1px solid var(--line)}
.cart-row .ci h3{font-size:1.05rem}
.cart-row .ci small{color:var(--muted);font-size:.78rem;letter-spacing:.08em;display:block;margin-top:2px}
.cart-row .price-note{font-family:var(--serif);font-style:italic;color:var(--gold-deep);font-size:.92rem}
.cq{display:flex;align-items:center;gap:10px}
.cq button{width:28px;height:28px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:1rem;color:var(--ink)}
.cq button:hover{border-color:var(--gold)}
.cx{background:none;border:none;font-size:1.3rem;color:var(--muted);cursor:pointer}
.cx:hover{color:#a33}
.cart-empty{font-family:var(--serif);font-size:1.2rem;color:var(--muted);text-align:center;padding:60px 0}
.cart-empty a{color:var(--gold-deep);border-bottom:1px solid var(--gold-soft)}
.cart-actions{margin-top:30px}
.cart-note-l{display:block;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.cart-actions textarea{width:100%;border:1px solid var(--line);padding:12px 14px;font-family:var(--sans);font-size:.95rem;resize:vertical;background:#fff}
.cart-fine{margin-top:18px;font-family:var(--serif);color:var(--muted);font-size:.95rem}
.au-err{color:#a33;font-size:.85rem;min-height:1.2em;margin-top:10px;text-align:left}
.auth-btns{display:flex;gap:12px;margin-top:18px;justify-content:center;flex-wrap:wrap}
.signed{font-family:var(--serif);font-size:1.05rem;margin:10px 0 6px}
@media(max-width:640px){
  .cart-row{grid-template-columns:72px 1fr;grid-template-rows:auto auto}
  .cart-row img{width:72px;height:72px}
  .cq{grid-column:2}
}


/* ================= v5.5 — editorial auto-slideshow + mobile header ================= */
.ed-carousel{position:relative;overflow:hidden}
.ed-carousel:before,.ed-carousel:after{content:"";position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none}
.ed-carousel:before{left:0;background:linear-gradient(to right,var(--paper),rgba(255,253,249,0))}
.ed-carousel:after{right:0;background:linear-gradient(to left,var(--paper),rgba(255,253,249,0))}
.ed-track{display:flex;gap:20px;width:max-content;animation:edscroll 46s linear infinite}
.ed-carousel:hover .ed-track{animation-play-state:paused}
.ed-track a{flex:0 0 auto;width:300px;overflow:hidden;background:var(--ivory);cursor:zoom-in}
.ed-track img{width:300px;aspect-ratio:2/3;object-fit:cover;object-position:center top;transition:transform 1s}
.ed-track a:hover img{transform:scale(1.04)}
@keyframes edscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ed-track{animation:none}.ed-carousel{overflow-x:auto}}
@media(max-width:760px){
  .ed-track{gap:14px;animation-duration:32s}
  .ed-track a,.ed-track img{width:230px}
}

/* mobile header: keep right-side icons clear of the centred logo */
@media(max-width:760px){
  .bar{padding:14px 4%}
  .brand img{height:60px}
  .actions{gap:16px}
}
@media(max-width:480px){
  .brand img{height:52px}
  .actions{gap:13px}
  .actions .ic,.actions .ic svg{width:20px;height:20px}
}

/* about — extra prose blocks */
.about-prose{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1100px;margin:0 auto}
.about-prose .ap-block h2{font-size:1.35rem;margin:12px 0 12px;letter-spacing:.04em}
.about-prose .ap-block p{font-family:var(--serif);font-size:1.08rem;color:#56503f}
@media(max-width:1080px){.about-prose{grid-template-columns:1fr;gap:34px;max-width:680px}}



/* === slider items: collection tiles + product cards in ed-track === */
.ed-track .tile{flex:0 0 auto;width:360px;height:470px;background:var(--ivory)}
.ed-track .tile img{width:100%;height:100%;aspect-ratio:auto;object-fit:cover;object-position:top center}
.ed-track .card{flex:0 0 auto;width:300px;background:#fff}
.ed-track .card .ph img{width:100%;height:100%;aspect-ratio:1/1}
.ed-track a.tile,.ed-track a.card{cursor:pointer}
.ed-tiles{animation-duration:40s}
.ed-cards{animation-duration:60s}
@media(max-width:760px){
  .ed-track .tile{width:260px;height:360px}
  .ed-track .card{width:220px}
}

/* === custom: step cards (styled like the appointment/whatsapp blocks) === */
.c-block .stepn{display:block;font-family:var(--serif);font-style:italic;font-weight:400;font-size:2.4rem;color:var(--gold-deep);line-height:1;margin-bottom:6px}

/* === offset frame: keep within page padding on small screens === */
@media(max-width:760px){
  .about-grid .img:after{top:10px;left:10px;right:-8px;bottom:-8px}
}


/* ================= footer — warm ivory ================= */
footer{background:#f7f1e6;color:#6b6253;margin-top:0}
footer .topline{height:1px;background:rgba(168,134,47,.45);margin-bottom:0}
footer .wrap{padding-top:0}
footer h4{color:var(--gold-deep)}
footer a{color:#5a5345}
footer a:hover{color:var(--gold-deep)}
footer .git svg,footer .socials svg{color:var(--gold-deep)}
footer .socials a{border:1px solid rgba(168,134,47,.5);color:var(--gold-deep)}
footer .socials a:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
footer .ig-handle{color:var(--gold-deep)}
footer .base{border-top:1px solid rgba(26,23,18,.12);color:#7a7163}
footer .base a{color:var(--gold-deep)}

/* newsletter band — on ivory */
footer .news{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;border:1px solid rgba(168,134,47,.4);padding:34px 40px;margin:54px 0 52px}
footer .news h4{margin-bottom:6px}
footer .news p{font-family:var(--serif);color:#6b6253;font-size:1.05rem}
footer .news form{display:flex;gap:12px}
footer .news input{flex:1;background:#fffdf9;border:1px solid rgba(168,134,47,.45);padding:13px 16px;color:var(--ink);font-family:var(--sans);font-size:.95rem;outline:none}
footer .news input::placeholder{color:#9a917f}
footer .news input:focus{border-color:var(--gold)}
footer .news .nl-thanks{font-family:var(--serif);color:var(--gold-deep);font-size:1.1rem;font-style:italic}
@media(max-width:1080px){footer .news{grid-template-columns:1fr;gap:20px}}
@media(max-width:760px){footer .news form{flex-direction:column}}

/* footer: keep all four columns in ONE row (Info · Policies · Get In Touch · Socials) */
footer .cols{grid-template-columns:1.1fr 1fr 1.6fr .8fr;gap:32px}
@media(max-width:1080px){footer .cols{grid-template-columns:1.1fr 1fr 1.6fr .8fr;gap:24px}}
@media(max-width:700px){footer .cols{grid-template-columns:1fr 1fr;text-align:left}}
@media(max-width:440px){footer .cols{grid-template-columns:1fr;text-align:center}}

/* footer columns — final: 4 across on desktop/tablet, 2 on phone, 1 on tiny */
footer .cols{grid-template-columns:1.1fr 1fr 1.6fr .8fr;gap:32px;text-align:left}
@media(max-width:760px){footer .cols{grid-template-columns:1fr 1fr;gap:24px;text-align:left}footer .socials{justify-content:flex-start}}
@media(max-width:440px){footer .cols{grid-template-columns:1fr;text-align:center}footer .socials{justify-content:center}}

/* custom/about image — a clean gold frame that borders the image */
.about-grid .img:after{display:none!important}
.about-grid .img{border:1px solid var(--gold-soft);padding:14px;background:#fff}
.about-grid .img img{position:static;z-index:auto;height:520px}
@media(max-width:760px){.about-grid .img{padding:10px}.about-grid .img img{height:360px}}

/* step cards: small caps label above the heading */
.c-block .stepn{display:block;font-family:var(--sans);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:6px}

/* frame stuck directly to the image (no gap) */
.about-grid .img{padding:0;border:1px solid var(--gold-soft);background:none}
.about-grid .img img{height:560px}
@media(max-width:760px){.about-grid .img{padding:0}.about-grid .img img{height:380px}}

/* custom — horizontal step timeline */
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;max-width:1000px;margin:0 auto}
.timeline .tl-step{position:relative;text-align:center;padding-top:74px}
.timeline .tl-step:before{content:"";position:absolute;top:27px;left:-50%;width:100%;height:1px;background:rgba(168,134,47,.45)}
.timeline .tl-step:first-child:before{display:none}
.timeline .tl-node{position:absolute;top:0;left:50%;transform:translateX(-50%);width:54px;height:54px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-deep);background:var(--paper);z-index:1}
.timeline .tl-step h3{font-size:1.18rem;letter-spacing:.06em;margin-bottom:8px}
.timeline .tl-step p{font-family:var(--serif);color:var(--muted);font-size:1.02rem}
@media(max-width:760px){
  .timeline{grid-template-columns:1fr;gap:0;max-width:440px}
  .timeline .tl-step{text-align:left;padding:0 0 38px 74px;min-height:74px}
  .timeline .tl-node{left:0;transform:none}
  .timeline .tl-step:before{display:block;top:54px;left:27px;width:1px;height:100%}
  .timeline .tl-step:first-child:before{display:block}
  .timeline .tl-step:last-child:before{display:none}
}

/* ===== bulletproof: content always visible even if JavaScript fails ===== */
.rv{opacity:1 !important;transform:none !important}
/* fallback nav (only visible if JS fails to build the real header) */
.nojs-nav{display:flex;gap:18px;flex-wrap:wrap;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.nojs-nav a{color:var(--ink)}
.nojs-nav a:hover{color:var(--gold-deep)}

/* === FIX: keep the menu button & icons tappable above the centered logo (mobile) === */
.bar .burger, .bar .actions{position:relative; z-index:5}
.bar .brand{z-index:1}
.bar .burger{padding:8px; margin:-8px; width:38px; height:32px; box-sizing:content-box}
.bar .burger span{height:2px}
@media(max-width:760px){
  .brand img{height:56px}
}
