/* ============================================================
   AL BAHAR · UNSEEN TOUCH
   albahar.css — single shared stylesheet for the storefront
   Loaded once via includes/head.php on every page.
   Brand green #005A30 is taken from the official logo.
   ============================================================ */

:root{
  --brand:#005A30; --brand-mid:#0A4D2C; --brand-deep:#013D21;
  --brand-night:#002616; --brand-ink:#001A0E;
  --gold:#D4AF37; --gold-light:#E8D49A; --gold-pale:#F1E6C4;
  --gold-deep:#A6802B; --gold-antique:#8A6A1F;
  --ivory:#FDFBF7; --cream:#F4EEE1; --ink:#1B1712;
  --gold-foil:linear-gradient(135deg,#8A6A1F 0%,#D4AF37 20%,#F1E6C4 38%,#D4AF37 55%,#A6802B 72%,#E8D49A 88%,#C9A233 100%);
}

html{scroll-behavior:smooth;}
body{background:var(--ivory);color:var(--ink);font-family:'Jost',system-ui,sans-serif;-webkit-font-smoothing:antialiased;}
::selection{background:var(--brand);color:var(--gold-pale);}

::-webkit-scrollbar{width:10px;}
::-webkit-scrollbar-track{background:var(--cream);}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold),var(--gold-deep));}

/* Letter-spacing helpers */
.tracked{letter-spacing:.42em;}
.tracked-sm{letter-spacing:.28em;}
.tracked-xs{letter-spacing:.18em;}

/* Gold foil text + rules */
.foil-text{background:var(--gold-foil);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;}
.foil-rule{height:1px;background:var(--gold-foil);}
.hairline{background:linear-gradient(90deg,transparent,var(--gold) 18%,var(--gold) 82%,transparent);}

/* Gold-foil bordered button with shimmer sweep */
.btn-foil{position:relative;overflow:hidden;border:1px solid var(--gold);transition:.55s cubic-bezier(.19,1,.22,1);cursor:pointer;}
.btn-foil::before{content:"";position:absolute;inset:0;background:var(--gold-foil);opacity:0;transition:opacity .5s ease;z-index:0;}
.btn-foil::after{content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);transition:left .7s ease;z-index:1;}
.btn-foil>span{position:relative;z-index:2;transition:color .4s ease;}
.btn-foil:hover{box-shadow:0 14px 40px -16px rgba(212,175,55,.65);}
.btn-foil:hover::before{opacity:1;}
.btn-foil:hover::after{left:140%;}
.btn-foil.on-light:hover>span,.btn-foil.on-dark:hover>span{color:var(--brand-deep);}

/* Animated nav underline */
.nav-link{position:relative;}
.nav-link::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold);transition:width .45s cubic-bezier(.19,1,.22,1);}
.nav-link:hover::after{width:100%;}

/* Product / category cards */
.lux-card{position:relative;transition:transform .6s cubic-bezier(.19,1,.22,1),box-shadow .6s ease;}
.lux-card .frame{position:absolute;inset:10px;border:1px solid rgba(212,175,55,0);transition:inset .55s ease,border-color .55s ease;pointer-events:none;z-index:3;}
.lux-card:hover{transform:translateY(-10px);box-shadow:0 40px 70px -40px rgba(1,61,33,.55);}
.lux-card:hover .frame{inset:14px;border-color:rgba(212,175,55,.85);}
.lux-card:hover .card-img{transform:scale(1.06);}
.card-img{transition:transform 1.1s cubic-bezier(.19,1,.22,1);}
.card-cta{opacity:0;transform:translateY(8px);transition:.5s ease;}
.lux-card:hover .card-cta{opacity:1;transform:translateY(0);}

/* Jali / lattice + paper textures */
.jali{background-image:repeating-linear-gradient(45deg,rgba(212,175,55,.10) 0 1px,transparent 1px 22px),repeating-linear-gradient(-45deg,rgba(212,175,55,.10) 0 1px,transparent 1px 22px);}
.jali-dark{background-image:repeating-linear-gradient(45deg,rgba(212,175,55,.16) 0 1px,transparent 1px 26px),repeating-linear-gradient(-45deg,rgba(212,175,55,.16) 0 1px,transparent 1px 26px);}
.paper{background-image:radial-gradient(rgba(0,0,0,.018) 1px,transparent 1px);background-size:4px 4px;}

/* Hero split hover weighting */
.split{transition:flex .9s cubic-bezier(.19,1,.22,1);}
@media(min-width:1024px){
  .hero-row:hover .split{flex:.85;}
  .hero-row .split:hover{flex:1.55;}
}
.split .veil{transition:opacity .8s ease;}
.split:hover .veil{opacity:.30;}
.split:hover .hero-fig{transform:translateY(-6px) scale(1.02);}
.hero-fig{transition:transform 1s cubic-bezier(.19,1,.22,1);}

/* Marquee */
.marquee{display:flex;width:max-content;animation:slide 34s linear infinite;}
@keyframes slide{to{transform:translateX(-50%);}}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1.1s cubic-bezier(.19,1,.22,1),transform 1.1s cubic-bezier(.19,1,.22,1);}
.reveal.show{opacity:1;transform:none;}

/* Staggered hero load */
@keyframes rise{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:none;}}
.rise{opacity:0;animation:rise 1.2s cubic-bezier(.19,1,.22,1) forwards;}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.foil-anim{animation:shimmer 6s linear infinite;}

/* Sticky nav scrolled state */
/* ===== NAV ===== transparent over dark hero, solid when scrolled / interior pages */
.navbar{background:transparent;}
.navtext{color:var(--ivory);}
.navlogo{color:var(--ivory);}
.navmark{stroke:var(--ivory);fill:var(--ivory);}
#nav.nav-scrolled .navbar{background:rgba(253,251,247,.98);backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(212,175,55,.4),0 18px 44px -38px rgba(1,61,33,.5);}
#nav.nav-scrolled .navtext{color:var(--brand-deep);}
#nav.nav-scrolled .navlogo{color:var(--brand-deep);}
#nav.nav-scrolled .navmark{stroke:var(--brand-deep);fill:var(--brand-deep);}
#nav.nav-scrolled .navtext.text-gold,#nav.nav-scrolled .nav-link.text-gold{color:var(--gold-deep);}
/* readability guard: when transparent over hero, add a soft top scrim so text never goes blind */
#nav:not(.nav-scrolled)::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,26,14,.45),transparent);pointer-events:none;}

/* announcement marquee — continuous on mobile + desktop */
.marquee-track{animation:marquee 32s linear infinite;will-change:transform;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(max-width:640px){.marquee-track{animation-duration:22s;}}

/* mobile drawer */
#mobile-drawer.open{transform:translateX(0);}
#drawer-overlay.open{opacity:1;pointer-events:auto;}
body.no-scroll{overflow:hidden;}

/* ============================================================
   PRODUCT PAGE (PDP) + COLLECTION components — shared
   ============================================================ */
.pdp-thumb{border-color:rgba(27,23,18,.12);transition:.3s;}
.pdp-thumb.active{border-color:var(--gold);}
.pdp-thumb img{transition:.4s;}
.pdp-thumb:hover img{opacity:.85;}

.pdp-swatch{width:34px;height:34px;border-radius:50%;padding:3px;border:1px solid rgba(27,23,18,.18);transition:.25s;cursor:pointer;}
.pdp-swatch span{display:block;width:100%;height:100%;border-radius:50%;}
.pdp-swatch.active{border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,175,55,.22);}

.pdp-size{min-width:52px;padding:10px 14px;border:1px solid rgba(27,23,18,.2);font-family:'Jost',sans-serif;font-size:12px;letter-spacing:.06em;color:var(--ink);background:#fff;transition:.25s;cursor:pointer;}
.pdp-size:hover{border-color:var(--gold);}
.pdp-size.active{background:var(--brand-deep);color:var(--gold-light);border-color:var(--brand-deep);}

details summary{list-style:none;}
details summary::-webkit-details-marker{display:none;}

/* Collection toolbar */
.coll-pill{padding:8px 16px;border:1px solid rgba(27,23,18,.18);font-size:11px;letter-spacing:.1em;font-family:'Jost',sans-serif;color:var(--ink);transition:.25s;cursor:pointer;white-space:nowrap;}
.coll-pill:hover,.coll-pill.active{background:var(--brand-deep);color:var(--gold-light);border-color:var(--brand-deep);}

/* Responsive offset to clear the fixed header (announce 30/34 + navbar 56/70/78) */
.page-top{padding-top:calc(56px + 30px);}
@media(min-width:640px){.page-top{padding-top:calc(70px + 34px);}}
@media(min-width:1024px){.page-top{padding-top:calc(78px + 34px);}}
.page-top-lg{padding-top:calc(56px + 30px + 16px);}
@media(min-width:640px){.page-top-lg{padding-top:calc(70px + 34px + 26px);}}
@media(min-width:1024px){.page-top-lg{padding-top:calc(78px + 34px + 38px);}}

/* ===== PREMIUM IMAGE HANDLING (stop heads/products getting cropped) =====
   Product imagery is portrait fashion — crop only from the BOTTOM, never the top,
   so faces & necklines stay intact. Taller ratio for a luxury editorial feel. */
.fashion-img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.lux-card .ratio{position:relative;width:100%;aspect-ratio:3/4;overflow:hidden;background:var(--cream);}
@media(min-width:1024px){.lux-card .ratio{aspect-ratio:4/5;}}
/* perfume / object imagery sits contained on a soft ground */
.object-img{width:100%;height:100%;object-fit:contain;padding:6%;background:#fff;}

/* ============================================================
   PREMIUM SIGNATURE ELEMENTS (restored + mobile-tuned)
   ============================================================ */
/* Gold ornamental divider (centered diamond between two rules) */
.ornament{display:flex;align-items:center;justify-content:center;gap:14px;}
.ornament::before,.ornament::after{content:"";height:1px;width:54px;background:linear-gradient(90deg,transparent,var(--gold));}
.ornament::after{background:linear-gradient(90deg,var(--gold),transparent);}
.ornament span{width:7px;height:7px;background:var(--gold);transform:rotate(45deg);}
.ornament.sm::before,.ornament.sm::after{width:34px;}

/* Mughal cusped arch (Mehraab) frame for imagery */
.mehraab{border-top-left-radius:50% 22%;border-top-right-radius:50% 22%;overflow:hidden;position:relative;}
.mehraab::after{content:"";position:absolute;inset:0;border:1px solid rgba(212,175,55,.5);border-top-left-radius:50% 22%;border-top-right-radius:50% 22%;pointer-events:none;}
.mehraab-frame{position:relative;padding:10px;}
.mehraab-frame::before{content:"";position:absolute;inset:0;border:1px solid rgba(212,175,55,.35);border-top-left-radius:50% 22%;border-top-right-radius:50% 22%;}

/* Eyebrow label with flanking rules */
.eyebrow-c{display:inline-flex;align-items:center;gap:12px;}
.eyebrow-c::before,.eyebrow-c::after{content:"";height:1px;width:30px;background:var(--gold);opacity:.7;}

/* Section number tag */
.sec-no{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold-deep);opacity:.8;}

/* Subtle gold top-hairline on dark sections */
.goldline-top{position:relative;}
.goldline-top::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:2px;background:var(--gold-foil);}

/* Mobile-friendly hero scale */
@media(max-width:640px){
  .hero-title{font-size:clamp(3rem,16vw,4.5rem)!important;line-height:.92!important;}
}

/* hide scrollbar on horizontal rails */
.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none;}
.no-scrollbar::-webkit-scrollbar{display:none;}

/* ============================================================
   CINEMATIC HERO (premium)
   ============================================================ */
.hero-bg{position:absolute;inset:0;overflow:hidden;}
.hero-bg::before{content:"";position:absolute;inset:-20%;background:
  radial-gradient(ellipse at 20% 30%, rgba(10,77,44,.55), transparent 55%),
  radial-gradient(ellipse at 85% 70%, rgba(1,26,14,.85), transparent 60%),
  linear-gradient(135deg,#001A0E,#013D21 55%,#002616);}
.hero-grain{position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");}

/* floating gold orbs */
.orb{position:absolute;border-radius:50%;filter:blur(2px);background:radial-gradient(circle at 30% 30%,var(--gold-light),var(--gold-deep));opacity:.0;animation:orbIn 1.6s ease forwards;}
@keyframes orbIn{to{opacity:.55;}}
.orb-float{animation:orbFloat 9s ease-in-out infinite;}
@keyframes orbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-22px)}}

/* kinetic hero words */
.kin{display:block;overflow:hidden;}
.kin > span{display:inline-block;transform:translateY(108%);animation:kinUp 1.05s cubic-bezier(.19,1,.22,1) forwards;}
@keyframes kinUp{to{transform:translateY(0);}}

/* arched hero image frames */
.arch-img{position:relative;border-radius:50% 50% 6px 6px / 28% 28% 6px 6px;overflow:hidden;box-shadow:0 50px 90px -40px rgba(0,0,0,.7);}
.arch-img::after{content:"";position:absolute;inset:0;border:1px solid rgba(212,175,55,.55);border-radius:inherit;pointer-events:none;}
.arch-img img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.hero-img-a{animation:floatA 11s ease-in-out infinite;}
.hero-img-b{animation:floatB 13s ease-in-out infinite;}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(14px)}}

/* thin gold ring accent */
.gold-ring{position:absolute;border:1px solid rgba(212,175,55,.45);border-radius:50%;animation:spin 40s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* shimmering rule under eyebrow */
.shimmer-rule{height:1px;width:64px;background:linear-gradient(90deg,transparent,var(--gold),transparent);background-size:200% 100%;animation:shim 3s linear infinite;}
@keyframes shim{to{background-position:200% 0;}}

@media(max-width:1023px){
  .arch-img{border-radius:50% 50% 6px 6px / 22% 22% 6px 6px;}
}

/* ===== HERO SLIDESHOW ===== */
.hero-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .9s ease;pointer-events:none;}
.hero-slide.is-active{opacity:1;visibility:visible;pointer-events:auto;}
/* replay entrance animations each time a slide becomes active */
.hero-slide .kin > span{animation:none;transform:translateY(108%);}
.hero-slide .hs-rise{opacity:0;transform:translateY(18px);}
.hero-slide.is-active .kin > span{animation:kinUp 1.05s cubic-bezier(.19,1,.22,1) forwards;}
.hero-slide.is-active .hs-rise{animation:hsRise .9s cubic-bezier(.19,1,.22,1) forwards;}
@keyframes hsRise{to{opacity:1;transform:translateY(0);}}
.hero-dot{width:30px;height:3px;background:rgba(241,230,196,.3);border:none;cursor:pointer;transition:background .4s;padding:0;}
.hero-dot.is-active{background:var(--gold);}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:30;width:46px;height:46px;place-items:center;border:1px solid rgba(212,175,55,.4);background:rgba(0,26,14,.5);backdrop-filter:blur(6px);color:var(--gold-light);font-size:26px;line-height:1;cursor:pointer;transition:background .3s,border-color .3s;}
.hero-arrow:hover{background:rgba(0,26,14,.85);border-color:var(--gold);}
.hero-prev{left:18px;} .hero-next{right:18px;}

/* ===== PDP no-crop image stage (shows the FULL garment) ===== */
.pdp-stage{position:relative;width:100%;background:linear-gradient(160deg,#F4EEE1,#FDFBF7);border:1px solid rgba(212,175,55,.16);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:420px;}
@media(min-width:1024px){.pdp-stage{min-height:560px;}}
.pdp-img{width:100%;height:auto;max-height:78vh;object-fit:contain;display:block;}

/* ============================================================
   SOFT PREMIUM MOTION  — "Analog Meditation"
   Quiet, slow, breathing. Nothing snaps; everything eases.
   ============================================================ */
/* slow Ken-Burns drift on hero imagery (only the active slide) */
.hero-slide .arch-img img{transform:scale(1.04);transition:transform 8s ease-out;}
.hero-slide.is-active .arch-img img{transform:scale(1.12);}
/* gentler, longer fade between slides */
.hero-slide{transition:opacity 1.15s cubic-bezier(.4,0,.2,1);}

/* softer reveal-on-scroll delays (base .reveal/.show defined above) */
.reveal-d1{transition-delay:.08s;} .reveal-d2{transition-delay:.16s;} .reveal-d3{transition-delay:.24s;}

/* softer, slower card lift */
.lux-card{transition:transform .75s cubic-bezier(.19,1,.22,1),box-shadow .75s ease;}
.lux-card:hover{transform:translateY(-8px);}
.lux-card:hover .card-img{transform:scale(1.05);}
.card-img{transition:transform 1.4s cubic-bezier(.19,1,.22,1);}

/* image inside cards fades in softly once loaded */
.fashion-img,.object-img{animation:imgIn 1.2s ease both;}
@keyframes imgIn{from{opacity:0;filter:blur(6px);}to{opacity:1;filter:blur(0);}}

/* gentle floating for the arched hero frames (slower than before) */
.hero-img-a{animation:floatA 14s ease-in-out infinite;}
.hero-img-b{animation:floatB 16s ease-in-out infinite;}

/* respect reduced-motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important;}
}
