/* ============================================================
   LUTERIA FAGUNDES — "IL VIRTUOSO"
   Chiaroscuro de ateliê · verniz âmbar de Cremona sobre espresso
   ============================================================ */

:root{
  --ink:#0c0907;          /* espresso noir */
  --ink-2:#15100b;        /* surface dark */
  --ink-3:#1e1610;        /* raised */
  --paper:#f3ebdb;        /* ivory showroom */
  --paper-2:#ece1cd;
  --amber:#c8772f;        /* verniz — acento âncora */
  --amber-2:#e0913f;      /* glow / hover */
  --ruby:#8f3415;         /* verniz profundo */
  --gold:#c4a45c;         /* detalhes finos */
  --muted:#b4a690;        /* warm gray on dark */
  --muted-ink:#6c6151;    /* muted on ivory */
  --line:rgba(243,235,219,.13);
  --line-2:rgba(28,20,12,.14);
  --maxw:1280px;
  --ease:cubic-bezier(.76,0,.24,1);
  --ease-out:cubic-bezier(.2,.7,.2,1);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);color:var(--paper);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  overflow-x:clip;-webkit-font-smoothing:antialiased;
}
body.lock{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--amber)}
::selection{background:var(--amber);color:var(--ink)}

/* ---------- LOADER ---------- */
.loader{
  position:fixed;inset:0;z-index:10000;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  transition:transform 1.05s var(--ease);
}
.loader.done{transform:translateY(-101%)}
.loader__mark img{opacity:.92;animation:floaty 3s ease-in-out infinite}
.loader__word{font-family:var(--serif);font-size:clamp(1.6rem,5vw,2.6rem);letter-spacing:.18em;color:var(--paper)}
.loader__sub{font-family:var(--mono);font-size:.66rem;letter-spacing:.32em;color:var(--muted)}
.lbar{width:min(240px,52vw);height:2px;background:rgba(255,255,255,.12);overflow:hidden;margin-top:6px}
.lbar i{display:block;height:100%;width:0;background:var(--amber);animation:ld 1.3s var(--ease-out) forwards}
@keyframes ld{to{width:100%}}
@keyframes floaty{50%{transform:translateY(-6px)}}

/* ---------- GRAIN / PROGRESS / CURSOR ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;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='160' height='160'%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)'/%3E%3C/svg%3E");
}
.scrollbar{position:fixed;top:0;left:0;height:2px;width:0;background:var(--amber);z-index:9500}
.cursor{
  position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--amber);border-radius:50%;
  transform:translate(-50%,-50%);pointer-events:none;z-index:9600;
  transition:width .25s var(--ease-out),height .25s var(--ease-out),background .25s,border-color .25s;
  mix-blend-mode:difference;
}
.cursor.grow{width:64px;height:64px;background:rgba(200,119,47,.16);border-color:transparent}
@media (pointer:coarse){.cursor{display:none}}

/* ---------- UTILITIES ---------- */
.eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;color:var(--muted)}
.eyebrow--dark{color:var(--muted-ink)}
.eyebrow--light{color:var(--muted)}
.eyebrow .num{color:var(--amber)}
.eyebrow__dot{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(200,119,47,.18)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--sans);font-size:.82rem;font-weight:600;letter-spacing:.04em;
  padding:1.05em 1.8em;border-radius:2px;cursor:pointer;border:1px solid transparent;
  transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s;white-space:nowrap;
}
.btn--amber{background:var(--amber);color:#1a1109}
.btn--amber:hover{background:var(--amber-2);transform:translateY(-2px)}
.btn--ghost{border-color:var(--line-2);color:var(--ink)}
.btn--ghost:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-2px)}
.btn--ghost-light{border-color:var(--line);color:var(--paper)}
.btn--ghost-light:hover{border-color:var(--amber);color:var(--amber)}
.btn--block{width:100%}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.clip{clip-path:inset(0 0 100% 0);transition:clip-path 1.15s var(--ease)}
.clip.in{clip-path:inset(0 0 0 0)}

/* line reveal */
.ln{display:block;overflow:hidden}
.ln>span{display:block;transform:translateY(115%);transition:transform 1.1s var(--ease)}
.ready .ln>span{transform:translateY(0)}
.ready .ln:nth-child(2)>span{transition-delay:.09s}
.ready .ln:nth-child(3)>span{transition-delay:.18s}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:8000;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:22px clamp(18px,4vw,56px);
  transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent;
}
.nav.solid{background:rgba(12,9,7,.82);backdrop-filter:blur(14px);padding:14px clamp(18px,4vw,56px);border-bottom-color:var(--line)}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__seal{filter:none}
.nav__name{font-family:var(--serif);font-size:1.15rem;letter-spacing:.12em;color:var(--paper)}
.nav__links{display:flex;gap:30px}
.nav__links a{font-size:.82rem;letter-spacing:.04em;color:var(--muted);position:relative;padding:4px 0;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--amber);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--paper)}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:16px}
.cart-btn{position:relative;background:none;border:none;color:var(--paper);cursor:pointer;display:flex;padding:6px}
.cart-count{position:absolute;top:-4px;right:-6px;background:var(--amber);color:#1a1109;font-family:var(--mono);
  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}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:1.6px;background:var(--paper);transition:.3s}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:7900;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  opacity:0;pointer-events:none;transform:translateY(-12px);transition:opacity .4s,transform .4s;
}
.mobile-menu.open{opacity:1;pointer-events:auto;transform:none}
.mobile-menu a{font-family:var(--serif);font-size:1.8rem;color:var(--paper)}
.mobile-menu a.btn{font-family:var(--sans);font-size:.9rem}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 clamp(18px,4vw,56px) clamp(28px,5vh,56px);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__img{width:100%;height:120%;object-fit:cover;transform:scale(1.08);
  animation:kenburns 26s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{to{transform:scale(1.2) translateY(-3%)}}
.hero__veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,9,7,.55) 0%,rgba(12,9,7,.2) 35%,rgba(12,9,7,.78) 80%,var(--ink) 100%),
             radial-gradient(120% 80% at 70% 30%,transparent 40%,rgba(12,9,7,.6) 100%)}
.hero__grid{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:clamp(60px,8vw,120px) clamp(60px,8vw,120px);
  mask-image:radial-gradient(80% 70% at 50% 40%,#000 30%,transparent 80%)}
.hero__inner{position:relative;max-width:var(--maxw);width:100%;margin:0 auto}
.hero__title{font-family:var(--serif);font-weight:500;
  font-size:clamp(3rem,11.5vw,11rem);line-height:.92;letter-spacing:-.02em;color:var(--paper);margin:.28em 0 .4em}
.hero__lede{max-width:46ch;font-size:clamp(1rem,1.5vw,1.18rem);color:#e7ddca;font-weight:400}
.hero__lede strong{color:var(--paper);font-weight:600}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero__foot{position:relative;max-width:var(--maxw);width:100%;margin:48px auto 0;
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px}
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.scrollcue i{width:1px;height:46px;background:linear-gradient(var(--amber),transparent);position:relative;overflow:hidden}
.scrollcue i::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--paper);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{to{top:100%}}
.hero__meta{display:flex;flex-direction:column;gap:6px;text-align:right;font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}

/* ---------- CINEMA (violino scrollytelling) ---------- */
.cinema{position:relative;height:400vh;background:#070504}
.cinema__stage{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;perspective:1600px}
.cinema__stage::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,#070504 0%,rgba(7,5,4,.72) 26%,rgba(7,5,4,0) 56%)}
.cinema__bars{position:absolute;inset:0;z-index:5;pointer-events:none}
.cinema__bars i{position:absolute;left:0;width:100%;height:0;background:#000;transition:height .9s var(--ease)}
.cinema__bars i:first-child{top:0}
.cinema__bars i:last-child{bottom:0}
.cinema.active .cinema__bars i{height:6.5vh}
.cinema__glow{position:absolute;width:78vmax;height:78vmax;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(200,119,47,.34),rgba(200,119,47,0) 60%);filter:blur(20px);will-change:transform,opacity}
.cinema__grid{position:absolute;inset:0;z-index:0;opacity:.22;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:92px 92px;mask-image:radial-gradient(68% 68% at 50% 50%,#000,transparent 78%)}
.cinema__violin{position:absolute;height:96vh;z-index:2;will-change:transform;
  filter:drop-shadow(0 50px 90px rgba(0,0,0,.75));transform-origin:center center;backface-visibility:hidden}
.cinema__violin img{height:96vh;width:auto;display:block}
.cinema__copy{position:absolute;left:clamp(18px,5vw,80px);top:50%;transform:translateY(-50%);z-index:3;width:min(440px,44vw)}
.cinema__count{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;display:block;margin-bottom:20px}
.cinema__count b{color:var(--amber);font-weight:500}
.cinema__count i{color:var(--muted);font-style:normal}
.cinema__chapters{position:relative;min-height:280px}
.ch{position:absolute;inset:0;opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease);pointer-events:none}
.ch.is-on{opacity:1;transform:none}
.ch h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.2vw,4.6rem);line-height:.94;margin-bottom:18px;color:var(--paper)}
.ch p{color:var(--muted);font-size:1.06rem;max-width:32ch}
.cinema__rail{position:absolute;right:clamp(16px,4vw,54px);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;z-index:3}
.cinema__rail i{width:2px;height:38px;background:var(--line);transition:background .4s,height .4s}
.cinema__rail i.on{background:var(--amber);height:54px}
.cinema__hint{position:absolute;bottom:8.5vh;left:50%;transform:translateX(-50%);font-family:var(--mono);
  font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);z-index:3;opacity:.85;white-space:nowrap}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--amber);color:#1a1109;padding:16px 0;overflow:hidden;border-block:1px solid rgba(0,0,0,.15)}
.marquee__track{display:flex;align-items:center;gap:0;white-space:nowrap;width:max-content;animation:marq 38s linear infinite}
.marquee__track span{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,2.1rem);font-style:italic;padding:0 .55em}
.marquee__track b{font-size:1rem;opacity:.6}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- CREDENCIAIS ---------- */
.creds{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vw,150px) clamp(18px,4vw,56px)}
.creds__intro{max-width:760px;margin-bottom:clamp(40px,6vw,80px)}
.creds__head{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.06;margin-top:18px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.stat{background:var(--ink);padding:clamp(24px,3vw,40px) clamp(20px,2.4vw,32px);display:flex;flex-direction:column;gap:14px}
.stat__num{font-family:var(--serif);font-size:clamp(2.6rem,6vw,5rem);line-height:.9;color:var(--amber)}
.stat__lab{font-size:.8rem;color:var(--muted);line-height:1.5}

/* ---------- SHOP (ATO CLARO) ---------- */
.shop{background:var(--paper);color:var(--ink);padding:clamp(70px,11vw,150px) clamp(18px,4vw,56px);
  border-radius:0;position:relative}
.shop__head{max-width:var(--maxw);margin:0 auto}
.shop__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.8rem,8vw,7rem);line-height:.9;letter-spacing:-.02em;margin:16px 0 18px}
.shop__lede{max-width:54ch;color:var(--muted-ink);font-size:1.02rem}
.filters{max-width:var(--maxw);margin:42px auto 36px;display:flex;flex-wrap:wrap;gap:10px}
.filter{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.7em 1.3em;border:1px solid var(--line-2);background:none;color:var(--muted-ink);cursor:pointer;border-radius:2px;transition:.3s}
.filter:hover{border-color:var(--ink);color:var(--ink)}
.filter.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,30px)}
.card{background:#fff;border:1px solid var(--line-2);border-radius:3px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s,border-color .5s}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(60,30,10,.35);border-color:rgba(200,119,47,.4)}
.card__media{position:relative;aspect-ratio:4/5;overflow:hidden;
  background:radial-gradient(75% 65% at 50% 36%,#ffffff 0%,#fbf7ef 70%,#f6efe2 100%)}
.card__media img{width:100%;height:100%;object-fit:contain;padding:14% 16%;transition:transform .9s var(--ease)}
.card:hover .card__media img{transform:scale(1.07)}
.card__tag{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;background:var(--ink);color:var(--paper);padding:.4em .8em;border-radius:2px}
.card__body{padding:22px 22px 20px;display:flex;flex-direction:column;gap:6px;flex:1;border-top:1px solid var(--line-2)}
.card__name{font-family:var(--serif);font-size:1.5rem;font-weight:500;line-height:1.05}
.card__model{font-size:.82rem;color:var(--muted-ink);flex:1}
.card__foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:10px}
.card__price{font-family:var(--mono);font-size:.86rem;color:var(--ruby);font-weight:500}
.add{font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.03em;
  border:1px solid var(--ink);background:none;color:var(--ink);padding:.6em 1em;border-radius:2px;cursor:pointer;transition:.3s;white-space:nowrap}
.add:hover{background:var(--amber);border-color:var(--amber);color:#1a1109}
.add.added{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.shop__note{max-width:var(--maxw);margin:38px auto 0;font-size:.92rem;color:var(--muted-ink)}
.shop__note a{color:var(--ruby);border-bottom:1px solid currentColor;padding-bottom:1px}
.card.hide{display:none}

/* ---------- FEATURE ---------- */
.feature{background:var(--ink);display:grid;grid-template-columns:1.05fr 1fr;align-items:stretch;gap:0}
.feature__media{position:relative;min-height:60vh;overflow:hidden;background:#0a0705;
  display:flex;align-items:center;justify-content:center}
.feature__media img{width:100%;height:100%;object-fit:cover}
.feature__sig{position:absolute;bottom:4%;right:5%;font-family:var(--serif);font-style:italic;
  font-size:clamp(4rem,12vw,11rem);color:rgba(243,235,219,.07)}
.feature__body{padding:clamp(48px,7vw,110px) clamp(22px,5vw,80px);display:flex;flex-direction:column;justify-content:center}
.feature__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.4vw,4.6rem);line-height:.94;margin:18px 0 20px}
.feature__desc{color:var(--muted);max-width:46ch;margin-bottom:28px}
.spec{list-style:none;border-top:1px solid var(--line)}
.spec li{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line)}
.spec span{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.spec b{font-weight:500;text-align:right;color:var(--paper)}
.feature__cta{display:flex;align-items:center;gap:22px;margin-top:32px;flex-wrap:wrap}
.feature__price{font-family:var(--serif);font-size:1.6rem;color:var(--amber)}

/* ---------- CRAFT (O OFÍCIO) ---------- */
.craft{padding:clamp(70px,11vw,150px) clamp(18px,4vw,56px);max-width:var(--maxw);margin:0 auto}
.craft__head{max-width:680px;margin-bottom:42px}
.craft__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,6.2vw,5.4rem);line-height:.92;letter-spacing:-.02em;margin-top:16px}
.craft__media{position:relative;aspect-ratio:21/9;overflow:hidden;border-radius:3px;margin-bottom:44px}
.craft__media img{width:100%;height:100%;object-fit:cover}
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{background:var(--ink);padding:clamp(24px,2.6vw,38px) clamp(20px,2vw,30px)}
.step__n{font-family:var(--mono);font-size:.8rem;color:var(--amber);letter-spacing:.1em}
.step h3{font-family:var(--serif);font-size:1.5rem;font-weight:500;margin:16px 0 10px}
.step p{font-size:.86rem;color:var(--muted)}

/* ---------- BLUEPRINT ---------- */
.blueprint{position:relative;overflow:hidden}
.blueprint img{width:100%;max-height:70vh;object-fit:cover;filter:saturate(.92)}
.blueprint__cap{position:absolute;left:0;bottom:0;padding:clamp(24px,4vw,56px);max-width:560px;
  background:linear-gradient(90deg,rgba(12,9,7,.85),transparent)}
.blueprint__cap p:last-child{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.6rem);color:var(--paper);margin-top:12px;line-height:1.3}

/* ---------- LUTHIER ---------- */
.luthier{display:grid;grid-template-columns:1fr 1.1fr;gap:0;align-items:stretch;background:var(--ink-2)}
.luthier__media{position:relative;min-height:70vh;overflow:hidden}
.luthier__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.04)}
.luthier__badge{position:absolute;top:24px;left:24px;font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;
  text-transform:uppercase;background:var(--amber);color:#1a1109;padding:.5em 1em;border-radius:2px}
.luthier__body{padding:clamp(48px,7vw,110px) clamp(22px,5vw,80px);display:flex;flex-direction:column;justify-content:center}
.luthier__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.8rem,6.5vw,5.6rem);line-height:.9;margin:16px 0 26px}
.luthier__quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.9rem);
  color:var(--paper);line-height:1.34;border-left:2px solid var(--amber);padding-left:22px;margin-bottom:26px}
.luthier__text{color:var(--muted);max-width:52ch;margin-bottom:30px}
.luthier__text strong{color:var(--paper);font-weight:600}

/* ---------- SERVIÇOS ---------- */
.serv{background:var(--paper);color:var(--ink);padding:clamp(70px,11vw,150px) clamp(18px,4vw,56px)}
.serv__head{max-width:var(--maxw);margin:0 auto 48px}
.serv__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,7vw,6rem);line-height:.9;margin-top:16px}
.serv__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,1.6vw,22px)}
.scard{position:relative;background:#fff;border:1px solid var(--line-2);border-radius:3px;
  padding:clamp(28px,3.4vw,48px);display:flex;flex-direction:column;gap:12px;min-height:230px;
  transition:transform .5s var(--ease),box-shadow .5s,border-color .5s;overflow:hidden}
.scard:hover{transform:translateY(-5px);box-shadow:0 30px 60px -34px rgba(60,30,10,.35);border-color:rgba(200,119,47,.45)}
.scard__n{font-family:var(--mono);font-size:.74rem;color:var(--amber);letter-spacing:.12em}
.scard h3{font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,2rem);font-weight:500;line-height:1.05}
.scard p{color:var(--muted-ink);font-size:.92rem;flex:1}
.scard__go{font-size:.8rem;font-weight:600;color:var(--ruby);transition:gap .3s}
.scard--feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.scard--feat h3{color:var(--paper)}.scard--feat p{color:var(--muted)}.scard--feat .scard__go{color:var(--amber)}

/* ---------- COURSE ---------- */
.course{position:relative;background:var(--ink);padding:clamp(80px,13vw,180px) clamp(18px,4vw,56px);overflow:hidden}
.course::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 80% at 80% 30%,rgba(200,119,47,.16),transparent 60%)}
.course__inner{position:relative;max-width:880px;margin:0 auto;text-align:center}
.course__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,6vw,5.2rem);line-height:.94;margin:18px 0 22px}
.course__lede{color:var(--muted);max-width:54ch;margin:0 auto 34px;font-size:1.06rem}
.course__lede strong{color:var(--paper)}
.course__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- VISIT ---------- */
.visit{background:var(--paper);color:var(--ink);display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.visit__info{padding:clamp(54px,7vw,120px) clamp(22px,5vw,72px);display:flex;flex-direction:column;justify-content:center}
.visit__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,6vw,5rem);line-height:.9;margin:16px 0 22px}
.visit__text{color:var(--muted-ink);max-width:44ch;margin-bottom:30px}
.visit__list{list-style:none;border-top:1px solid var(--line-2);margin-bottom:32px}
.visit__list li{display:flex;flex-direction:column;gap:3px;padding:15px 0;border-bottom:1px solid var(--line-2)}
.visit__list span{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-ink)}
.visit__list b{font-weight:500;font-size:1rem}
.visit__list a{border-bottom:1px solid var(--amber)}
.visit__cta{display:flex;gap:14px;flex-wrap:wrap}
.visit__map{min-height:420px}
.visit__map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.4) contrast(1.05) sepia(.12)}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink);padding:clamp(60px,8vw,110px) clamp(18px,4vw,56px) 28px;overflow:hidden}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.footer__col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:18px}
.footer__col p{color:var(--muted);font-size:.9rem;max-width:34ch;margin-top:14px}
.footer__col a{display:block;color:var(--muted);font-size:.9rem;padding:5px 0;transition:color .3s}
.footer__col a:hover{color:var(--paper)}
.footer__word{font-family:var(--serif);font-weight:600;font-size:clamp(4rem,21vw,20rem);line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(243,235,219,.1);text-stroke:1px rgba(243,235,219,.1);
  text-align:center;margin:48px 0 8px;letter-spacing:.02em;user-select:none}
.footer__bottom{max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line);padding-top:22px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.78rem;color:var(--muted)}
.footer__credit a{color:var(--amber)}

/* ---------- WHATSAPP FAB ---------- */
.wa-fab{position:fixed;bottom:24px;right:24px;z-index:8500;width:58px;height:58px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:transform .3s}
.wa-fab:hover{transform:scale(1.08)}

/* ---------- DRAWER ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(8,6,4,.6);backdrop-filter:blur(3px);z-index:8800;opacity:0;pointer-events:none;transition:opacity .4s}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,90vw);background:var(--ink-2);z-index:8900;
  transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;border-left:1px solid var(--line)}
.drawer.open{transform:none}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:26px 26px 18px;border-bottom:1px solid var(--line)}
.drawer__head h3{font-family:var(--serif);font-size:1.6rem;font-weight:500}
.drawer__close{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;transition:color .3s}
.drawer__close:hover{color:var(--paper)}
.drawer__body{flex:1;overflow-y:auto;padding:20px 26px}
.drawer__empty{color:var(--muted);font-size:.9rem;line-height:1.6;margin-top:20px}
.ditem{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.ditem__name{font-family:var(--serif);font-size:1.1rem;line-height:1.2}
.ditem__price{font-family:var(--mono);font-size:.74rem;color:var(--amber);margin-top:4px}
.ditem__rm{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.72rem;text-decoration:underline}
.ditem__rm:hover{color:var(--amber)}
.drawer__foot{padding:22px 26px;border-top:1px solid var(--line)}
.drawer__hint{font-size:.78rem;color:var(--muted);margin-bottom:14px;line-height:1.5}
.btn--block:disabled{opacity:.4;cursor:not-allowed}

/* card quick-view hint */
.card__view{position:absolute;bottom:12px;left:50%;transform:translateX(-50%) translateY(8px);
  font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);padding:.45em .9em;border-radius:2px;opacity:0;transition:.4s var(--ease);pointer-events:none}
.card:hover .card__view{opacity:1;transform:translateX(-50%) translateY(0)}
.card__media{cursor:pointer}

/* ---------- QUICK VIEW ---------- */
.qv-overlay{position:fixed;inset:0;background:rgba(7,5,4,.7);backdrop-filter:blur(5px);z-index:9100;opacity:0;pointer-events:none;transition:opacity .4s}
.qv-overlay.open{opacity:1;pointer-events:auto}
.qv{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%);z-index:9200;width:min(880px,92vw);max-height:90vh;
  background:var(--ink-2);border:1px solid var(--line);border-radius:5px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;
  opacity:0;pointer-events:none;transition:opacity .45s var(--ease),transform .45s var(--ease)}
.qv.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)}
.qv__media{background:radial-gradient(70% 60% at 50% 40%,#fff,#f4ecdd);display:flex;align-items:center;justify-content:center;min-height:340px}
.qv__media img{width:100%;height:100%;max-height:60vh;object-fit:contain;padding:8% 10%}
.qv__body{padding:clamp(26px,3vw,42px);display:flex;flex-direction:column;justify-content:center;gap:10px;overflow-y:auto}
.qv__tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.qv__name{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.6rem);font-weight:500;line-height:1.02}
.qv__desc{color:var(--muted);font-size:.92rem;line-height:1.6;margin:6px 0}
.qv__foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:8px}
.qv__price{font-family:var(--serif);font-size:1.5rem;color:var(--amber)}
.qv__wa{font-family:var(--sans);font-size:.82rem;color:var(--muted);margin-top:14px;border-bottom:1px solid var(--line);padding-bottom:2px;align-self:flex-start;transition:color .3s,border-color .3s}
.qv__wa:hover{color:var(--amber);border-color:var(--amber)}
.qv__close{position:absolute;top:14px;right:16px;z-index:2;background:rgba(7,5,4,.5);border:1px solid var(--line);color:var(--paper);
  width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1rem;transition:.3s}
.qv__close:hover{background:var(--amber);color:#1a1109;border-color:var(--amber)}
@media (max-width:680px){
  .qv{grid-template-columns:1fr;top:auto;bottom:0;transform:translate(-50%,100%);max-height:92vh;border-radius:14px 14px 0 0}
  .qv.open{transform:translate(-50%,0)}
  .qv__media{min-height:240px}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid{grid-template-columns:repeat(2,1fr)}
  .feature,.luthier,.visit{grid-template-columns:1fr}
  .feature__media,.luthier__media{min-height:54vh}
  .steps{grid-template-columns:repeat(2,1fr)}
  .serv__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .visit__map{min-height:340px}
  .visit__map iframe{min-height:340px}
}
@media (max-width:760px){
  .cinema{height:320vh}
  .cinema__stage::before{background:linear-gradient(0deg,#070504 0%,rgba(7,5,4,.7) 30%,rgba(7,5,4,0) 62%)}
  .cinema__violin,.cinema__violin img{height:62vh}
  .cinema__copy{left:50%;right:auto;top:auto;bottom:6vh;transform:translateX(-50%);width:min(92vw,520px);text-align:center}
  .cinema__count{margin-bottom:12px}
  .cinema__chapters{min-height:180px}
  .ch p{margin:0 auto}
  .cinema__rail{display:none}
  .cinema__hint{bottom:2vh}
}
@media (max-width:560px){
  .stats{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .hero__meta{display:none}
  .hero__foot{justify-content:center}
  .card__name{font-size:1.3rem}
  .card__body{padding:16px}
  .add{padding:.55em .8em}
  .footer__bottom{justify-content:center;text-align:center}
}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .loader{display:none}
  .reveal{opacity:1;transform:none}
  .clip{clip-path:inset(0)!important}
  .ln>span{transform:none!important}
  .hero__img{transform:scale(1.05)}
  .cursor{display:none}
  .cinema{height:auto}
  .cinema__stage{position:relative;height:auto;min-height:90vh;padding:14vh 0}
  .cinema__violin{position:relative;transform:none!important}
  .cinema__copy{position:relative;transform:none;top:auto;left:auto;margin-top:30px}
  .ch{position:relative;opacity:1;transform:none}
  .ch+.ch{margin-top:24px}
  .cinema__bars i{display:none}
}
