/* ============================================================
   HAIR MASTERS — BRAND HUB  ·  Digidzire pitch microsite
   Theme system + components
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

/* ---------- THEME TOKENS ---------- */
[data-theme="noir"]{
  --bg:#1C0A0F; --bg-2:#240D13;
  --surface:#2A1018; --surface-2:#341622;
  --ink:#F5E8ED; --ink-soft:rgba(245,232,237,.62); --ink-faint:rgba(245,232,237,.32);
  --accent:#E8A0B4; --accent-2:#D4956A; --on-accent:#1C0A0F;
  --accent-wash:rgba(232,160,180,.10);
  --hairline:rgba(232,160,180,.16);
  --deep:#120609; --on-deep:#F5E8ED;
  --watermark:rgba(232,160,180,.05);
}
[data-theme="emerald"]{
  --bg:#F7F4EF; --bg-2:#F1ECE3;
  --surface:#FFFFFF; --surface-2:#EEE9E1;
  --ink:#1A3530; --ink-soft:rgba(26,53,48,.66); --ink-faint:rgba(26,53,48,.4);
  --accent:#2D5A4A; --accent-2:#B8860B; --on-accent:#F7F4EF;
  --accent-wash:rgba(45,90,74,.07);
  --hairline:rgba(45,90,74,.16);
  --deep:#1A3530; --on-deep:#DCEAE4;
  --watermark:rgba(45,90,74,.05);
}
[data-theme="blush"]{
  --bg:#FAF6F4; --bg-2:#F4EEEB;
  --surface:#FFFFFF; --surface-2:#F2ECE9;
  --ink:#3A2A28; --ink-soft:rgba(58,42,40,.66); --ink-faint:rgba(58,42,40,.4);
  --accent:#9B6E6E; --accent-2:#8A7560; --on-accent:#FAF6F4;
  --accent-wash:rgba(155,110,110,.08);
  --hairline:rgba(155,110,110,.18);
  --deep:#3A2A28; --on-deep:#EBD9D2;
  --watermark:rgba(155,110,110,.05);
}

body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased;
  transition:background .5s ease,color .5s ease;
  line-height:1.6;
}

/* ---------- TYPOGRAPHY HELPERS ---------- */
.serif{font-family:'Cormorant Garamond',serif}
.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:500}
.eyebrow .num{color:var(--ink-faint);margin-right:.6em}
.display{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:1.06;letter-spacing:.5px}
.display em{font-style:italic;color:var(--accent)}
.lede{font-size:clamp(15px,1.4vw,18px);color:var(--ink-soft);max-width:60ch;line-height:1.75}
.rule{width:54px;height:1px;background:var(--accent);opacity:.7}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:0 clamp(20px,5vw,56px)}
section{padding:clamp(64px,9vh,120px) 0;position:relative}
.sec-head{margin-bottom:48px}
.sec-head .display{font-size:clamp(34px,5vw,60px);margin:18px 0 14px}
.band{background:var(--deep);color:var(--on-deep)}
.band .eyebrow{color:var(--accent)}
.band .lede,.band .ink-soft{color:rgba(255,255,255,.6)}
/* band sections sit on the dark --deep colour in EVERY theme, so any text
   drawn directly on the band must be light (the ink vars flip dark on light themes) */
.band .voicecard .cap{color:rgba(255,255,255,.92)}
.band .voicecard .cap .tag{color:var(--accent)}
.band .word{color:rgba(255,255,255,.72);border-color:rgba(255,255,255,.2)}
.band .word.no{color:rgba(255,255,255,.42)}
.band .legend{color:rgba(255,255,255,.64)}
.band .tl p{color:rgba(255,255,255,.64)}
.band .step p{color:rgba(255,255,255,.64)}
/* role cards use a light surface on the dark band — keep their heading on ink */
.band .role h5{color:var(--ink)}

/* ---------- TOP BAR ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(20px,5vw,56px);
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hairline);
}
.topbar .brand{display:flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;white-space:nowrap}
.topbar .brand>span:first-child{white-space:nowrap}
.topbar .brand b{color:var(--accent);font-weight:600}
.topbar .brand .by{color:var(--ink-faint);font-size:10px;letter-spacing:.22em}
.theme-switch{display:flex;gap:6px;align-items:center}
.theme-switch .lbl{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-right:6px}
.tpill{
  width:34px;height:22px;border-radius:20px;border:1px solid var(--hairline);
  cursor:pointer;position:relative;padding:0;background:transparent;transition:transform .2s,border-color .2s;
  display:flex;align-items:center;justify-content:center;
}
.tpill:hover{transform:translateY(-1px)}
.tpill span{width:20px;height:10px;border-radius:8px;display:block}
.tpill[data-set="noir"] span{background:linear-gradient(90deg,#1C0A0F,#E8A0B4)}
.tpill[data-set="emerald"] span{background:linear-gradient(90deg,#2D5A4A,#B8860B)}
.tpill[data-set="blush"] span{background:linear-gradient(90deg,#9B6E6E,#EBD9D2)}
.tpill.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}

/* ---------- HERO ---------- */
.hero{min-height:88vh;display:flex;flex-direction:column;justify-content:center;text-align:center;overflow:hidden}
.hero .watermark{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-weight:300;font-size:min(46vw,640px);
  color:var(--watermark);line-height:1;pointer-events:none;user-select:none;letter-spacing:-.04em;
}
.hero-logo{width:104px;height:104px;border-radius:50%;margin:0 auto 30px;
  background:#fff;display:flex;align-items:center;justify-content:center;
  padding:5px;position:relative;z-index:1;
  box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent);
}
.hero-logo img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.hero h1{font-size:clamp(46px,8.5vw,108px);position:relative;z-index:1;margin-bottom:8px}
.hero .kicker{position:relative;z-index:1;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.hero .sub{position:relative;z-index:1;font-size:clamp(13px,1.4vw,16px);letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);margin-top:18px}
.hero .meta{position:relative;z-index:1;margin-top:42px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint)}
.hero .meta .dot{width:3px;height:3px;border-radius:50%;background:var(--accent)}
.scrollcue{position:relative;z-index:1;margin-top:54px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-faint)}

/* ---------- STAT / AUDIT ---------- */
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:26px}
.card.flat{background:var(--surface-2)}
.statn{font-family:'Cormorant Garamond',serif;font-size:clamp(38px,5vw,56px);font-weight:400;color:var(--accent);line-height:1}
.statl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px}

.ba{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}
.ba .col h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.ba .now h4{color:var(--ink-faint)}
.ba .next h4{color:var(--accent)}
.ba .tagchip{font-size:10px;letter-spacing:.12em;padding:2px 9px;border-radius:20px;text-transform:uppercase}
.ba .now .tagchip{background:var(--surface-2);color:var(--ink-faint)}
.ba .next .tagchip{background:var(--accent);color:var(--on-accent)}
.checklist{list-style:none;display:flex;flex-direction:column;gap:13px}
.checklist li{display:flex;gap:12px;font-size:14px;color:var(--ink-soft);line-height:1.5}
.checklist li i{color:var(--accent);font-size:17px;flex-shrink:0;margin-top:1px}
.ba .now .checklist li i{color:var(--ink-faint)}

/* ---------- IDENTITY ---------- */
.swatchrow{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:8px}
.swatch{border-radius:12px;overflow:hidden;border:1px solid var(--hairline)}
.swatch .chip{height:84px}
.swatch .meta{padding:10px 12px;background:var(--surface)}
.swatch .nm{font-size:12px;font-weight:500}
.swatch .hex{font-family:'DM Sans';font-size:11px;color:var(--ink-faint);letter-spacing:.05em;margin-top:2px}
.specimen{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:30px 32px}
.specimen .big{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,6vw,68px);font-weight:300;line-height:1}
.specimen .lab{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.specimen .alpha{font-size:14px;letter-spacing:.04em;color:var(--ink-soft);margin-top:14px}
.specimen.sans .big{font-family:'DM Sans';font-weight:500;font-size:clamp(26px,3vw,38px)}

.dodont{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.dd{border-radius:14px;padding:22px 24px;border:1px solid var(--hairline)}
.dd h5{font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;display:flex;gap:8px;align-items:center}
.dd.do h5{color:var(--accent)} .dd.dont h5{color:var(--ink-faint)}
.dd ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.dd li{font-size:13px;color:var(--ink-soft);display:flex;gap:9px}
.dd li i{flex-shrink:0;margin-top:2px}
.dd.do li i{color:var(--accent)} .dd.dont li i{color:var(--ink-faint)}

/* ---------- PILLARS ---------- */
.pillar{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:26px 24px;display:flex;flex-direction:column;gap:12px;transition:border-color .25s,transform .25s}
.pillar:hover{border-color:var(--accent);transform:translateY(-3px)}
.pillar .pn{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--accent)}
.pillar .ico{width:46px;height:46px;border-radius:50%;background:var(--accent-wash);display:flex;align-items:center;justify-content:center}
.pillar .ico i{font-size:22px;color:var(--accent)}
.pillar h4{font-size:16px;font-weight:600}
.pillar p{font-size:13px;color:var(--ink-soft);line-height:1.6}
.pillar .pct{margin-top:auto;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.pillar .pct b{color:var(--accent)}

/* ---------- VOICE ---------- */
.voicecard{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:24px 26px}
.voicecard .h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.cap{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;line-height:1.4;color:var(--ink)}
.cap .tag{font-style:normal;font-family:'DM Sans';font-size:12px;color:var(--accent);letter-spacing:.04em}
.wordbank{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.word{font-size:12px;letter-spacing:.06em;padding:6px 13px;border:1px solid var(--hairline);border-radius:30px;color:var(--ink-soft)}
.word.no{text-decoration:line-through;color:var(--ink-faint);opacity:.7}

/* ---------- WEEKLY RHYTHM ---------- */
.week{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:8px}
.day{background:var(--surface);border:1px solid var(--hairline);border-radius:12px;padding:14px 12px;min-height:150px}
.day .dn{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--hairline)}
.slot{font-size:11px;line-height:1.4;margin-bottom:10px;display:flex;flex-direction:column;gap:3px}
.slot .t{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}
.slot .n{color:var(--ink-soft)}
.legend{display:flex;gap:20px;flex-wrap:wrap;margin-top:22px;font-size:11px;color:var(--ink-soft);letter-spacing:.04em}
.legend span{display:flex;align-items:center;gap:7px}
.legend i{width:9px;height:9px;border-radius:3px;display:block}

/* ---------- CALENDAR ---------- */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;margin-top:8px}
.cal .dow{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);text-align:center;padding-bottom:4px}
.cell{aspect-ratio:1/1.08;background:var(--surface);border:1px solid var(--hairline);border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden}
.cell .dd2{font-size:10px;color:var(--ink-faint);font-weight:600}
.cell .ev{font-size:9px;line-height:1.25;color:var(--ink-soft);letter-spacing:.01em}
.cell .pin{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%}
.cell.feat{background:var(--accent-wash);border-color:var(--accent)}
.dotk{display:flex;gap:18px;flex-wrap:wrap;margin-top:20px;font-size:11px;color:var(--ink-soft)}
.dotk span{display:flex;align-items:center;gap:7px}
.dotk i{width:8px;height:8px;border-radius:50%;display:block}

/* ---------- FEED / STORY MOCKUPS ---------- */
.feedwrap{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:start}
.phone{background:#000;border-radius:34px;padding:10px;box-shadow:0 30px 60px -20px rgba(0,0,0,.5);max-width:340px;margin:0 auto;border:1px solid var(--hairline)}
.phone-screen{background:var(--surface);border-radius:26px;overflow:hidden}
.ig-head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--hairline)}
.ig-avatar{width:38px;height:38px;border-radius:50%;background:#fff;padding:2px;box-shadow:0 0 0 2px var(--accent)}
.ig-avatar img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.ig-name{font-size:13px;font-weight:600}
.ig-sub{font-size:10px;color:var(--ink-faint)}
.ig-bio{padding:12px 14px;font-size:11px;color:var(--ink-soft);line-height:1.55;border-bottom:1px solid var(--hairline)}
.ig-bio b{color:var(--ink)}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.tile{aspect-ratio:1/1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface-2)}
.tile img{width:100%;height:100%;object-fit:cover}
.tile.acc{background:var(--deep);color:var(--on-deep);flex-direction:column;text-align:center;padding:8px}
.tile .ttl{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:var(--accent)}
.tile .pr{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--accent)}
.tile .sm{font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:3px}
.ph{background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 8px,var(--surface) 8px,var(--surface) 16px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.ph .m{font-family:'DM Mono','Courier New',monospace;font-size:8px;letter-spacing:.08em;color:var(--ink-faint);text-align:center;line-height:1.4;padding:0 6px}
.ph i{font-size:18px;color:var(--ink-faint)}

.storyrow{display:flex;gap:14px;overflow:hidden;flex-wrap:wrap;justify-content:center}
.story{width:148px;aspect-ratio:9/16;border-radius:18px;overflow:hidden;position:relative;border:1px solid var(--hairline);background:var(--deep)}
.story .bar{position:absolute;top:9px;left:9px;right:9px;height:2px;border-radius:2px;background:rgba(255,255,255,.35);z-index:3}
.story .bar::after{content:'';position:absolute;left:0;top:0;bottom:0;width:60%;background:#fff;border-radius:2px}
.story-img{position:absolute;inset:0}
.story-img img{width:100%;height:100%;object-fit:cover}
.story .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),transparent 40%,rgba(0,0,0,.7))}
.story .cap{position:absolute;left:0;right:0;bottom:16px;text-align:center;z-index:2;padding:0 12px}
.story .cap .e{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.story .cap .t{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:#fff;line-height:1.25}
.story.ph{flex-direction:column}

/* ---------- HASHTAGS ---------- */
.hset{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:22px 24px}
.hset .h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.hset .d{font-size:12px;color:var(--ink-faint);margin-bottom:14px}
.tags{display:flex;flex-wrap:wrap;gap:7px}
.htag{font-size:12px;padding:5px 11px;border-radius:30px;background:var(--accent-wash);color:var(--accent);letter-spacing:.02em}
.eng-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.eng-list li{display:flex;gap:14px;align-items:flex-start}
.eng-list .n{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--accent);line-height:1;width:34px;flex-shrink:0}
.eng-list .tx h5{font-size:14px;font-weight:600;margin-bottom:3px}
.eng-list .tx p{font-size:12px;color:var(--ink-soft)}

/* ---------- KPI ---------- */
.kpi{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:24px;text-align:center;position:relative;overflow:hidden}
.kpi .from{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.kpi .to{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4.5vw,50px);color:var(--accent);line-height:1;margin:6px 0}
.kpi .lab{font-size:12px;color:var(--ink-soft);letter-spacing:.04em}
.kpi .arrow{font-size:11px;color:var(--accent-2);letter-spacing:.1em;margin-top:8px}
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.tl{border-top:2px solid var(--accent);padding-top:16px}
.tl .ph2{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.tl h5{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;margin-bottom:8px}
.tl p{font-size:13px;color:var(--ink-soft)}

/* ---------- OFFERS ---------- */
.offer{background:var(--deep);color:var(--on-deep);border-radius:14px;padding:24px;position:relative;overflow:hidden}
.offer::before{content:'';position:absolute;top:-26px;right:-26px;width:96px;height:96px;border-radius:50%;background:var(--accent-wash)}
.offer .pr{font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--accent);font-weight:400;position:relative}
.offer .nm{font-size:14px;color:rgba(255,255,255,.8);margin-top:4px;position:relative}
.offer .dt{font-size:11px;color:rgba(255,255,255,.45);margin-top:8px;position:relative;letter-spacing:.04em}
.offer .tg{display:inline-block;font-size:9px;letter-spacing:.16em;text-transform:uppercase;background:var(--accent);color:var(--on-accent);padding:3px 9px;border-radius:20px;margin-top:12px;position:relative}
.campaign{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--hairline)}
.campaign:last-child{border-bottom:none}
.campaign .mo{font-family:'Cormorant Garamond',serif;font-size:15px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);width:130px;flex-shrink:0;padding-top:2px}
.campaign .cd h5{font-size:15px;font-weight:600;margin-bottom:3px}
.campaign .cd p{font-size:13px;color:var(--ink-soft)}

/* ---------- WORKFLOW ---------- */
.flow{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:10px}
.step{padding:22px 18px;position:relative;text-align:center}
.step:not(:last-child)::after{content:'→';position:absolute;right:-9px;top:34px;color:var(--accent);font-size:16px;z-index:2}
.step .sn{width:42px;height:42px;border-radius:50%;border:1px solid var(--accent);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-family:'Cormorant Garamond',serif;font-size:18px}
.step h5{font-size:13px;font-weight:600;margin-bottom:6px}
.step p{font-size:12px;color:var(--ink-soft);line-height:1.5}
.roles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px}
.role{background:var(--surface-2);border-radius:12px;padding:20px}
.role .who{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.role h5{font-size:15px;font-weight:600;margin-bottom:6px}
.role p{font-size:12px;color:var(--ink-soft)}

/* ---------- FOOTER ---------- */
.foot{background:var(--deep);color:var(--on-deep);text-align:center;padding:clamp(64px,9vh,110px) 0}
.foot .display{font-size:clamp(34px,5vw,58px);color:var(--on-deep)}
.foot .display em{color:var(--accent)}
.foot .lede{color:rgba(255,255,255,.6);margin:18px auto 0}
.foot .cta{display:inline-flex;gap:10px;align-items:center;margin-top:34px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--on-accent);background:var(--accent);padding:15px 34px;border-radius:30px;text-decoration:none;font-weight:600;transition:transform .2s}
.foot .cta:hover{transform:translateY(-2px)}
.foot .sig{margin-top:46px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.foot .sig b{color:var(--accent)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:1fr}
  .ba,.feedwrap,.dodont,.timeline,.roles{grid-template-columns:1fr}
  .flow{grid-template-columns:1fr 1fr}
  .step:not(:last-child)::after{display:none}
  .swatchrow{grid-template-columns:repeat(3,1fr)}
  .week,.cal{grid-template-columns:repeat(4,1fr)}
  .topbar .brand .full{display:none}
}
@media(max-width:560px){
  .cols-2,.cols-4{grid-template-columns:1fr}
  .swatchrow{grid-template-columns:repeat(2,1fr)}
  .week,.cal{grid-template-columns:repeat(3,1fr)}
  .theme-switch .lbl{display:none}
}
@media print{.topbar,.scrollcue{display:none}.reveal{opacity:1;transform:none}}
