/* =========================================================
   Data Collection Sheets — design system
   Ink / Teal / Coral · editorial · phone-first
   ========================================================= */
:root{
  --ink:#1d2b38; --ink-2:#243447; --ink-3:#2c3f50;
  --teal:#21B6A8; --teal-d:#1aa093; --coral:#F06A4B; --coral-d:#e25334;
  --paper:#F4F1EC; --paper-2:#ece7df; --white:#ffffff;
  --mist:#EAEEF2; --line:#C9D3DC; --slate:#5E6E7B; --slate-2:#7C8B98; --fog:#9DB0BF;
  --maxw:1200px; --r:16px; --r-lg:24px;
  --shadow:0 1px 2px rgba(20,30,40,.04),0 12px 32px -12px rgba(20,30,40,.18);
  --shadow-lg:0 2px 6px rgba(20,30,40,.05),0 30px 60px -22px rgba(20,30,40,.30);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ff-display:"Space Grotesk",-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --ff-body:"Inter",-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.04;letter-spacing:-.02em;margin:0}
p{margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ---- micro label ---- */
.eyebrow{font-family:var(--ff-display);font-weight:600;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--coral);border-radius:2px}
.eyebrow.on-dark{color:var(--teal)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-display);font-weight:600;
  font-size:15px;padding:14px 22px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s,border-color .25s;line-height:1;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 10px 22px -10px rgba(240,106,75,.7)}
.btn-primary:hover{background:var(--coral-d);transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06);transform:translateY(-2px)}
.btn-dark{background:var(--ink-2);color:#fff}
.btn-dark:hover{background:var(--ink-3);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
@media (prefers-reduced-motion:reduce){.btn:hover{transform:none}}

/* =========== NAV =========== */
.nav{position:sticky;top:0;z-index:60;background:rgba(244,241,236,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-color:var(--line)}
.nav .wrap{display:flex;align-items:center;gap:18px;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--ff-display);font-weight:700;
  letter-spacing:-.02em;font-size:17px;color:var(--ink)}
.brand .tile{width:34px;height:34px;border-radius:0;overflow:visible;flex:0 0 auto}
.nav-links{display:flex;gap:6px;margin-left:auto;align-items:center}
.nav-links a{font-family:var(--ff-display);font-weight:500;font-size:14.5px;color:var(--slate);
  padding:9px 13px;border-radius:9px;transition:color .2s,background .2s}
.nav-links a:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.nav-cta{margin-left:4px}
.nav-mute{background:none;border:1px solid var(--line);border-radius:9px;width:38px;height:38px;
  display:grid;place-items:center;cursor:pointer;color:var(--slate);transition:.2s}
.nav-mute:hover{color:var(--ink);border-color:var(--slate-2)}
.nav-toggle{display:none}
@media(max-width:900px){
  .nav-links{position:fixed;inset:68px 0 auto 0;flex-direction:column;background:var(--paper);
    border-bottom:1px solid var(--line);padding:14px 24px 22px;gap:2px;transform:translateY(-120%);
    transition:transform .35s var(--ease);margin-left:0;box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%;padding:13px 8px;font-size:16px;border-bottom:1px solid var(--mist)}
  .nav-cta{margin:10px 0 0}
  .nav-mute{margin-left:auto}
  .nav-toggle{display:grid;place-items:center;margin-left:auto;width:42px;height:42px;border:1px solid var(--line);
    background:none;border-radius:10px;cursor:pointer}
  .nav-toggle span{width:18px;height:2px;background:var(--ink);position:relative;transition:.25s}
  .nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);transition:.25s}
  .nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
  .nav-toggle.open span{background:transparent}
  .nav-toggle.open span::before{top:0;transform:rotate(45deg)}
  .nav-toggle.open span::after{top:0;transform:rotate(-45deg)}
}

/* =========== HERO =========== */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero-grid-bg{position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 78%);
  animation:drift 28s linear infinite}
@keyframes drift{from{background-position:0 0}to{background-position:46px 46px}}
.hero-glow{position:absolute;width:680px;height:680px;right:-160px;top:-220px;border-radius:50%;
  background:radial-gradient(circle,rgba(33,182,168,.30),transparent 62%);filter:blur(8px);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;
  padding:84px 24px 92px;z-index:2}
.hero h1{font-size:clamp(40px,7vw,76px);letter-spacing:-.035em}
.hero h1 .teal{color:var(--teal)}
.hero-lead{color:#c4d2dc;font-size:clamp(16px,2.1vw,19px);max-width:34ch;margin:22px 0 30px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.hero-meta{margin-top:34px;display:flex;gap:26px;flex-wrap:wrap;color:var(--fog);font-size:13.5px}
.hero-meta b{color:#fff;font-family:var(--ff-display);font-size:21px;display:block;letter-spacing:-.02em}
/* hero collage */
.collage{position:relative;height:430px}
.collage .card{position:absolute;border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.collage .c-site{width:74%;right:0;top:18px;aspect-ratio:16/10;background:#0e1820}
.collage .c-book{width:34%;left:0;top:90px;aspect-ratio:17/22;background:#fff;transform:rotate(-7deg)}
.collage .c-sheet{width:40%;left:14%;bottom:-6px;aspect-ratio:17/22;background:#fff;transform:rotate(5deg);z-index:3}
.collage .tag{position:absolute;z-index:5;font-family:var(--ff-display);font-weight:600;font-size:11px;
  letter-spacing:.04em;background:#fff;color:var(--ink);padding:6px 11px;border-radius:999px;box-shadow:var(--shadow)}
.collage .tag.t1{top:6px;right:18%}.collage .tag.t2{bottom:14%;left:-4px}
.collage .float{animation:float 7s ease-in-out infinite}
.collage .float.d{animation-delay:-3.5s}
@keyframes float{0%,100%{transform:translateY(0) rotate(var(--rot,0))}50%{transform:translateY(-12px) rotate(var(--rot,0))}}
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;padding:62px 24px 70px}
  .collage{height:340px;max-width:440px;margin:0 auto;width:100%}
}
@media(prefers-reduced-motion:reduce){.hero-grid-bg,.collage .float{animation:none}}

/* =========== SECTIONS =========== */
.section{padding:96px 0}
.section.tight{padding:72px 0}
.section-dark{background:var(--ink);color:#fff}
.section-paper2{background:var(--paper-2)}
.sec-head{max-width:660px;margin-bottom:46px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(28px,4.4vw,44px);margin:16px 0 14px}
.sec-head p{color:var(--slate);font-size:17px}
.section-dark .sec-head p{color:#aebecb}
.sec-head .teal{color:var(--teal)}
.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:42px;flex-wrap:wrap}
.head-row .sec-head{margin-bottom:0}
.link-more{font-family:var(--ff-display);font-weight:600;font-size:14.5px;color:var(--ink);display:inline-flex;
  gap:7px;align-items:center;padding-bottom:3px;border-bottom:2px solid var(--coral);transition:gap .2s}
.section-dark .link-more{color:#fff}
.link-more:hover{gap:12px}

/* ---- trust strip ---- */
.trust{background:var(--ink-2);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;gap:14px 50px;padding:26px 24px;align-items:center;justify-content:center}
.trust .item{display:flex;align-items:baseline;gap:10px;font-size:14px;color:var(--fog)}
.trust .item b{font-family:var(--ff-display);font-size:24px;color:#fff;letter-spacing:-.02em}
.trust .item .tl{color:var(--teal);font-weight:700}
.trust .dot{width:5px;height:5px;border-radius:50%;background:var(--slate-2)}
@media(max-width:680px){.trust .wrap{gap:12px 26px}.trust .item b{font-size:20px}}

/* =========== WORK / PORTFOLIO =========== */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.work-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--mist);transition:transform .4s var(--ease),box-shadow .4s;display:flex;flex-direction:column}
.work-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.work-shot{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--ink)}
.work-shot img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .7s var(--ease)}
.work-card:hover .work-shot img{transform:scale(1.04)}
.work-live{position:absolute;top:14px;left:14px;background:rgba(29,43,56,.78);color:#fff;backdrop-filter:blur(6px);
  font-family:var(--ff-display);font-weight:600;font-size:11px;letter-spacing:.05em;text-transform:uppercase;
  padding:6px 11px;border-radius:999px;display:flex;align-items:center;gap:7px}
.work-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(33,182,168,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(33,182,168,.55)}70%{box-shadow:0 0 0 8px rgba(33,182,168,0)}100%{box-shadow:0 0 0 0 rgba(33,182,168,0)}}
.work-body{padding:20px 22px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.work-body h3{font-size:20px}
.work-body .meta{color:var(--slate);font-size:13.5px;margin-top:4px}
.work-arrow{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:.3s}
.work-card:hover .work-arrow{background:var(--coral);border-color:var(--coral);color:#fff;transform:rotate(-45deg)}
.work-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.work-chip{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--mist);border-radius:999px;
  padding:9px 16px 9px 11px;font-family:var(--ff-display);font-weight:600;font-size:13.5px;box-shadow:var(--shadow);transition:.25s}
.work-chip:hover{transform:translateY(-3px);border-color:var(--line)}
.work-chip .pin{width:24px;height:24px;border-radius:7px;background:var(--ink-2);color:var(--teal);display:grid;place-items:center;font-size:11px}
.work-chip small{color:var(--slate-2);font-weight:500}
@media(max-width:760px){.work-grid{grid-template-columns:1fr}}

/* Not yet live — no destination, so don't invite a click */
.work-card.no-link,.work-chip.no-link{cursor:default}
.work-card.no-link:hover{transform:none;box-shadow:var(--shadow)}
.work-card.no-link:hover .work-shot img{transform:none}
.work-card.no-link .work-arrow{display:none}
.work-chip.no-link:hover{transform:none;border-color:var(--mist)}

/* =========== PRODUCT CARDS (sheets) =========== */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.pcard{background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid var(--mist);box-shadow:var(--shadow);
  transition:transform .35s var(--ease),box-shadow .35s;display:flex;flex-direction:column;position:relative}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.pcard .thumb{aspect-ratio:1/1;overflow:hidden;background:var(--paper-2);position:relative}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .thumb img{transform:scale(1.05)}
.pcard .cat{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.94);color:var(--ink-2);
  font-family:var(--ff-display);font-weight:600;font-size:10.5px;letter-spacing:.03em;padding:5px 9px;border-radius:7px}
.pcard .pbody{padding:15px 16px 17px;flex:1;display:flex;flex-direction:column;gap:5px}
.pcard .pbody h3{font-size:15.5px;letter-spacing:-.01em;line-height:1.18}
.pcard .pbody p{color:var(--slate);font-size:12.8px;line-height:1.45}
.pcard .pfoot{margin-top:auto;padding-top:11px;display:flex;align-items:center;gap:7px;color:var(--teal-d);
  font-family:var(--ff-display);font-weight:600;font-size:12px}
.pcard .pfoot .fmt{margin-left:auto;color:var(--slate-2);font-weight:500;font-size:11px}
@media(max-width:980px){.cards,.cards.c3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:430px){.cards,.cards.c3{grid-template-columns:1fr 1fr;gap:13px}.pcard .pbody h3{font-size:14px}}

/* category filter chips */
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:34px}
.filters button{font-family:var(--ff-display);font-weight:600;font-size:13px;padding:9px 15px;border-radius:999px;
  border:1px solid var(--line);background:#fff;color:var(--slate);cursor:pointer;transition:.2s}
.filters button:hover{border-color:var(--slate-2);color:var(--ink)}
.filters button.active{background:var(--ink-2);color:#fff;border-color:var(--ink-2)}

/* =========== EBOOK SHELF =========== */
.books{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.book{display:flex;flex-direction:column;gap:13px;transition:transform .35s var(--ease)}
.book:hover{transform:translateY(-6px)}
.book .cov{aspect-ratio:17/22;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);background:var(--paper-2);
  position:relative;border:1px solid rgba(0,0,0,.05)}
.book .cov img{width:100%;height:100%;object-fit:cover}
.book .cov::after{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:linear-gradient(90deg,rgba(0,0,0,.18),transparent)}
.book h3{font-size:15.5px;line-height:1.2}
.book p{color:var(--slate);font-size:12.6px;line-height:1.45}
.section-dark .book p{color:#9fb0bd}
.book .pages{font-family:var(--ff-display);font-size:11px;font-weight:600;color:var(--teal);letter-spacing:.04em;text-transform:uppercase}
@media(max-width:980px){.books{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.books{grid-template-columns:repeat(2,1fr);gap:18px}}

/* =========== ABOUT =========== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-grid .lead{font-family:var(--ff-display);font-weight:500;font-size:clamp(20px,2.6vw,27px);line-height:1.32;letter-spacing:-.02em}
.about-grid .lead .teal{color:var(--teal)}
.about-grid p+p{margin-top:16px}
.about-grid .body{color:var(--slate);font-size:15.5px}
.pillars{display:grid;gap:14px}
.pillar{display:flex;gap:16px;background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow)}
.pillar .ic{flex:0 0 46px;height:46px;border-radius:12px;background:var(--ink-2);color:var(--teal);display:grid;place-items:center}
.pillar .ic svg{width:22px;height:22px}
.pillar h4{font-size:16.5px;margin-bottom:3px}
.pillar p{color:var(--slate);font-size:13.6px}

/* =========== FAQ =========== */
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:8px}
.faq-item{background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow)}
.faq-item h4{font-size:16.5px;margin-bottom:7px}
.faq-item p{color:var(--slate);font-size:14px;line-height:1.55}
@media(max-width:760px){.faq-grid{grid-template-columns:1fr}}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:34px}}

/* =========== CONTACT =========== */
.contact{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.contact .hero-grid-bg{opacity:.7}
.contact .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:54px;padding:92px 24px}
.contact h2{font-size:clamp(30px,4.6vw,48px)}
.contact .teal{color:var(--teal)}
.contact .clead{color:#bccad4;font-size:17px;margin:18px 0 28px;max-width:40ch}
.cmethods{display:flex;flex-direction:column;gap:12px}
.cmethod{display:flex;align-items:center;gap:15px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:16px 18px;transition:.25s}
.cmethod:hover{background:rgba(255,255,255,.09);transform:translateX(4px)}
.cmethod .ic{width:44px;height:44px;border-radius:11px;background:var(--coral);display:grid;place-items:center;flex:0 0 auto}
.cmethod .ic svg{width:20px;height:20px;color:#fff}
.cmethod .lbl{font-size:12px;color:var(--fog);letter-spacing:.04em;text-transform:uppercase;font-family:var(--ff-display);font-weight:600}
.cmethod .val{font-family:var(--ff-display);font-weight:600;font-size:18px;color:#fff;margin-top:2px}
/* intents card */
.intent-card{background:#fff;color:var(--ink);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-lg)}
.intent-card h3{font-size:21px;margin-bottom:6px}
.intent-card .sub{color:var(--slate);font-size:14px;margin-bottom:20px}
.intents{display:grid;gap:11px;margin-bottom:22px}
.intent{display:flex;align-items:center;gap:14px;border:1.5px solid var(--mist);border-radius:13px;padding:14px 16px;cursor:pointer;transition:.2s;text-align:left;background:#fff;width:100%;font-family:var(--ff-body)}
.intent:hover{border-color:var(--teal);background:#f7fdfc}
.intent.sel{border-color:var(--teal);background:#f2fbfa;box-shadow:0 0 0 3px rgba(33,182,168,.12)}
.intent .ic{width:38px;height:38px;border-radius:10px;background:var(--paper-2);display:grid;place-items:center;flex:0 0 auto}
.intent.sel .ic{background:var(--teal);color:#fff}
.intent .ic svg{width:18px;height:18px}
.intent b{font-family:var(--ff-display);font-size:14.5px;display:block}
.intent small{color:var(--slate);font-size:12px}
.intent-card .btn{width:100%;justify-content:center}
.fineprint{color:var(--slate-2);font-size:12px;text-align:center;margin-top:13px}

/* lead-capture form (intent-card as a <form>) */
.lead-form .field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lead-form .field{margin-bottom:14px}
.lead-form label{display:block;font-family:var(--ff-display);font-weight:600;font-size:11.5px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--slate-2);margin-bottom:6px}
.lead-form input,.lead-form textarea{width:100%;font-family:var(--ff-body);font-size:15px;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--mist);border-radius:11px;padding:12px 14px;
  transition:border-color .2s,box-shadow .2s}
.lead-form input:focus,.lead-form textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(33,182,168,.14)}
.lead-form textarea{resize:vertical;min-height:96px;font-family:var(--ff-body)}
.lead-form .status{margin-top:12px;font-size:13px;color:var(--teal-d);font-weight:600;display:none}
.lead-form .status.show{display:block}
.lead-form .status.error{color:var(--coral-d)}
@media(max-width:520px){.lead-form .field-row{grid-template-columns:1fr}}
@media(max-width:860px){.contact .wrap{grid-template-columns:1fr;gap:36px;padding:64px 24px}}

/* =========== FOOTER =========== */
.foot{background:#16222d;color:#aebecb;padding:54px 0 30px}
.foot .top{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot .brand{color:#fff}
.foot .tag{max-width:30ch;font-size:13.5px;margin-top:14px;color:#8ea0ae}
.foot nav{display:flex;gap:50px;flex-wrap:wrap}
.foot h5{font-family:var(--ff-display);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--fog);margin:0 0 14px}
.foot a{display:block;color:#aebecb;font-size:14px;padding:5px 0;transition:.2s}
.foot a:hover{color:#fff}
.foot .bot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:22px;font-size:12.5px;color:#7c8b98}
.foot .bot .teal{color:var(--teal)}

/* =========== reveal animation (fail-safe: only hides when JS is active) =========== */
html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}

/* =========== PIP MASCOT =========== */
#pip{position:fixed;right:22px;bottom:22px;z-index:80;width:96px;height:96px;cursor:pointer;
  -webkit-tap-highlight-color:transparent;transition:transform .4s var(--ease),opacity .3s}
#pip.hidden{opacity:0;transform:translateY(20px) scale(.8);pointer-events:none}
#pip .body{animation:bob 4.5s ease-in-out infinite;transform-origin:50% 90%}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
#pip:hover .body{animation-duration:2.2s}
.pip-eye{transform-origin:center;animation:blink 5.5s infinite}
@keyframes blink{0%,94%,100%{transform:scaleY(1)}97%{transform:scaleY(.12)}}
.pip-ant{transform-origin:bottom;animation:sway 4s ease-in-out infinite}
@keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
.pip-dot{animation:dotpulse 2.2s ease-in-out infinite}
@keyframes dotpulse{0%,100%{opacity:.55;r:4.4}50%{opacity:1;r:5.4}}
#pip-bubble{position:fixed;right:30px;bottom:120px;z-index:80;max-width:240px;background:#fff;color:var(--ink);
  border-radius:16px;padding:13px 16px;box-shadow:var(--shadow-lg);border:1px solid var(--mist);
  font-size:14px;line-height:1.4;opacity:0;transform:translateY(8px) scale(.96);transform-origin:bottom right;
  transition:opacity .3s var(--ease),transform .3s var(--ease);pointer-events:none}
#pip-bubble.show{opacity:1;transform:none}
#pip-bubble::after{content:"";position:absolute;right:26px;bottom:-7px;width:14px;height:14px;background:#fff;
  border-right:1px solid var(--mist);border-bottom:1px solid var(--mist);transform:rotate(45deg)}
#pip-bubble .pname{font-family:var(--ff-display);font-weight:700;font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--teal);display:block;margin-bottom:3px}
#pip-bubble .pip-mute{position:absolute;top:8px;right:10px;font-size:10px;color:var(--slate-2);
  font-family:var(--ff-display);font-weight:600;cursor:pointer;letter-spacing:.04em;background:none;border:none}
#pip-bubble .pip-mute:hover{color:var(--ink)}
@media(prefers-reduced-motion:reduce){
  #pip .body,.pip-eye,.pip-ant,.pip-dot{animation:none}
  #pip-bubble{transition:opacity .2s}
}
@media(max-width:640px){
  #pip{width:68px;height:68px;right:14px;bottom:14px}
  #pip-bubble{right:18px;bottom:90px;max-width:200px;font-size:13px}
}

/* =========================================================
   REVAMP v2 — "the site is itself a data collection sheet"
   Signature layer: self-ticking intake form, tally counters,
   browser-framed work, 3D bookshelf, Pip everywhere, grain.
   ========================================================= */

/* ---- paper grain (whole site, very subtle) ---- */
body::after{content:"";position:fixed;inset:0;z-index:3000;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}

/* ---- scroll progress: a form being completed ---- */
#progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;pointer-events:none}
#progress b{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--coral));transition:width .08s linear}

/* ---- custom cursor ring (desktop pointers only) ---- */
#cursor-ring{position:fixed;left:0;top:0;width:34px;height:34px;border:1.5px solid rgba(33,182,168,.8);border-radius:50%;
  pointer-events:none;z-index:9990;transform:translate(-50%,-50%);display:none;align-items:center;justify-content:center;
  transition:width .25s var(--ease),height .25s var(--ease),background .25s,border-color .25s,opacity .3s}
@media(hover:hover) and (pointer:fine){#cursor-ring{display:flex}}
@media(prefers-reduced-motion:reduce){#cursor-ring{display:none}}

/* ---- selection + focus flavour ---- */
::selection{background:var(--teal);color:#fff}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:4px}

/* =========== HERO v2 =========== */
@media(min-width:901px){.hero .wrap{grid-template-columns:1.04fr .96fr;gap:48px;padding:76px 24px 78px}}
.hero h1{font-size:clamp(42px,7.4vw,84px)}
.hero h1 .strike{position:relative;white-space:nowrap}
.hero h1 .strike::after{content:"";position:absolute;left:-2%;right:-3%;top:54%;height:.09em;background:var(--coral);
  border-radius:99px;transform:rotate(-1.6deg) scaleX(0);transform-origin:left center;transition:transform .7s var(--ease) 1s}
html.hero-in .hero h1 .strike::after{transform:rotate(-1.6deg) scaleX(1)}
.hero-scroll{margin-top:42px;display:inline-flex;align-items:center;gap:12px;color:var(--fog);
  font-family:var(--ff-display);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.hero-scroll .ln{position:relative;width:52px;height:1px;background:rgba(255,255,255,.18);overflow:hidden}
.hero-scroll .ln::after{content:"";position:absolute;left:0;top:0;width:18px;height:100%;background:var(--teal);animation:lnrun 2.2s var(--ease) infinite}
@keyframes lnrun{0%{transform:translateX(-20px)}100%{transform:translateX(56px)}}

/* collage v2 — layered scene with Pip */
.collage2{height:480px}
.collage2 .cl{position:absolute;inset:0;pointer-events:none;transition:transform .35s ease-out}
.collage2 .card{position:absolute;border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.collage2 .c-site{width:78%;right:0;top:0;background:#0e1820}
.collage2 .c-site img{width:100%;display:block}
.collage2 .c-sheet{width:37%;left:1%;bottom:6%;aspect-ratio:17/21;background:#fff;transform:rotate(-6deg)}
.collage2 .c-book{width:29%;right:5%;bottom:0;aspect-ratio:17/22;background:#fff;transform:rotate(5deg)}
.collage2 .c-pip{position:absolute;width:33%;left:29%;bottom:-2%;filter:drop-shadow(0 22px 28px rgba(8,16,24,.45))}
.collage2 .c-check{position:absolute;width:47%;left:-3%;top:5%;background:#fff;border-radius:14px;padding:14px 16px 12px;
  box-shadow:var(--shadow-lg);color:var(--ink)}
.c-check b{display:block;font-family:var(--ff-display);font-weight:700;font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--slate);padding-bottom:8px;margin-bottom:6px;border-bottom:1.5px dashed var(--line)}
.c-check .chk{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:13px;font-weight:500}
.c-check .chk i{width:17px;height:17px;flex:0 0 auto;border:1.5px solid var(--line);border-radius:5px;position:relative;
  transition:background .3s,border-color .3s;background:#fff}
.c-check .chk i::after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid #fff;border-width:0 2.2px 2.2px 0;
  transform:rotate(45deg) scale(0);transition:transform .25s cubic-bezier(.3,1.6,.4,1) .05s}
.c-check .chk.done i{background:var(--teal);border-color:var(--teal)}
.c-check .chk.done i::after{transform:rotate(45deg) scale(1)}
/* browser chrome frame */
.bbar{height:32px;background:#0b141c;display:flex;align-items:center;gap:5px;padding:0 12px;border-bottom:1px solid rgba(255,255,255,.06)}
.bbar i{width:8px;height:8px;border-radius:50%;background:#2c3f50}
.bbar i:nth-child(1){background:#f06a4b}.bbar i:nth-child(2){background:#e8b04b}.bbar i:nth-child(3){background:#21b6a8}
.bbar .url{margin-left:8px;flex:1;min-width:0;background:rgba(255,255,255,.07);color:#8ea0ae;font:500 10.5px/1 var(--ff-body);
  padding:5px 10px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bbar .blive{flex:0 0 auto;display:flex;align-items:center;gap:5px;color:#fff;font:600 9.5px/1 var(--ff-display);letter-spacing:.08em;text-transform:uppercase}
.bbar .blive::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(33,182,168,.6);animation:pulse 2.4s infinite}

/* ---- ticker (hero bottom marquee) ---- */
.ticker{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.08);overflow:hidden;padding:15px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.ticker-track{display:flex;width:max-content;animation:tick 60s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker-track .tk{display:flex;align-items:center;gap:34px;padding-right:34px;color:#7d92a2;
  font-family:var(--ff-display);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}
.ticker-track .tk em{font-style:normal;color:#a8bccb}
.ticker-track .tk i{width:6px;height:6px;border-radius:50%;background:var(--coral);flex:0 0 auto;opacity:.8}
@keyframes tick{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}.hero-scroll .ln::after{animation:none}}

/* =========== TALLY STRIP v2 =========== */
.trust .wrap{gap:14px 44px;padding:30px 24px}
.tally{width:36px;height:26px;flex:0 0 auto;overflow:visible}
.tally path{stroke:var(--teal);stroke-width:2.6;stroke-linecap:round;fill:none;opacity:.85}
.tally .t5{stroke:var(--coral)}
html.js .tally path{stroke-dasharray:40;stroke-dashoffset:40;transition:stroke-dashoffset .5s var(--ease)}
html.js .trust.in .tally path{stroke-dashoffset:0}
html.js .trust.in .tally path:nth-child(2){transition-delay:.12s}
html.js .trust.in .tally path:nth-child(3){transition-delay:.24s}
html.js .trust.in .tally path:nth-child(4){transition-delay:.36s}
html.js .trust.in .tally .t5{transition-delay:.55s;transition-duration:.4s}
@media(prefers-reduced-motion:reduce){html.js .tally path{stroke-dasharray:none;stroke-dashoffset:0}}
@media(max-width:680px){.tally{display:none}}

/* =========== SECTION INDEX NUMBERS =========== */
.section{position:relative;overflow:hidden}
.idx{position:absolute;top:26px;right:18px;z-index:0;pointer-events:none;user-select:none;
  font-family:var(--ff-display);font-weight:700;font-size:clamp(96px,15vw,190px);line-height:.8;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1.5px rgba(36,52,71,.14)}
.section-dark .idx,.contact .idx{-webkit-text-stroke:1.5px rgba(255,255,255,.10)}
.section .wrap{position:relative;z-index:1}
@media(max-width:680px){.idx{font-size:96px;top:14px;right:10px;-webkit-text-stroke-width:1px}}

/* =========== WORK CARDS v2 (browser frames) =========== */
.work-shot{aspect-ratio:auto;background:#0b141c}
.work-shot .shot-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.work-shot .shot-img img{width:100%;height:100%;object-fit:cover;object-position:top center;
  transition:object-position 2.6s var(--ease),transform .7s var(--ease)}
.work-card:hover .shot-img img{object-position:bottom center;transform:none}
.work-card:hover .work-shot img{transform:none}

/* =========== SHEET CARDS v2 (paper stack + receipt foot) =========== */
.pcard{overflow:visible;z-index:0}
.pcard .thumb{border-radius:var(--r) var(--r) 0 0}
.pcard::before,.pcard::after{content:"";position:absolute;left:7px;right:7px;bottom:-5px;height:14px;background:#fdfcfa;
  border:1px solid var(--mist);border-radius:0 0 13px 13px;z-index:-1;transition:transform .35s var(--ease)}
.pcard::after{left:14px;right:14px;bottom:-9px;z-index:-2;background:#f7f4ef}
.pcard:hover{transform:translateY(-6px) rotate(-.5deg)}
.pcard:hover::before{transform:translateY(3px)}
.pcard:hover::after{transform:translateY(6px)}
.pcard .pfoot{border-top:1.5px dashed var(--line);padding-top:11px}
.pcard .pfoot svg{width:14px;height:14px;flex:0 0 auto}
.work-chip .pin svg{width:12px;height:12px}

/* =========== EBOOK SHELF v2 (3D) =========== */
.books{perspective:1500px}
.book .cov{transition:transform .55s var(--ease),box-shadow .55s;transform-style:preserve-3d}
.book:hover .cov{transform:rotateY(-15deg) translateY(-4px);box-shadow:18px 30px 50px -18px rgba(10,20,30,.5)}
.book .cov::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.14) 48%,transparent 58%);
  transform:translateX(-120%);transition:transform .8s var(--ease)}
.book:hover .cov::before{transform:translateX(120%)}
@media(prefers-reduced-motion:reduce){.book:hover .cov{transform:none}.book .cov::before{display:none}}

/* =========== PIP PEEK (section edge cameo) =========== */
.peek{position:absolute;top:-58px;right:7%;width:96px;z-index:2;pointer-events:none}
.peek img{width:100%;transform:rotate(7deg);filter:drop-shadow(0 10px 14px rgba(8,16,24,.35))}
html.js .peek{opacity:0;transform:translateY(46px);transition:opacity .7s var(--ease) .1s,transform .7s var(--ease) .1s}
html.js .peek.in{opacity:1;transform:none}
@media(max-width:680px){.peek{width:64px;top:-40px;right:5%}}

/* footer pip */
.foot-pip{display:inline-block;width:22px;height:auto;vertical-align:-6px;margin-left:2px}

/* staggered reveals inside grids */
html.js .work-grid .work-card:nth-child(2){transition-delay:.08s}
html.js .cards .pcard:nth-child(2),html.js .books .book:nth-child(2){transition-delay:.05s}
html.js .cards .pcard:nth-child(3),html.js .books .book:nth-child(3){transition-delay:.1s}
html.js .cards .pcard:nth-child(4),html.js .books .book:nth-child(4){transition-delay:.15s}
html.js .cards .pcard:nth-child(6),html.js .books .book:nth-child(6){transition-delay:.05s}
html.js .cards .pcard:nth-child(7),html.js .books .book:nth-child(7){transition-delay:.1s}
html.js .cards .pcard:nth-child(8),html.js .books .book:nth-child(8){transition-delay:.15s}

/* =========== HERO v2 — phone =========== */
@media(max-width:900px){
  .hero .wrap{gap:40px;padding:56px 24px 64px}
  .collage2{height:390px;max-width:460px}
  .collage2 .c-check{width:52%}
  .c-check .chk{font-size:12px}
  .hero-scroll{display:none}
}
@media(max-width:430px){
  .collage2{height:330px}
  .c-check b{font-size:9.5px}
}
.bbar .blive.shipped::before{animation:none;background:var(--fog)}

/* ---- v2.1 fixes: collage composition, cursor ring, spacing ---- */
#cursor-ring{opacity:0}
.collage2{height:500px}
.collage2 .c-site{width:72%;right:0;top:0;z-index:1}
.collage2 .c-check{width:44%;left:-1%;top:4%;z-index:6}
.collage2 .c-sheet{width:34%;left:3%;bottom:5%;z-index:3;transform:rotate(-5deg)}
.collage2 .c-book{width:25%;right:3%;bottom:0;z-index:3;transform:rotate(4deg)}
.collage2 .c-pip{width:31%;left:36%;bottom:-2%;z-index:5;animation:pipbob 5s ease-in-out infinite}
@keyframes pipbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-scroll{margin-top:32px}
@media(prefers-reduced-motion:reduce){.collage2 .c-pip{animation:none}}
@media(max-width:900px){
  .collage2{height:400px;max-width:470px;margin:0 auto;width:100%}
  .collage2 .c-site{width:82%}
  .collage2 .c-check{width:50%;top:34%;left:-1%}
  .collage2 .c-sheet{display:none}
  .collage2 .c-book{width:27%;right:1%;bottom:2%}
  .collage2 .c-pip{width:36%;left:30%;bottom:-1%}
}
@media(max-width:430px){.collage2{height:340px}}

/* ---- v2.2: kill v1 positional inheritance on collage pieces ---- */
.collage2 .c-site{aspect-ratio:auto;top:0;right:0;left:auto;bottom:auto}
.collage2 .c-book{left:auto;top:auto;right:2%;bottom:0}
.collage2 .c-sheet{top:auto;right:auto}
.collage2 .c-pip{height:auto}

/* crop baked-in mockup chrome on promo-style shots so our frame is the only frame */
.shot-img.reframe img{transform:translateY(-6.5%) scale(1.07);transform-origin:50% 100%}
.work-card:hover .shot-img.reframe img{transform:translateY(-6.5%) scale(1.07)}
/* let Pip actually peek over the ebooks section edge */
#ebooks{overflow:visible}

/* ---- v2.3: process section, photo grid, hours block, sub-page hero ---- */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:8px}
.process-step .pnum{font-family:var(--ff-display);font-weight:700;font-size:13px;letter-spacing:.06em;
  color:var(--coral);margin-bottom:14px;display:block}
.process-step .pshot{border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;margin-bottom:18px;box-shadow:var(--shadow)}
.process-step .pshot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.process-step:hover .pshot img{transform:scale(1.045)}
.process-step h4{font-size:19px;margin-bottom:8px}
.process-step p{color:var(--slate);font-size:14.5px;line-height:1.6}
@media(max-width:860px){.process-grid{grid-template-columns:1fr;gap:36px}}

.about-photos{margin-top:28px;display:grid;grid-template-columns:1.3fr 1fr;gap:14px}
.about-photos .big{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/11}
.about-photos .small{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/4}
.about-photos img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width