/* ═══════════════════════════════════════════════════════
   MAHFEL · style.css  —  Mobile-First
   ═══════════════════════════════════════════════════════ */

/* ── 0. TOKENS ── */
:root {
  --ink-900:#060403; --ink-850:#0B0705; --ink-800:#110A06;
  --ink-700:#1A0F09; --ink-600:#25160C;
  --gold-100:#F6E7C1; --gold-300:#D9A93C; --gold-400:#E9C879;
  --gold-500:#BF8108; --gold-600:#94610A;
  --pom-600:#6E1A0C; --pom-500:#8C2410;
  --parch:#EBD9B4; --parch-dim:#B79E73; --muted:#8A734F; --muted-2:#5E4D34;
  --ff-body:'Vazirmatn',system-ui,sans-serif;
  --ff-disp:'Lalezar','Vazirmatn',cursive;
  --ff-lat:'Cormorant Garamond',Georgia,serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-io:cubic-bezier(.65,.05,.36,1);
  /* native-app spring easings */
  --spring:cubic-bezier(.34,1.56,.64,1);
  --spring-soft:cubic-bezier(.16,1,.3,1);
  --maxw:1240px;
  --bnav-h:64px;
  /* gold-foil gradient surfaces (depth, not flat) */
  --foil:linear-gradient(135deg,#F6E7C1 0%,#D9A93C 26%,#94610A 50%,#E9C879 74%,#BF8108 100%);
  --foil-soft:linear-gradient(140deg,rgba(246,231,193,.16),rgba(191,129,8,.04) 45%,rgba(110,26,12,.10));
  --glass:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.012) 40%,transparent);
  --sheen:linear-gradient(105deg,transparent 30%,rgba(246,231,193,.22) 48%,transparent 62%);
  /* shadow ladder for real depth */
  --sh-1:0 2px 8px rgba(0,0,0,.3);
  --sh-2:0 10px 30px rgba(0,0,0,.45);
  --sh-3:0 26px 60px rgba(0,0,0,.55);
  --glow-gold:0 0 40px rgba(191,129,8,.35);
  /* vertical rhythm */
  --sp-sec:94px;
}

/* ── 1. RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{
  scroll-behavior:smooth;-webkit-text-size-adjust:100%;
  /* keep anchored scrolling clear of the fixed top nav */
  scroll-padding-top:84px;
}
body{
  font-family:var(--ff-body);
  background:var(--ink-900);
  color:var(--parch);
  line-height:1.85;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","kern";
  /* native feel: no rubber-band bleed between scroll containers */
  overscroll-behavior-y:none;
  /* room for bottom nav on mobile */
  padding-bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px));
}
html.cur,html.cur body,html.cur a,html.cur button{cursor:none}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;border:none;background:none;cursor:pointer}
::selection{background:var(--gold-500);color:var(--ink-900)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ── 2. FILM GRAIN ── */
.grain{
  position:fixed;inset:0;z-index:9990;pointer-events:none;
  opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain-shift 1.2s steps(3) infinite;
}
@keyframes grain-shift{
  0%{transform:translate(0,0)} 33%{transform:translate(-4%,2%)}
  66%{transform:translate(3%,-3%)} 100%{transform:translate(0,0)}
}

/* ── 3. SCROLL PROGRESS ── */
.scroll-prog{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:10001;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-400));
  transform:scaleX(0);transform-origin:left;pointer-events:none;
}

/* ── 4. CUSTOM CURSOR (pointer device only) ── */
.cursor-dot,.cursor-ring{
  position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  border-radius:50%;transform:translate(-50%,-50%);
  mix-blend-mode:difference;display:none;
}
@media(hover:hover){
  .cursor-dot{display:block;width:6px;height:6px;background:var(--gold-100)}
  .cursor-ring{
    display:block;width:38px;height:38px;
    border:1px solid rgba(233,200,121,.6);
    transition:width .25s var(--ease),height .25s var(--ease),border-color .25s,background .25s;
  }
  .cursor-ring.hover{width:64px;height:64px;border-color:var(--gold-400);background:rgba(233,200,121,.08)}
  .cursor-ring.down{width:30px;height:30px}
}

/* ── 5. PRELOADER ── */
.preloader{
  position:fixed;inset:0;z-index:10000;background:var(--ink-900);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  transition:opacity .8s var(--ease),visibility .8s;
}
.preloader.done{opacity:0;visibility:hidden}
.pre-logo{
  width:min(78vw,400px);height:auto;opacity:0;
  filter:drop-shadow(0 0 50px rgba(191,129,8,.4));
  animation:pre-logo-in 1.2s var(--ease) .2s forwards;
}
@keyframes pre-logo-in{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.pre-ring{width:50px;height:50px}
.pre-ring circle{
  fill:none;stroke:var(--gold-500);stroke-width:1.5;stroke-linecap:round;
  stroke-dasharray:40 120;transform-origin:center;animation:pre-spin 1s linear infinite;
}
@keyframes pre-spin{to{transform:rotate(360deg)}}
.pre-sub{font-size:.64rem;letter-spacing:.5em;color:var(--muted);opacity:0;animation:fade-in .9s ease 1s forwards}
@keyframes fade-in{to{opacity:1}}

/* ── 6. SHARED HEADINGS ── */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.68rem;letter-spacing:.4em;color:var(--gold-300);
  text-transform:uppercase;margin-bottom:1.3rem;font-weight:500;
}
.eyebrow::before,.eyebrow.center::after{
  content:'';width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-500));
}
.eyebrow.center::before{background:linear-gradient(90deg,var(--gold-500),transparent)}
.h-title{
  font-family:var(--ff-disp);
  font-size:clamp(2.35rem,8.4vw,4.6rem);
  font-weight:400;line-height:1.12;color:var(--gold-100);letter-spacing:.005em;
  text-shadow:0 1px 0 rgba(0,0,0,.4),0 0 34px rgba(191,129,8,.12);
}
.h-title .accent{
  position:relative;
  background:var(--foil);background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 2px 10px rgba(191,129,8,.28));
  animation:foil-shift 7s ease-in-out infinite;
}
@keyframes foil-shift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.divider{display:flex;align-items:center;gap:.6rem;margin:1.3rem 0 1.7rem}
.divider.center{justify-content:center}
.divider .d-line{width:44px;height:1px;background:linear-gradient(90deg,var(--gold-500),transparent)}
.divider.center .d-line:last-child{background:linear-gradient(90deg,transparent,var(--gold-500))}
.divider .d-rhombus{width:7px;height:7px;background:var(--gold-400);transform:rotate(45deg);box-shadow:0 0 12px rgba(217,169,60,.6)}
.lede{font-size:.97rem;color:var(--parch-dim);max-width:560px}
.section-head.center{text-align:center}
.section-head.center .lede{margin-inline:auto}

/* ── 7. REVEAL ── */
.rv{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.l{transform:translateX(-40px)}
.rv.r{transform:translateX(40px)}
.rv.s{transform:scale(.92)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.4s}

/* ── 7b. NATIVE PAGE TRANSITION ── */
.page-fade{
  position:fixed;inset:0;z-index:10002;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%,var(--ink-700),var(--ink-900) 75%);
  opacity:0;transform:translateZ(0);
  transition:opacity .42s var(--spring-soft);
}
.page-fade.show{opacity:1;pointer-events:auto}
.page-fade .pf-mark{
  position:absolute;top:50%;left:50%;width:46px;height:46px;
  transform:translate(-50%,-50%) scale(.6);opacity:0;color:var(--gold-400);
  transition:opacity .42s var(--spring-soft) .05s,transform .5s var(--spring) .05s;
}
.page-fade.show .pf-mark{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(120deg)}
/* fresh page entrance */
@keyframes page-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.page-enter{animation:page-in .6s var(--spring-soft) both}

/* ── 7c. TAP RIPPLE ── */
.rippling{position:relative;overflow:hidden}
.ripple{
  position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(246,231,193,.5),rgba(246,231,193,0) 70%);
  transform:translate(-50%,-50%) scale(0);opacity:.8;
  animation:ripple-out .6s var(--ease) forwards;
}
@keyframes ripple-out{to{transform:translate(-50%,-50%) scale(1);opacity:0}}

/* ── 7d. PREMIUM ARTWORK SYSTEM ──
   gradient-filled SVG emblems w/ depth, replacing thin sketch strokes */
.art-foil{stroke:url(#goldFoil)!important}
.art-fill{fill:url(#goldFoilV)!important}
.glow-soft{filter:drop-shadow(0 6px 18px rgba(191,129,8,.35))}
.glow-warm{filter:drop-shadow(0 0 26px rgba(191,129,8,.45)) drop-shadow(0 2px 6px rgba(140,36,16,.4))}
/* the hidden SVG holding shared gradient/filter defs */
.svg-defs{position:absolute;width:0;height:0;overflow:hidden;pointer-events:none}

/* ═══════════════════════════
   NAVBAR
═══════════════════════════ */
.nav{
  position:fixed;inset:0 0 auto;z-index:900;
  padding:14px 0;
  transition:padding .4s var(--ease),background .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.shrink{
  padding:10px 0;background:rgba(6,4,3,.9);
  backdrop-filter:blur(24px) saturate(150%);
  border-bottom:1px solid rgba(191,129,8,.18);
}
.nav-in{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:0 20px;
}
.brand{display:flex;align-items:center}
.brand-logo{height:36px;width:auto;transition:height .4s var(--ease)}
.nav.shrink .brand-logo{height:28px}

/* nav links — hidden on mobile, shown on desktop */
.nav-menu{display:none}
/* burger — hidden on small mobile (bottom nav used), shown on tablet */
.burger{display:none;width:28px;height:18px;position:relative;z-index:950}
.burger span{position:absolute;right:0;width:100%;height:1.5px;background:var(--gold-300);transition:.35s var(--ease)}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:8px;width:70%}
.burger span:nth-child(3){top:16px}
.burger.x span:nth-child(1){top:8px;transform:rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){top:8px;transform:rotate(-45deg)}

.m-nav{
  position:fixed;inset:0;z-index:920;background:rgba(6,4,3,.97);
  backdrop-filter:blur(20px);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2.2rem;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;
}
.m-nav.open{opacity:1;visibility:visible}
.m-nav a{font-family:var(--ff-disp);font-size:2.2rem;color:var(--parch);transition:color .3s,transform .3s}
.m-nav a:hover,.m-nav a:active{color:var(--gold-400);transform:scale(1.05)}

.nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;padding:9px 20px;
  border-radius:2px;font-size:.84rem;font-weight:500;color:var(--gold-100);
  border:1px solid rgba(217,169,60,.4);position:relative;overflow:hidden;transition:color .4s;
}
.nav-cta::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,var(--gold-500),var(--pom-600));
  transform:translateY(101%);transition:transform .4s var(--ease);z-index:-1;
}
.nav-cta:hover,.nav-cta:active{color:#fff;border-color:transparent}
.nav-cta:hover::after,.nav-cta:active::after{transform:translateY(0)}
.nav-cta svg{width:14px;height:14px}

/* ═══════════════════════════
   BOTTOM NAV (mobile only)
═══════════════════════════ */
.b-nav{
  display:flex;
  position:fixed;bottom:0;left:0;right:0;z-index:1000;
  background:rgba(6,4,3,.94);
  backdrop-filter:blur(32px) saturate(180%);
  -webkit-backdrop-filter:blur(32px) saturate(180%);
  border-top:1px solid rgba(191,129,8,.2);
  padding-top:8px;
  padding-bottom:max(10px,env(safe-area-inset-bottom));
}
.bn{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:6px 0 2px;font-size:.58rem;letter-spacing:.04em;
  color:var(--muted);transition:color .3s;
  position:relative;touch-action:manipulation;-webkit-user-select:none;user-select:none;
}
/* glowing pill that springs in behind the icon */
.bn svg{position:relative;z-index:1;width:23px;height:23px;transition:transform .45s var(--spring)}
.bn span{position:relative;z-index:1;transition:opacity .3s,transform .3s var(--spring)}
.bn::before{
  content:'';position:absolute;top:2px;left:50%;width:46px;height:30px;
  transform:translateX(-50%) scale(.5);opacity:0;border-radius:16px;z-index:0;
  background:radial-gradient(circle,rgba(233,200,121,.2),rgba(233,200,121,.04) 70%);
  transition:opacity .35s,transform .45s var(--spring);
}
.bn::after{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%) scaleX(0);
  width:26px;height:2px;background:var(--gold-400);
  border-radius:0 0 3px 3px;box-shadow:0 0 10px rgba(233,200,121,.6);
  transition:transform .4s var(--spring);
}
.bn.active{color:var(--gold-400)}
.bn.active svg{transform:translateY(-4px) scale(1.05)}
.bn.active::before{opacity:1;transform:translateX(-50%) scale(1)}
.bn.active::after{transform:translateX(-50%) scaleX(1)}
.bn:active svg{transform:translateY(-3px) scale(.86)}

/* ═══════════════════════════
   HERO
═══════════════════════════ */
.hero{
  position:relative;min-height:100svh;display:grid;place-items:center;
  overflow:hidden;isolation:isolate;
}
.hero-bg{
  position:absolute;inset:0;z-index:-3;
  background:radial-gradient(ellipse 90% 90% at 50% 30%,var(--ink-700),var(--ink-900) 70%);
}
.hero-girih{
  position:absolute;inset:-10%;z-index:-2;opacity:.5;will-change:transform;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cg fill='none' stroke='rgba(191,129,8,0.10)' stroke-width='.8'%3E%3Cpolygon points='70,8 84,42 120,42 91,64 102,98 70,78 38,98 49,64 20,42 56,42'/%3E%3Ccircle cx='70' cy='70' r='46'/%3E%3Cpolygon points='70,30 79,52 103,52 84,66 91,90 70,76 49,90 56,66 37,52 61,52'/%3E%3Cpath d='M70,0V140M0,70H140'/%3E%3C/g%3E%3C/svg%3E");
  background-size:140px 140px;
}
.hero-rosette{
  position:absolute;top:50%;left:50%;
  width:min(110vw,720px);aspect-ratio:1;z-index:-2;
  transform:translate(-50%,-50%);opacity:.22;color:var(--gold-500);
  animation:spin 70s linear infinite;
}
.hero-rosette.slow{animation-duration:110s;animation-direction:reverse;opacity:.12;width:min(140vw,920px)}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.hero-glow{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 55% 45% at 50% 42%,rgba(140,36,16,.40),transparent 70%),
    radial-gradient(circle at 18% 78%,rgba(191,129,8,.16),transparent 55%),
    radial-gradient(circle at 82% 22%,rgba(110,26,12,.30),transparent 55%);
}
.hero-vig{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to bottom,rgba(6,4,3,.4) 0%,transparent 22%,transparent 60%,rgba(6,4,3,.85) 92%,var(--ink-900) 100%);
}
.embers{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.ember{
  position:absolute;bottom:-10px;border-radius:50%;
  background:radial-gradient(circle,var(--gold-400),rgba(217,169,60,0) 70%);
  opacity:0;animation:rise var(--du,11s) var(--de,0s) infinite ease-out;
}
@keyframes rise{
  0%{transform:translateY(0) translateX(0) scale(.4);opacity:0}
  12%{opacity:.8} 85%{opacity:.25}
  100%{transform:translateY(-104vh) translateX(var(--dx,40px)) scale(1);opacity:0}
}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 20px;padding-top:70px}
.hero-pre{
  font-size:.7rem;letter-spacing:.5em;color:var(--gold-300);text-transform:uppercase;
  margin-bottom:1.5rem;opacity:0;transform:translateY(18px);
  animation:hero-up .9s var(--ease) .15s forwards;
}
.hero-logo{
  max-height:min(44vw,220px);width:auto;margin:0 auto 1.4rem;
  filter:drop-shadow(0 12px 50px rgba(191,129,8,.3));
  opacity:0;transform:translateY(26px) scale(.97);
  animation:hero-logo-in 1.1s var(--ease) .3s forwards;
}
@keyframes hero-logo-in{to{opacity:1;transform:none}}
.hero-logo-float{animation:hero-logo-in 1.1s var(--ease) .3s forwards,float 6s ease-in-out 1.4s infinite}
@keyframes float{0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)}}
@keyframes hero-up{to{opacity:1;transform:none}}
.hero-sub{
  font-size:clamp(.9rem,3.5vw,1.3rem);font-weight:300;letter-spacing:.18em;
  color:var(--parch);margin-bottom:1.6rem;
  opacity:0;transform:translateY(18px);animation:hero-up .9s var(--ease) .5s forwards;
}
.hero-orn{
  display:flex;align-items:center;justify-content:center;gap:.9rem;
  margin-bottom:1.2rem;color:var(--gold-400);
  opacity:0;animation:hero-up .9s var(--ease) .65s forwards;
}
.hero-orn .o-line{width:56px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-500))}
.hero-orn .o-line:last-child{background:linear-gradient(90deg,var(--gold-500),transparent)}
.hero-orn svg{width:20px;height:20px}
.hero-tag{
  font-size:.94rem;color:var(--parch-dim);margin-bottom:2.2rem;
  max-width:400px;margin-inline:auto;
  opacity:0;animation:hero-up .9s var(--ease) .78s forwards;
}
.hero-actions{
  display:flex;flex-direction:column;gap:.8rem;align-items:stretch;
  opacity:0;animation:hero-up .9s var(--ease) .9s forwards;
}
/* buttons */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:15px 28px;border-radius:4px;font-size:.92rem;font-weight:500;letter-spacing:.03em;
  overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s,color .4s;
  touch-action:manipulation;
}
.btn svg{width:16px;height:16px}
.btn-solid{
  color:var(--ink-900);background:linear-gradient(120deg,var(--gold-400),var(--gold-300));
  box-shadow:0 8px 30px rgba(191,129,8,.35);font-weight:700;
}
.btn-solid::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,var(--gold-100),var(--gold-400));opacity:0;transition:opacity .4s}
.btn-solid:hover,.btn-solid:active{transform:translateY(-2px);box-shadow:0 14px 40px rgba(191,129,8,.5)}
.btn-solid:active{transform:scale(.97)}
.btn-solid:hover::after,.btn-solid:active::after{opacity:1}
.btn-solid span,.btn-solid svg{position:relative;z-index:1}
.btn-line{color:var(--gold-100);border:1px solid rgba(217,169,60,.45)}
.btn-line::after{content:'';position:absolute;inset:0;background:rgba(233,200,121,.1);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.btn-line:hover,.btn-line:active{transform:translateY(-2px);border-color:var(--gold-400)}
.btn-line:active{transform:scale(.97)}
.btn-line:hover::after,.btn-line:active::after{transform:scaleX(1)}
.btn-line span,.btn-line svg{position:relative;z-index:1}

.hero-scroll{
  position:absolute;
  bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 18px);
  left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--muted);font-size:.58rem;letter-spacing:.3em;
}
.hero-scroll .mouse{width:20px;height:32px;border:1px solid rgba(191,129,8,.4);border-radius:10px;position:relative}
.hero-scroll .mouse::before{
  content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%);
  width:3px;height:6px;border-radius:3px;background:var(--gold-400);
  animation:wheel 1.7s ease-in-out infinite;
}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 100%{opacity:0;transform:translate(-50%,10px)}}

/* ═══════════════════════════
   MARQUEE
═══════════════════════════ */
.marquee{
  background:linear-gradient(90deg,var(--ink-700),var(--ink-600) 50%,var(--ink-700));
  border-top:1px solid rgba(191,129,8,.16);border-bottom:1px solid rgba(191,129,8,.16);
  padding:16px 0;overflow:hidden;
}
.marquee-track{display:flex;gap:2.4rem;width:max-content;animation:slide 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.marquee-item{
  display:inline-flex;align-items:center;gap:1.2rem;
  font-family:var(--ff-disp);font-size:1.35rem;color:var(--gold-300);white-space:nowrap;
}
.marquee-item svg{width:15px;height:15px;color:var(--pom-500)}

/* ═══════════════════════════
   ABOUT
═══════════════════════════ */
.about{position:relative;padding:var(--sp-sec) 0}
.about-grid{display:grid;grid-template-columns:1fr;gap:44px;align-items:center}
.about-vis{position:relative}
.plate-frame{
  position:relative;aspect-ratio:4/5;max-height:340px;
  border:1px solid rgba(191,129,8,.3);border-radius:14px;overflow:hidden;
  background:
    radial-gradient(110% 80% at 50% 8%,rgba(140,36,16,.3),transparent 50%),
    radial-gradient(circle at 50% 40%,var(--ink-600),var(--ink-850) 74%);
  box-shadow:var(--sh-3),inset 0 1px 0 rgba(246,231,193,.1);
}
/* foil rim */
.plate-frame::after{
  content:'';position:absolute;inset:0;border-radius:14px;padding:1px;z-index:4;pointer-events:none;
  background:linear-gradient(150deg,rgba(246,231,193,.55),transparent 38%,transparent 62%,rgba(191,129,8,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
}
.plate-frame svg.scene{position:absolute;inset:0;width:100%;height:100%;color:var(--gold-400);filter:drop-shadow(0 8px 24px rgba(191,129,8,.4))}
.plate-frame .scene-glow{position:absolute;inset:0;background:radial-gradient(circle at 50% 42%,rgba(233,200,121,.2),transparent 62%)}
.plate-corner{position:absolute;width:30px;height:30px;border-color:var(--gold-400);border-style:solid;z-index:2;animation:pulse 3.4s ease-in-out infinite}
.plate-corner.tl{top:12px;right:12px;border-width:2px 0 0 2px}
.plate-corner.br{bottom:12px;left:12px;border-width:0 2px 2px 0;animation-delay:.7s}
@keyframes pulse{0%,100%{opacity:.4} 50%{opacity:1}}
.about-badge{
  position:absolute;left:12px;bottom:18px;z-index:3;
  background:linear-gradient(135deg,var(--ink-700),var(--ink-600));
  border:1px solid rgba(217,169,60,.35);padding:12px 18px;border-radius:4px;
  text-align:center;box-shadow:0 16px 40px rgba(0,0,0,.6);
}
.about-badge .b-since{display:block;font-size:.56rem;letter-spacing:.3em;color:var(--gold-300);margin-bottom:.12rem}
.about-badge .b-year{display:block;font-family:var(--ff-disp);font-size:1.8rem;color:var(--gold-100);line-height:1}
.about-body p{color:var(--parch-dim);margin-bottom:1.3rem;line-height:2.1;font-size:.97rem}
.about-body p .drop{font-family:var(--ff-disp);font-size:1.5em;color:var(--gold-400)}
.stats{display:flex;margin-top:2rem;padding-top:1.8rem;border-top:1px solid rgba(191,129,8,.14)}
.stat{flex:1;text-align:center}
.stat .n{font-family:var(--ff-disp);font-size:2.1rem;color:var(--gold-100);line-height:1}
.stat .l{font-size:.7rem;color:var(--muted);letter-spacing:.04em;margin-top:.3rem}
.stat+.stat{border-right:1px solid rgba(191,129,8,.14)}

/* ═══════════════════════════
   EXPERIENCE — swipe carousel (mobile)
═══════════════════════════ */
.exp{padding:var(--sp-sec) 0;background:var(--ink-850);position:relative;overflow:hidden}
.exp::before{
  content:'';position:absolute;inset:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90'%3E%3Cpolygon points='45,9 53,31 76,31 58,45 65,67 45,53 25,67 32,45 14,31 37,31' fill='none' stroke='rgba(191,129,8,0.05)' stroke-width='.7'/%3E%3C/svg%3E");
}
.exp .wrap{position:relative}
.exp-track{
  display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
  gap:14px;padding:48px 20px 4px;margin:0 -20px;
}
.exp-track::-webkit-scrollbar{display:none}
.xcard{
  flex:0 0 82vw;min-width:250px;scroll-snap-align:start;
  position:relative;padding:38px 28px;border:1px solid rgba(191,129,8,.16);border-radius:16px;
  background:var(--glass),linear-gradient(165deg,rgba(37,22,12,.5),rgba(11,7,5,.2));
  box-shadow:var(--sh-1),inset 0 1px 0 rgba(246,231,193,.06);overflow:hidden;
  transition:border-color .5s,box-shadow .5s,transform .5s var(--spring-soft);
}
.xcard:active{transform:scale(.97)}
/* foil rim */
.xcard::after{
  content:'';position:absolute;inset:0;border-radius:16px;padding:1px;
  background:linear-gradient(150deg,rgba(246,231,193,.45),transparent 40%,transparent 60%,rgba(191,129,8,.3));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s;pointer-events:none;
}
.xcard::before{
  content:'';position:absolute;top:0;right:0;width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold-400),transparent);
  transform:scaleX(0);transform-origin:right;transition:transform .6s var(--ease);
}
.xcard:hover::before,.xcard:active::before{transform:scaleX(1)}
.xcard:hover::after,.xcard:active::after{opacity:1}
/* glowing emblem disc behind the icon */
.xcard-ico{
  position:relative;width:64px;height:64px;color:var(--gold-400);margin-bottom:1.4rem;
  padding:0;display:grid;place-items:center;
  transition:transform .6s var(--spring);
  filter:drop-shadow(0 6px 16px rgba(191,129,8,.4));
}
.xcard-ico::before{
  content:'';position:absolute;inset:-10px -10px -10px -10px;border-radius:50%;z-index:-1;
  background:radial-gradient(circle,rgba(233,200,121,.16),transparent 68%);
}
.xcard:hover .xcard-ico,.xcard:active .xcard-ico{transform:scale(1.1) rotate(-4deg)}
.xcard-num{position:absolute;top:22px;left:24px;font-family:var(--ff-lat);font-size:2.6rem;color:rgba(191,129,8,.18);font-style:italic;line-height:1}
.xcard h3{font-family:var(--ff-disp);font-size:1.5rem;font-weight:400;color:var(--gold-100);margin-bottom:.6rem}
.xcard p{font-size:.9rem;color:var(--parch-dim);line-height:2}

/* ═══════════════════════════
   CAROUSEL DOTS (shared)
═══════════════════════════ */
.c-dots{display:flex;justify-content:center;gap:7px;padding:14px 0 0}
.c-dot{
  width:7px;height:7px;border-radius:50%;background:var(--muted-2);
  transition:background .3s,width .35s var(--ease),border-radius .35s;
}
.c-dot.on{background:var(--gold-400);width:22px;border-radius:4px}

/* ═══════════════════════════
   MENU SECTION
═══════════════════════════ */
.menu{
  position:relative;padding:var(--sp-sec) 0;
  background:linear-gradient(150deg,var(--ink-800),var(--ink-700) 50%,var(--ink-800));
  overflow:hidden;
}
.menu .rule{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-500),transparent)}
.menu .rule.top{top:0}.menu .rule.bot{bottom:0}
.menu-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;margin-top:24px}
.menu-copy .step{display:flex;gap:1rem;margin-bottom:1.3rem;align-items:flex-start}
.menu-copy .step .si{
  flex-shrink:0;width:38px;height:38px;border:1px solid rgba(217,169,60,.35);border-radius:50%;
  display:grid;place-items:center;font-family:var(--ff-disp);color:var(--gold-300);font-size:1rem;
}
.menu-copy .step .st{font-size:.92rem;color:var(--parch-dim);padding-top:7px;line-height:1.7}
.menu-copy .step .st b{color:var(--gold-100);font-weight:700}
.qr-stage{display:flex;justify-content:center}
.qr-card{
  position:relative;padding:0;background:transparent;border:none;
}
/* category tiles */
.cat-tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;
  aspect-ratio:1;border:1px solid rgba(191,129,8,.22);border-radius:16px;
  background:var(--glass),linear-gradient(165deg,rgba(37,22,12,.5),rgba(11,7,5,.25));
  box-shadow:var(--sh-1),inset 0 1px 0 rgba(246,231,193,.06);
  color:var(--gold-100);transition:transform .45s var(--spring-soft),border-color .4s,box-shadow .45s;
  position:relative;overflow:hidden;touch-action:manipulation;
}
.cat-tile::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 120%,rgba(233,200,121,.22),transparent 62%);
  opacity:.4;transition:opacity .4s;
}
.cat-tile svg{width:46px;height:46px;color:var(--gold-400);transition:transform .45s var(--spring);filter:drop-shadow(0 5px 14px rgba(191,129,8,.4))}
.cat-tile span{position:relative;font-family:var(--ff-disp);font-size:1.15rem;letter-spacing:.01em}
.cat-tile:hover,.cat-tile:active{transform:translateY(-3px);border-color:rgba(217,169,60,.5);box-shadow:var(--sh-2)}
.cat-tile:active{transform:scale(.96)}
.cat-tile:hover::before,.cat-tile:active::before{opacity:1}
.cat-tile:hover svg,.cat-tile:active svg{transform:scale(1.12) translateY(-3px)}

/* ═══════════════════════════
   GALLERY — swipe carousel (mobile)
═══════════════════════════ */
.gallery{padding:var(--sp-sec) 0}
.g-track{
  display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
  gap:12px;padding:48px 20px 4px;margin:0 -20px;
}
.g-track::-webkit-scrollbar{display:none}
.g-card{
  flex:0 0 76vw;height:270px;min-width:220px;scroll-snap-align:start;
  position:relative;border-radius:16px;overflow:hidden;
  border:1px solid rgba(191,129,8,.22);
  background:
    radial-gradient(120% 90% at 70% 12%,rgba(140,36,16,.28),transparent 55%),
    radial-gradient(circle at 50% 36%,var(--ink-600),var(--ink-850) 78%);
  box-shadow:var(--sh-2),inset 0 1px 0 rgba(246,231,193,.08);
  transition:transform .5s var(--spring-soft),box-shadow .5s,border-color .5s;
}
/* foil rim highlight */
.g-card::before{
  content:'';position:absolute;inset:0;border-radius:16px;padding:1px;z-index:3;
  background:linear-gradient(150deg,rgba(246,231,193,.5),transparent 35%,transparent 65%,rgba(191,129,8,.35));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.7;transition:opacity .5s;pointer-events:none;
}
.g-card:active{transform:scale(.97)}
.g-art{
  position:absolute;inset:0;display:grid;place-items:center;
  color:var(--gold-400);opacity:1;
  transition:transform .8s var(--spring-soft),opacity .5s;
  filter:drop-shadow(0 8px 22px rgba(191,129,8,.4));
}
.g-art svg{width:62%;height:62%;overflow:visible}
.g-card:hover .g-art,.g-card:active .g-art{transform:scale(1.07) translateY(-4px)}
.g-card:hover,.g-card:active{box-shadow:var(--sh-3),inset 0 1px 0 rgba(246,231,193,.12);border-color:rgba(217,169,60,.4)}
.g-card:hover::before,.g-card:active::before{opacity:1}
.g-card::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(6,4,3,.92) 4%,rgba(6,4,3,.25) 42%,transparent 70%)}
.g-card .g-glow{position:absolute;inset:0;z-index:0;background:radial-gradient(circle at 50% 36%,rgba(233,200,121,.18),transparent 62%);opacity:.55;transition:opacity .5s}
.g-card:hover .g-glow,.g-card:active .g-glow{opacity:1}
/* frosted label plate */
.g-label{
  position:absolute;bottom:14px;right:14px;left:14px;z-index:4;
  display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;
  padding:10px 14px;border-radius:10px;
  background:linear-gradient(120deg,rgba(11,7,5,.55),rgba(11,7,5,.2));
  backdrop-filter:blur(8px) saturate(140%);-webkit-backdrop-filter:blur(8px) saturate(140%);
  border:1px solid rgba(191,129,8,.18);
}
.g-label .gl-fa{display:block;font-family:var(--ff-disp);font-size:1.3rem;color:var(--gold-100);line-height:1.2}
.g-label .gl-en{font-family:var(--ff-lat);font-style:italic;font-size:.78rem;letter-spacing:.16em;color:var(--gold-300);text-transform:uppercase}
.g-note{text-align:center;margin-top:1.4rem;font-size:.78rem;color:var(--muted-2)}

/* ═══════════════════════════
   CONTACT
═══════════════════════════ */
.contact{padding:var(--sp-sec) 0;background:var(--ink-850);border-top:1px solid rgba(191,129,8,.1)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:44px;align-items:start}
.c-list{margin-top:1.8rem;display:flex;flex-direction:column;gap:1.4rem}
.c-row{
  display:flex;gap:1rem;align-items:center;
  padding:14px 16px;border:1px solid rgba(191,129,8,.12);border-radius:12px;
  background:linear-gradient(160deg,rgba(255,255,255,.02),transparent);
  transition:border-color .35s,background .35s,transform .35s var(--spring-soft),box-shadow .35s;
}
.c-row:hover,.c-row:active{border-color:rgba(191,129,8,.35);background:rgba(191,129,8,.05);transform:scale(1.015);box-shadow:var(--sh-1)}
.c-ico{
  flex-shrink:0;width:44px;height:44px;border:1px solid rgba(191,129,8,.22);
  border-radius:50%;display:grid;place-items:center;color:var(--gold-400);transition:.4s var(--ease);
}
.c-row:hover .c-ico,.c-row:active .c-ico{border-color:var(--gold-400);background:rgba(191,129,8,.08)}
.c-ico svg{width:19px;height:19px}
.c-row .c-k{display:block;font-size:.64rem;letter-spacing:.18em;color:var(--gold-300);text-transform:uppercase;margin-bottom:.22rem}
.c-row .c-v{font-size:.93rem;color:var(--parch-dim)}
.c-v.wa{color:#37d069;font-weight:600;transition:color .3s}
.c-row:hover .c-v.wa,.c-row:active .c-v.wa{color:#5cee8a}
.c-map{
  position:relative;min-height:300px;border:1px solid rgba(191,129,8,.18);
  border-radius:12px;overflow:hidden;
  background:radial-gradient(circle at 50% 50%,var(--ink-600),var(--ink-850) 75%);
  display:grid;place-items:center;
}
.c-map::before{
  content:'';position:absolute;inset:0;opacity:.6;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='70' height='70'%3E%3Cg fill='none' stroke='rgba(191,129,8,0.06)' stroke-width='.7'%3E%3Cpath d='M0,35H70M35,0V70M0,0L70,70M70,0L0,70'/%3E%3Ccircle cx='35' cy='35' r='20'/%3E%3C/g%3E%3C/svg%3E");
}
.c-map .pin{position:relative;text-align:center;color:var(--muted)}
.c-map .pin svg{width:48px;height:48px;color:var(--pom-500);margin:0 auto .7rem;filter:drop-shadow(0 0 20px rgba(140,36,16,.6));animation:pin-bob 2.4s ease-in-out infinite}
@keyframes pin-bob{0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)}}
.c-map .pin span{font-size:.78rem;letter-spacing:.06em}

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
.footer{position:relative;padding:60px 0 28px;border-top:1px solid rgba(191,129,8,.18);overflow:hidden}
.footer::before{
  content:'';position:absolute;inset:0;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90'%3E%3Cpolygon points='45,9 53,31 76,31 58,45 65,67 45,53 25,67 32,45 14,31 37,31' fill='none' stroke='rgba(191,129,8,0.04)' stroke-width='.7'/%3E%3C/svg%3E");
}
.footer .wrap{position:relative}
.f-top{display:flex;flex-direction:column;align-items:center;gap:.9rem;text-align:center;margin-bottom:2rem}
.f-logo{max-height:120px;width:auto;filter:drop-shadow(0 8px 30px rgba(191,129,8,.25))}
.f-slogan{font-size:.78rem;color:var(--muted);letter-spacing:.14em}
.f-social{display:flex;gap:.8rem;margin-top:.3rem}
.f-social a{
  width:44px;height:44px;border:1px solid rgba(191,129,8,.22);border-radius:50%;
  display:grid;place-items:center;color:var(--parch-dim);transition:.4s var(--ease);
  touch-action:manipulation;
}
.f-social a svg{width:18px;height:18px}
.f-social a:hover,.f-social a:active{color:var(--gold-100);border-color:var(--gold-400);background:rgba(191,129,8,.1);transform:translateY(-3px)}
.f-orn{text-align:center;margin:1.4rem 0;opacity:.45}
.f-orn svg{width:130px;height:20px;margin:0 auto;color:var(--gold-500)}
.f-bottom{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;
  border-top:1px solid rgba(191,129,8,.1);padding-top:1.5rem;
  font-size:.72rem;color:var(--muted-2);
}

/* ════════════════════════════════
   DESKTOP BREAKPOINTS
════════════════════════════════ */
@media(min-width:768px){
  /* reset mobile body padding */
  body{padding-bottom:0}
  .wrap{padding:0 32px}

  /* hide bottom nav, restore desktop nav */
  .b-nav{display:none}
  .hero-scroll{bottom:30px}

  /* navbar */
  .nav{padding:26px 0}
  .nav.shrink{padding:13px 0}
  .brand-logo{height:42px}
  .nav.shrink .brand-logo{height:34px}

  /* hero */
  .hero-content{padding:0 24px;padding-top:0}
  .hero-actions{flex-direction:row;align-items:center;justify-content:center}

  /* about */
  .about{padding:130px 0}
  .about-grid{grid-template-columns:.92fr 1.08fr;gap:90px}
  .plate-frame{max-height:none}
  .about-badge{left:-18px;bottom:40px}

  /* experience */
  .exp{padding:120px 0}
  .exp-track{
    display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
    overflow:visible;padding:64px 0 0;margin:0;
  }
  .xcard{flex:none;border-radius:4px;padding:44px 34px}
  .xcard:hover{transform:translateY(-8px);border-color:rgba(217,169,60,.35);box-shadow:0 30px 60px rgba(0,0,0,.45)}
  .xcard:active{transform:scale(1)}
  .xcard-ico{width:58px;height:58px}

  /* menu */
  .menu{padding:130px 0}
  .menu-grid{grid-template-columns:1.05fr .95fr;gap:80px;margin-top:30px}

  /* gallery */
  .gallery{padding:130px 0}
  .g-track{
    display:grid;
    grid-template-columns:repeat(12,1fr);grid-auto-rows:230px;gap:16px;
    overflow:visible;padding:64px 0 0;margin:0;scroll-snap-type:none;
  }
  .g-card{
    flex:none;height:auto;border-radius:4px;scroll-snap-align:none;
  }
  .g-card:nth-child(1){grid-column:1/6;grid-row:span 2}
  .g-card:nth-child(2){grid-column:6/10}
  .g-card:nth-child(3){grid-column:10/13}
  .g-card:nth-child(4){grid-column:6/9}
  .g-card:nth-child(5){grid-column:9/13}
  .g-card:active{transform:none}

  /* contact */
  .contact{padding:130px 0}
  .contact-grid{grid-template-columns:1fr 1.05fr;gap:80px}
  .c-map{min-height:420px}
  .c-row{padding:0;border:none;border-radius:0}
  .c-row:hover,.c-row:active{background:transparent;border-color:transparent}

  /* footer */
  .footer{padding:70px 0 34px}
  .f-bottom{flex-direction:row;justify-content:space-between;text-align:left}
}

/* tablet — show burger, hide full nav links */
@media(min-width:768px) and (max-width:1023px){
  .nav-menu{display:none}
  .burger{display:block}
}

/* desktop — full nav links */
@media(min-width:1024px){
  .nav-menu{display:flex;align-items:center;gap:2.3rem}
  .nav-menu a{font-size:.86rem;color:var(--parch-dim);position:relative;transition:color .3s;padding:4px 0}
  .nav-menu a::after{content:'';position:absolute;bottom:-2px;right:0;width:0;height:1px;background:var(--gold-400);transition:width .35s var(--ease)}
  .nav-menu a:hover,.nav-menu a.active{color:var(--gold-100)}
  .nav-menu a:hover::after,.nav-menu a.active::after{width:100%}
}

/* carousel dots hidden on desktop (grids show instead) */
@media(min-width:768px){
  .c-dots{display:none}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.1s !important}
  .rv{opacity:1;transform:none}
}
