/* =========================================================================
   VÉORA AESTHETICS & PLASTIC SURGERY — shared system
   "Dusk & Champagne" — near-monochrome luxury, one atmospheric gradient.
   ========================================================================= */

/* ---- Fonts ---- */
/* Fraunces (display serif) via Google · General Sans (body grotesk) via Fontshare */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,300;1,9..144,400;1,9..144,500&display=swap');
@import url('https://api.fontshare.com/v2/css?f[]=general-sans@400,500,600&display=swap');

/* ---- Tokens ---- */
:root{
  --noir:#121013;
  --noir-2:#181519;
  --ivory:#F5F1EA;
  --champagne:#D9B98A;
  --blush:#E8C4B8;
  --aubergine:#3B2433;
  --stone:#8A8580;

  --dusk:linear-gradient(135deg,#E8C4B8 0%,#D9B98A 45%,#3B2433 100%);
  --hair:rgba(217,185,138,.30);          /* champagne @ 30% hairline */
  --hair-soft:rgba(217,185,138,.16);

  --font-display:'Fraunces',Georgia,serif;
  --font-body:'General Sans','Helvetica Neue',sans-serif;

  --ease:cubic-bezier(0.65,0,0.35,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);

  --mx:clamp(20px,6vw,120px);            /* page side margin */
  --maxw:1680px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  background:var(--noir);
  color:var(--ivory);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.7;
  font-weight:400;
  overflow-x:hidden;
  cursor:none;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:none}
::selection{background:var(--champagne);color:var(--noir)}

/* ---- Type helpers ---- */
.display{font-family:var(--font-display);font-weight:300;line-height:.98;letter-spacing:-.01em}
.italic{font-style:italic}
.serif-accent{color:var(--champagne);font-style:italic}

.meta{
  font-family:var(--font-body);
  font-size:10px;
  font-weight:500;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--stone);
}
.meta-11{font-size:11px}

.eyebrow{
  font-family:var(--font-body);
  font-size:11px;
  font-weight:600;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--champagne);
}

.lede{font-size:clamp(15px,1.05vw,16px);line-height:1.75;color:var(--ivory);max-width:62ch}
.dim{color:var(--stone)}

/* film grain overlay applied to photos */
.grain::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.07;mix-blend-mode:overlay;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* B&W editorial photo treatment */
.bw{filter:grayscale(1) contrast(1.06) brightness(.96)}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--mx)}
section{position:relative}

/* =========================================================================
   CUSTOM CURSOR
   ========================================================================= */
.cursor{
  position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;
  background:var(--champagne);
  transform:translate(-50%,-50%);
  pointer-events:none;z-index:9000;
  transition:width .3s var(--ease),height .3s var(--ease),background .3s var(--ease),opacity .3s;
  will-change:transform;
}
.cursor.is-media{mix-blend-mode:difference;background:#fff;width:64px;height:64px}
.cursor.is-link{width:42px;height:42px;background:transparent;border:1px solid var(--champagne)}
.cursor.is-hidden{opacity:0}
.cursor-dot{
  position:fixed;top:0;left:0;width:4px;height:4px;border-radius:50%;
  background:var(--champagne);transform:translate(-50%,-50%);
  pointer-events:none;z-index:9001;will-change:transform;
}
@media (hover:none){ .cursor,.cursor-dot{display:none} body{cursor:auto} button,a{cursor:pointer} }

/* =========================================================================
   CURTAIN PAGE TRANSITION (atelier drapes)
   ========================================================================= */
.curtain{position:fixed;inset:0;z-index:8000;pointer-events:none;display:flex}
.curtain__panel{flex:1;background:var(--ivory);transform:translateX(0);transition:transform 1.1s cubic-bezier(0.65,0,0.35,1)}
.curtain.no-trans .curtain__panel{transition:none}
.curtain.is-open .curtain__panel--l{transform:translateX(-101%)}
.curtain.is-open .curtain__panel--r{transform:translateX(101%)}
.curtain.nav-dur .curtain__panel{transition-duration:.6s}
/* if JS never runs, never trap the user behind the curtain */
.no-js-open .curtain{display:none}

/* =========================================================================
   NAV
   ========================================================================= */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:7000;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--mx);
  border-bottom:1px solid var(--hair-soft);
  background:rgba(18,16,19,0);
  transition:background .5s var(--ease),border-color .5s var(--ease),padding .5s var(--ease);
  mix-blend-mode:normal;
}
.nav.is-solid{background:rgba(18,16,19,.82);backdrop-filter:blur(14px);border-color:var(--hair-soft);padding-block:16px}
.nav__logo{display:flex;flex-direction:column;gap:5px;line-height:1}
.nav__word{font-family:var(--font-display);font-weight:400;font-size:21px;letter-spacing:.3em;color:var(--ivory)}
.nav__word .accent{
  background:var(--dusk);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.nav__sub{font-size:8px;letter-spacing:.34em;color:var(--stone);text-transform:uppercase}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory);position:relative;padding-block:4px}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--champagne);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav__links a:hover::after,.nav__links a.is-active::after{transform:scaleX(1)}
.nav__links a.is-active{color:var(--champagne)}

.btn-consult{
  font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory);white-space:nowrap;
  border:1px solid var(--champagne);padding:13px 22px;border-radius:1px;
  position:relative;overflow:hidden;background:transparent;transition:color .35s var(--ease);
}
.btn-consult span{position:relative;z-index:2}
.btn-consult::before{content:"";position:absolute;inset:0;background:var(--dusk);transform:translateY(101%);transition:transform .4s var(--ease);z-index:1}
.btn-consult:hover{color:var(--noir)}
.btn-consult:hover::before{transform:translateY(0)}
.btn-consult:focus-visible{outline:2px solid var(--champagne);outline-offset:3px}

/* mobile nav */
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px}
.nav__burger span{display:block;width:24px;height:1px;background:var(--ivory);transition:transform .4s var(--ease),opacity .3s}
.nav__mobile{
  position:fixed;inset:0;z-index:6999;background:var(--noir);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 var(--mx);
  transform:translateY(-100%);transition:transform .6s var(--ease);
}
.nav__mobile.is-open{transform:translateY(0)}
.nav__mobile a{font-family:var(--font-display);font-size:34px;font-weight:300;color:var(--ivory)}
.nav__mobile a .idx{font-family:var(--font-body);font-size:11px;color:var(--stone);margin-right:14px;letter-spacing:.2em}

@media (max-width:920px){
  .nav__links,.nav .btn-consult.desktop-only{display:none}
  .nav__burger{display:flex}
}

/* =========================================================================
   BUTTONS / LINKS
   ========================================================================= */
.btn-outline{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ivory);
  border:1px solid var(--champagne);padding:18px 34px;border-radius:1px;
  position:relative;overflow:hidden;background:transparent;transition:color .35s var(--ease);
}
.btn-outline span{position:relative;z-index:2}
.btn-outline::before{content:"";position:absolute;inset:0;background:var(--dusk);transform:translateY(101%);transition:transform .4s var(--ease);z-index:1}
.btn-outline:hover{color:var(--noir)}
.btn-outline:hover::before{transform:translateY(0)}
.btn-outline:focus-visible{outline:2px solid var(--champagne);outline-offset:3px}

.link-line{
  display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);position:relative;
}
.link-line::after{content:"";position:absolute;left:0;bottom:-5px;width:100%;height:1px;background:var(--champagne);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.link-line:hover::after{transform:scaleX(1)}

/* =========================================================================
   HAIRLINES / DIVIDERS
   ========================================================================= */
.rule{height:1px;width:100%;background:var(--hair)}
.rule-dusk{height:1px;width:100%;background:var(--dusk);opacity:.6}
.draw-rule{height:1px;background:var(--hair);transform:scaleX(0);transform-origin:left}

/* =========================================================================
   LIGHT-REVEAL GALLERY (before/after via dusk light spot)
   ========================================================================= */
.reveal{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--noir-2);isolation:isolate}
.reveal img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reveal__before{z-index:1}
.reveal__after{z-index:2;-webkit-mask-image:radial-gradient(circle var(--r,180px) at var(--x,50%) var(--y,50%),#000 0%,#000 45%,transparent 78%);mask-image:radial-gradient(circle var(--r,180px) at var(--x,50%) var(--y,50%),#000 0%,#000 45%,transparent 78%)}
.reveal__hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;pointer-events:none;transition:opacity .5s}
.reveal__spot{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--champagne);box-shadow:0 0 40px 14px rgba(217,185,138,.5);transform:translate(-50%,-50%);z-index:4;pointer-events:none;opacity:0;transition:opacity .4s}
.reveal.is-active .reveal__hint{opacity:0}
.reveal.is-active .reveal__spot{opacity:1}
.reveal__tag{position:absolute;left:14px;bottom:14px;z-index:5;pointer-events:none}
.reveal__tag .b{color:var(--stone)} .reveal__tag .a{color:var(--champagne)}
/* reduced-motion / no-pointer fallback: simple side-by-side */
.reveal.fallback .reveal__after{-webkit-mask-image:none;mask-image:none;clip-path:inset(0 0 0 50%)}

/* =========================================================================
   POLAROID cursor-follow (procedures index)
   ========================================================================= */
.polaroid{
  position:fixed;top:0;left:0;width:230px;z-index:5000;pointer-events:none;
  opacity:0;transform:translate(-50%,-50%) scale(.9) rotate(0deg);
  transition:opacity .4s var(--ease),transform .5s var(--ease);
  background:var(--ivory);padding:10px 10px 38px;box-shadow:0 30px 60px rgba(0,0,0,.5);
}
.polaroid img{width:100%;aspect-ratio:3/4;object-fit:cover}
.polaroid.is-on{opacity:1}
.polaroid__cap{position:absolute;left:0;bottom:12px;width:100%;text-align:center;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--aubergine)}

.index-list{border-top:1px solid var(--hair)}
.index-row{
  display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:24px;
  padding:clamp(20px,3vw,38px) 4px;border-bottom:1px solid var(--hair);
  position:relative;transition:padding-left .5s var(--ease);
}
.index-row__num{font-family:var(--font-body);font-size:12px;letter-spacing:.2em;color:var(--stone)}
.index-row__name{font-family:var(--font-display);font-weight:300;font-size:clamp(28px,4.4vw,62px);line-height:1;transition:color .4s var(--ease),transform .5s var(--ease)}
.index-row__name .em{font-style:italic}
.index-row__meta{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);text-align:right}
.index-row:hover{padding-left:24px}
.index-row:hover .index-row__name{color:var(--champagne)}
@media (max-width:720px){
  .index-row{grid-template-columns:48px 1fr;gap:14px}
  .index-row__meta{display:none}
}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{background:var(--aubergine);color:var(--ivory);padding-top:clamp(60px,8vw,120px);overflow:hidden;position:relative}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-bottom:60px}
.footer h4{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);margin-bottom:20px;font-weight:600}
.footer a{display:block;font-size:13px;color:var(--ivory);opacity:.78;padding:5px 0;transition:opacity .3s,padding-left .3s var(--ease)}
.footer a:hover{opacity:1;padding-left:6px}
.footer__big{font-family:var(--font-display);font-weight:300;font-size:18vw;line-height:.8;color:transparent;-webkit-text-stroke:1px rgba(245,241,234,.22);text-stroke:1px rgba(245,241,234,.22);letter-spacing:.02em;padding-bottom:.06em;user-select:none}
.footer__base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;padding:28px 0 40px;border-top:1px solid rgba(245,241,234,.14)}
.footer__disc{max-width:64ch;font-size:11px;line-height:1.7;color:rgba(245,241,234,.5)}
@media (max-width:820px){.footer__grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:540px){.footer__grid{grid-template-columns:1fr}}

/* =========================================================================
   SHARED SECTION SCAFFOLDS
   ========================================================================= */
.sec-pad{padding-block:clamp(80px,12vw,200px)}
.sec-label{display:flex;align-items:center;gap:16px;margin-bottom:48px}
.sec-label .n{font-size:10px;letter-spacing:.2em;color:var(--stone)}
.sec-label .t{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--champagne)}
.sec-label .ln{flex:1;height:1px;background:var(--hair)}

/* word-by-word ink-in */
.inkin .w{opacity:.14;transition:opacity .6s var(--ease)}
.inkin .w.lit{opacity:1}

/* generic fade-rise reveal (used sparingly) */
.rise{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rise.in{opacity:1;transform:none}

/* page hero shared */
.phero{position:relative;display:flex;align-items:flex-end;overflow:hidden}
.phero__img{position:absolute;inset:0}
.phero__img img{width:100%;height:100%;object-fit:cover}
.phero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,16,19,.5) 0%,rgba(18,16,19,.15) 40%,rgba(18,16,19,.85) 100%)}
.phero__inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,7vw,110px)}
.phero h1{font-family:var(--font-display);font-weight:300;font-size:clamp(52px,9vw,128px);line-height:.96;letter-spacing:-.01em}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
  .rise{opacity:1;transform:none;transition:none}
  .inkin .w{opacity:1}
}
