/* ============================================================
   ARTILE — one-page site  (intro-reveal + fixed breathing bg)
   ============================================================ */
:root{
  --ink:#0b0a08;
  --ink-2:#13110e;
  --paper:#f5f0e6;
  --paper-dim:#cdc6b7;
  --muted:rgba(245,240,230,.56);
  --faint:rgba(245,240,230,.34);
  --line:rgba(245,240,230,.12);
  --line-strong:rgba(245,240,230,.22);
  --gold:#e7c46a;
  --gold-bright:#f6c81d;
  --rose:#c8788a;
  --font-display:"NY Display",Georgia,"Times New Roman",serif;
  --font-text:"NY Text",Georgia,serif;
  --font-ui:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",system-ui,sans-serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:#000;color:var(--paper);font-family:var(--font-text);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
::selection{background:var(--gold);color:#1a1206}

/* reveals */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.fade{opacity:0;transition:opacity 1.1s var(--ease)}
.fade.in{opacity:1}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}
[data-d="3"]{transition-delay:.24s}[data-d="4"]{transition-delay:.32s}[data-d="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){.reveal,.fade{opacity:1;transform:none}}

/* ============================================================
   FIXED STAGE — breathing painting, assembled from tiles
   ============================================================ */
.stage{position:fixed;inset:0;z-index:0;background:#000;overflow:hidden}
.stage-art{position:absolute;inset:0;will-change:transform;
  animation:breathe 19s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1.02)}50%{transform:scale(1.09)}}
@media (prefers-reduced-motion:reduce){.stage-art{animation:none;transform:scale(1.02)}}
.tiles{position:absolute;inset:0}
.tile{position:absolute;background-repeat:no-repeat;will-change:transform,opacity;backface-visibility:hidden}
.stage-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% 36%,rgba(11,10,8,0) 30%,rgba(11,10,8,.42) 68%,rgba(11,10,8,.86) 100%),
    linear-gradient(to bottom,rgba(11,10,8,.45),rgba(11,10,8,0) 22%,rgba(11,10,8,0) 70%,rgba(11,10,8,.6))}
.stage-grain{position:absolute;inset:0;z-index:3;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:url('assets/grain.png');background-size:140px 140px}

/* ============================================================
   NAV  (logo doubles as the intro hero logo)
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;
  padding:34px clamp(20px,5vw,56px);
  transition:padding .5s var(--ease)}
.nav::before{content:"";position:absolute;left:0;right:0;top:0;height:calc(100% + 70px);z-index:-1;pointer-events:none;
  background:linear-gradient(to bottom,rgba(0,0,0,.85),rgba(0,0,0,.45) 55%,transparent)}
.nav.solid{padding:28px clamp(20px,5vw,56px)}
.nav-inner{width:100%;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px}
.nav-group{display:flex;gap:clamp(18px,2.4vw,40px);align-items:center;opacity:0}
.nav-group.left{justify-content:flex-end}
.nav-group.right{justify-content:flex-start}
.nav-link{font-family:var(--font-display);font-weight:500;font-size:clamp(15px,1.15vw,18px);
  color:var(--paper);opacity:.84;position:relative;padding:4px 2px;transition:opacity .3s var(--ease)}
.nav-link::after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:1px;background:var(--gold);transition:right .4s var(--ease)}
.nav-link:hover{opacity:1}.nav-link:hover::after{right:0}
.nav-wordmark{display:block;justify-self:center}
.nav-wordmark .logo-svg{height:clamp(30px,3.2vw,42px);width:auto;display:block;transform-origin:center top;
  --logo-ty:40vh;--logo-sc:3;
  transform:translateY(var(--logo-ty)) scale(var(--logo-sc));
  filter:drop-shadow(0 14px 30px rgba(0,0,0,.55))}

/* intro subtitle + scroll cue (fixed, fade on scroll) */
.intro{position:fixed;left:0;right:0;z-index:78;top:0;height:100svh;pointer-events:none;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.intro-sub{font-family:var(--font-text);color:var(--paper-dim);font-size:clamp(16px,1.5vw,21px);
  line-height:1.5;max-width:34ch;margin:clamp(230px,34vh,380px) auto 0;text-wrap:pretty;
  text-shadow:0 2px 24px rgba(0,0,0,.6)}
.scrollcue{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);z-index:78;
  font-family:var(--font-ui);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--paper-dim);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue .bar{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);
  animation:cue 2.4s var(--ease) infinite;transform-origin:top}
@keyframes cue{0%,100%{transform:scaleY(.35);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ============================================================
   CONTENT
   ============================================================ */
main{position:relative;z-index:10}
.hero-scroll{height:220vh;position:relative}
.hero-pin{position:sticky;top:0;height:100svh;display:flex;align-items:center;justify-content:center;text-align:center}
.hero-msg{max-width:var(--maxw);padding:0 clamp(20px,5vw,56px);opacity:0}
.hero-msg h1{font-family:var(--font-display);font-weight:800;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(40px,7vw,96px);margin:.3em 0 0;max-width:15ch;margin-inline:auto;text-wrap:balance;
  text-shadow:0 4px 40px rgba(0,0,0,.55)}
.hero-msg h1 em{font-style:italic;font-weight:900;color:var(--gold)}
.hero-msg .hero-sub{font-family:var(--font-text);color:var(--paper-dim);font-size:clamp(16px,1.5vw,21px);
  line-height:1.5;max-width:44ch;margin:1.2em auto 0;text-shadow:0 2px 22px rgba(0,0,0,.6)}
.hero-actions{display:flex;flex-direction:column;align-items:center;gap:13px;margin-top:30px}
.appstore{display:inline-block;transition:transform .4s var(--ease),filter .4s var(--ease)}
.appstore .store-svg{height:54px;width:auto;display:block}
.appstore:hover{transform:translateY(-3px);filter:drop-shadow(0 12px 26px rgba(0,0,0,.5))}
/* ---------- THE APP: 2x2 screenshot grid ---------- */
#shots.panel{background:transparent}
#shots::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 55% at 50% 50%,rgba(11,10,8,.78),rgba(11,10,8,.32) 70%,rgba(11,10,8,0))}
.shots-grid{display:grid;grid-template-columns:repeat(2,auto);justify-content:center;gap:clamp(28px,4.5vw,64px)}
.shots-grid .shot{filter:drop-shadow(0 36px 56px rgba(0,0,0,.55))}
.shots-grid .shot img{height:80svh;max-width:44vw;width:auto;object-fit:contain;display:block}
@media (max-width:560px){.shots-grid{grid-template-columns:1fr;gap:36px}.shots-grid .shot img{max-width:86vw}}

/* solid section base — these scroll up and cover the fixed bg */
.panel{position:relative;background:var(--ink);z-index:10}
.section{padding:clamp(90px,13vh,168px) 0;position:relative}
.h2{font-family:var(--font-display);font-weight:800;line-height:1.02;letter-spacing:-.018em;
  font-size:clamp(34px,5vw,68px);margin:0;max-width:17ch;text-wrap:balance}
.h2 em{font-style:italic;color:var(--gold);font-weight:900}
.lead{font-family:var(--font-text);color:var(--muted);font-size:clamp(16px,1.45vw,20px);
  line-height:1.6;max-width:54ch;margin:24px 0 0;text-wrap:pretty}

/* ---------- RELAX (transparent — breathing bg shows through) ---------- */
.relax{position:relative;z-index:10;text-align:center;
  padding:clamp(120px,22vh,260px) 0;display:flex;align-items:center;justify-content:center}
.relax::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 55% at 50% 50%,rgba(11,10,8,.78),rgba(11,10,8,.32) 70%,rgba(11,10,8,0))}
.relax-inner{max-width:760px;padding:0 clamp(20px,5vw,56px)}
.relax h2{font-family:var(--font-display);font-weight:800;line-height:1.04;letter-spacing:-.02em;
  font-size:clamp(34px,5.4vw,76px);margin:18px 0 0;text-wrap:balance;text-shadow:0 4px 40px rgba(0,0,0,.6)}
.relax h2 em{font-style:italic;color:var(--gold);font-weight:900}
.relax p{font-family:var(--font-text);color:var(--paper-dim);font-size:clamp(17px,1.6vw,22px);
  line-height:1.62;max-width:48ch;margin:26px auto 0;text-wrap:pretty;text-shadow:0 2px 22px rgba(0,0,0,.6)}

/* ---------- COLLECTION (movements + featured artwork) ---------- */
#collection.panel{background:transparent}
#collection .h2,#collection .lead{text-align:center;margin-inline:auto}
#collection .movements{justify-content:center}
#collection .museums{text-align:center}
#collection::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 55% at 50% 50%,rgba(11,10,8,.78),rgba(11,10,8,.32) 70%,rgba(11,10,8,0))}
.coll-grid{display:grid;grid-template-columns:1fr .9fr;gap:clamp(36px,5vw,84px);align-items:center;
  margin-top:clamp(40px,6vh,72px)}
.frame{position:relative;width:min(380px,80vw);aspect-ratio:3974/5014;border-radius:4px;overflow:hidden;
  box-shadow:0 50px 90px -30px rgba(0,0,0,.85),0 0 0 1px rgba(245,240,230,.06);justify-self:center}
.frame img{width:100%;height:100%;object-fit:cover}
.frame-video{aspect-ratio:474/1080;width:min(320px,70vw);border-radius:22px}
.frame-video video{width:100%;height:100%;object-fit:cover;display:block}
.frame-video::after{border-radius:22px;box-shadow:inset 0 0 0 1px rgba(245,240,230,.1)}
.frame::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:4px;
  box-shadow:inset 0 0 0 6px rgba(20,16,10,.55),inset 0 0 70px rgba(0,0,0,.5)}
.frame-cap{font-family:var(--font-ui);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);text-align:center;margin-top:18px}
.movements{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.mv{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(16px,1.5vw,21px);
  color:var(--paper);opacity:.84;border:1px solid var(--line-strong);border-radius:999px;padding:9px 18px;
  transition:border-color .4s var(--ease),color .4s var(--ease)}
.mv:hover{border-color:var(--gold);color:var(--gold)}
.museums{font-family:var(--font-ui);font-size:13px;letter-spacing:.06em;color:var(--muted);margin-top:26px;line-height:1.8}
.museums b{color:var(--gold);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:11px;display:block;margin-bottom:8px}
@media (max-width:880px){.coll-grid{grid-template-columns:1fr;gap:48px}.coll-art{order:-1}}

/* ---------- ACCESSIBILITY ---------- */
.a11y-head{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center}
.a11y-head .h2{margin:0 auto}
.a11y-icon{width:clamp(64px,7vw,88px);height:clamp(64px,7vw,88px);display:block;background:var(--gold);
  -webkit-mask:var(--icon) center/contain no-repeat;mask:var(--icon) center/contain no-repeat}
.a11y-list{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px clamp(36px,6vw,80px);
  max-width:720px;margin:clamp(44px,6vh,72px) auto 0;padding:0}
.a11y-list li{font-family:var(--font-text);font-size:clamp(16px,1.45vw,20px);color:var(--paper);
  display:flex;align-items:center;gap:16px;line-height:1.4}
.a11y-list .sym{width:42px;height:42px;flex:none;background:var(--paper);opacity:.95;
  -webkit-mask:var(--icon) center/contain no-repeat;mask:var(--icon) center/contain no-repeat}
@media (max-width:680px){.a11y-list{grid-template-columns:1fr;max-width:320px}}

/* ============================================================
   FOOTER / FINAL  (transparent — breathing bg returns)
   ============================================================ */
.final{position:relative;z-index:10;text-align:center;padding:clamp(120px,20vh,240px) 0 0}
.final::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(70% 70% at 50% 40%,rgba(11,10,8,.74),rgba(11,10,8,.3) 72%,rgba(11,10,8,0))}
.final h2{font-family:var(--font-display);font-weight:800;line-height:1.0;letter-spacing:-.02em;
  font-size:clamp(36px,6vw,90px);margin:0 auto;max-width:18ch;text-wrap:balance;text-shadow:0 4px 40px rgba(0,0,0,.6)}
.final h2 em{font-style:italic;color:var(--gold);font-weight:900}
.final .hero-actions{margin-top:34px}
.footer{position:relative;z-index:10;margin-top:clamp(90px,14vh,170px);
  background:linear-gradient(to bottom,rgba(11,10,8,.55),var(--ink) 32%);
  border-top:1px solid var(--line);padding:54px 0 48px}
.colophon{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);
  padding-bottom:42px;margin-bottom:34px;border-bottom:1px solid var(--line)}
.note h3{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin:0 0 14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.note p{font-family:var(--font-text);color:var(--paper-dim);font-size:15px;line-height:1.72;margin:0 0 12px;text-wrap:pretty}
.note a{color:var(--gold);border-bottom:1px solid rgba(231,196,106,.4)}
.note a:hover{border-color:var(--gold)}
.note .copy{font-style:italic;color:var(--muted)}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px}
.footer-logo .logo-svg{height:32px;width:auto;display:block;opacity:.92}
.footer-nav{display:flex;flex-wrap:wrap;gap:clamp(16px,2vw,32px)}
.footer-nav a{font-family:var(--font-ui);font-size:14px;color:var(--muted);transition:color .3s var(--ease)}
.footer-nav a:hover{color:var(--paper)}
.footer-legal{width:100%;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:28px;
  font-family:var(--font-ui);font-size:12.5px;color:var(--faint)}
.footer-legal a{color:var(--faint)}.footer-legal a:hover{color:var(--muted)}
@media (max-width:760px){.colophon{grid-template-columns:1fr;gap:34px}}

/* ============================================================
   LEGAL PAGES (privacy)
   ============================================================ */
.legal-body{min-height:100svh;display:flex;flex-direction:column}
.legal-body .nav-group{opacity:1;pointer-events:auto}
.legal-body .nav-wordmark .logo-svg{height:clamp(30px,3.2vw,42px);width:auto;transform:none;filter:none}
.legal-body .footer{width:100%}
.legal{flex:1;width:100%;max-width:680px;margin:0 auto;padding:160px clamp(20px,5vw,56px) 40px;
  font-family:var(--font-text);color:var(--muted);font-size:16.5px;line-height:1.7}
.legal h1{font-family:var(--font-display);font-weight:800;letter-spacing:-.018em;color:var(--paper);
  font-size:clamp(34px,4.6vw,54px);margin:0;text-wrap:balance}
.legal-date{font-family:var(--font-ui);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);margin:14px 0 0}
.legal-intro{color:var(--paper-dim);font-size:clamp(17px,1.5vw,20px);margin:28px 0 0}
.legal h2{font-family:var(--font-display);font-weight:700;color:var(--paper);font-size:clamp(20px,2vw,26px);
  letter-spacing:-.01em;margin:44px 0 0}
.legal p{margin:14px 0 0}
.legal a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.legal strong{color:var(--paper);font-weight:700}
.legal-address{color:var(--faint);line-height:1.8}
.contact-form{margin-top:36px;background:#fff;border-radius:18px;padding:28px 28px 12px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6)}
.contact-form iframe{display:block}
