/* ==========================================================================
   Off Hours — Shared Blog Stylesheet
   Used by: /blog/index.html, individual post pages, /about
   Inherits the marketing site's design system completely
   ========================================================================== */

:root{
  --cream:#F5F1E8;
  --cream-deep:#EDE6D5;
  --paper:#FAF7EE;
  --ink:#0F2A1E;
  --ink-soft:#3D5448;
  --ink-faint:#6B7E73;
  --line:rgba(15,42,30,0.08);
  --line-mid:rgba(15,42,30,0.14);
  --line-strong:rgba(15,42,30,0.22);
  --moss:#1a4d3a;
  --moss-bright:#2C6E52;

  --peach:#FFD4B8;
  --peach-deep:#F7B894;
  --butter:#F5E6A8;
  --butter-deep:#EAD173;
  --sky:#CDE1E8;
  --sky-deep:#A9CBD6;
  --coral:#FF8A66;
  --mint:#C9E2B8;
  --mint-deep:#A8CE8F;
  --lilac:#D4C8E8;
  --rose:#F2C8D2;

  --rainbow: linear-gradient(90deg, var(--coral) 0%, var(--peach-deep) 20%, var(--butter-deep) 40%, var(--mint-deep) 62%, var(--sky-deep) 82%, var(--lilac) 100%);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:400;font-size:16px;line-height:1.5;letter-spacing:-0.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
::selection{background:var(--ink);color:var(--cream);}

/* ============== ATMOSPHERE ============== */
.grid-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 50% 30%,rgba(0,0,0,0.8),transparent 85%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 30%,rgba(0,0,0,0.8),transparent 85%);
}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:0.3;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.05 0 0 0 0 0.05 0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.iridescence{position:absolute;top:12%;right:-5%;width:55%;height:75%;z-index:0;pointer-events:none;filter:blur(90px);opacity:0.7;animation:float 22s ease-in-out infinite alternate;}
.iridescence::before,.iridescence::after{content:"";position:absolute;border-radius:50%;}
.iridescence::before{top:0;left:20%;width:60%;height:70%;background:radial-gradient(circle,var(--peach),transparent 70%);}
.iridescence::after{bottom:0;right:0;width:70%;height:60%;background:radial-gradient(circle,var(--butter),transparent 70%);}
.iridescence-b{position:absolute;top:30%;left:-8%;width:45%;height:60%;z-index:0;filter:blur(90px);opacity:0.5;pointer-events:none;background:radial-gradient(circle,var(--sky),transparent 65%);animation:float 26s ease-in-out infinite alternate-reverse;}
.iridescence-c{position:absolute;top:55%;right:25%;width:28%;height:35%;z-index:0;filter:blur(70px);opacity:0.5;pointer-events:none;background:radial-gradient(circle,var(--mint),transparent 65%);animation:float 28s ease-in-out infinite alternate;}
@keyframes float{from{transform:translate(0,0) scale(1);}to{transform:translate(40px,-30px) scale(1.08);}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.65;transform:scale(0.85);}}

/* ============== NAV ============== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px 28px;display:flex;align-items:center;justify-content:space-between;
  backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);
  background:rgba(245,241,232,0.78);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);}
.brand-mark{
  width:32px;height:32px;border-radius:9px;background:var(--moss);color:var(--cream);
  display:grid;place-items:center;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;letter-spacing:-0.04em;
  position:relative;overflow:hidden;
  transition:transform 0.4s cubic-bezier(0.2,0.8,0.2,1);
}
.brand-mark::after{content:"";position:absolute;top:8px;right:8px;width:5px;height:5px;border-radius:50%;background:var(--butter-deep);box-shadow:0 0 6px var(--butter);}
.brand:hover .brand-mark{transform:rotate(-6deg) scale(1.05);}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;letter-spacing:-0.03em;}
.nav-links{display:flex;gap:30px;}
.nav-links a{color:var(--ink);text-decoration:none;font-size:14px;font-weight:450;letter-spacing:-0.01em;position:relative;padding:4px 0;font-family:'Inter',sans-serif;}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform 0.3s cubic-bezier(0.2,0.8,0.2,1);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-links a.active{color:var(--moss);}
.nav-links a.active::after{transform:scaleX(1);background:var(--moss);}
.nav-cta{font-family:'Inter',sans-serif;font-size:14px;font-weight:500;letter-spacing:-0.01em;padding:11px 20px;border-radius:999px;background:var(--moss);color:var(--cream);text-decoration:none;transition:transform 0.25s,background 0.25s,box-shadow 0.3s;display:inline-flex;align-items:center;gap:8px;}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--butter-deep);box-shadow:0 0 6px var(--butter);}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 25px rgba(26,77,58,0.2);background:var(--ink);}
@media (max-width:820px){.nav-links{display:none;}.nav{padding:14px 18px;}}

/* ============== BUTTONS ============== */
.btn-primary{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 12px 18px 26px;background:var(--moss);color:var(--cream);
  text-decoration:none;border-radius:999px;
  font-family:'Inter',sans-serif;font-weight:500;font-size:16px;letter-spacing:-0.015em;
  transition:transform 0.3s cubic-bezier(0.2,0.8,0.2,1),box-shadow 0.3s,background 0.3s;
  border:none;cursor:pointer;
}
.btn-primary .arr-circle{width:30px;height:30px;border-radius:50%;background:var(--cream);display:grid;place-items:center;color:var(--moss);font-size:12px;transition:transform 0.35s cubic-bezier(0.2,0.8,0.2,1),background 0.3s;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(26,77,58,0.25);background:var(--ink);}
.btn-primary:hover .arr-circle{transform:rotate(-45deg);background:var(--butter);}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:14px 4px;color:var(--ink);text-decoration:none;font-size:15px;font-weight:500;letter-spacing:-0.01em;font-family:'Inter',sans-serif;position:relative;transition:gap 0.25s;}
.btn-ghost:hover{gap:14px;}
.btn-outline{display:inline-flex;align-items:center;gap:12px;padding:14px 22px;border-radius:999px;background:transparent;color:var(--ink);border:1px solid var(--ink);text-decoration:none;font-family:'Inter',sans-serif;font-weight:500;font-size:15px;letter-spacing:-0.01em;transition:background 0.25s,color 0.25s,gap 0.25s;cursor:pointer;}
.btn-outline:hover{background:var(--ink);color:var(--cream);gap:16px;}

/* ============== SECTION SHELL ============== */
section.block{position:relative;z-index:2;padding:90px 28px;max-width:1480px;margin:0 auto;}
.section-head{display:flex;flex-direction:column;align-items:flex-start;gap:24px;margin-bottom:48px;}
.section-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--paper);border:1px solid var(--line-mid);font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-soft);width:fit-content;text-transform:uppercase;letter-spacing:0.04em;}
.section-tag .num{width:18px;height:18px;border-radius:50%;background:var(--moss);color:var(--cream);display:grid;place-items:center;font-size:9px;font-weight:700;letter-spacing:0;}
.section-title{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(40px,5.5vw,72px);line-height:0.96;letter-spacing:-0.04em;color:var(--ink);max-width:1100px;}
.section-title .accent{color:var(--moss);}

/* ============== BLOG-SPECIFIC: HERO ============== */
.blog-hero{position:relative;z-index:2;padding:130px 28px 40px;max-width:1480px;margin:0 auto;}
.blog-hero-top{display:flex;gap:24px;align-items:center;margin-bottom:32px;flex-wrap:wrap;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;border-radius:999px;background:var(--paper);border:1px solid var(--line-mid);font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.04em;}
.hero-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral);box-shadow:0 0 8px rgba(255,138,102,0.6);animation:pulse 2.2s ease-in-out infinite;}
.blog-hero h1{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(60px,10vw,168px);line-height:0.9;letter-spacing:-0.055em;color:var(--ink);}
.blog-hero h1 .accent-word{color:var(--moss);position:relative;display:inline-block;padding-bottom:0.14em;}
.blog-hero h1 .accent-word::after{content:"";position:absolute;left:0;right:0;bottom:0;height:0.07em;background:var(--rainbow);border-radius:999px;opacity:0.95;}
.blog-hero-sub{margin-top:28px;font-size:20px;line-height:1.45;letter-spacing:-0.01em;color:var(--ink-soft);max-width:560px;}
.blog-hero-sub b{color:var(--ink);font-weight:500;}

/* ============== FEATURED POST BLOCK ============== */
.featured-wrap{position:relative;z-index:2;max-width:1480px;margin:72px auto 0;padding:0 28px;}
.featured-post{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;
  border-radius:28px;overflow:hidden;
  background:var(--paper);border:1px solid var(--line-mid);
  position:relative;
  transition:transform 0.4s cubic-bezier(0.2,0.8,0.2,1),box-shadow 0.4s;
}
.featured-post::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--rainbow);z-index:2;}
.featured-post:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(15,42,30,0.08);}
@media (max-width:900px){.featured-post{grid-template-columns:1fr;}}
.featured-image{
  position:relative;overflow:hidden;
  min-height:420px;
  background:var(--butter);
  display:flex;align-items:center;justify-content:center;
}
.featured-image img{width:100%;height:100%;object-fit:cover;display:block;}
.featured-image .placeholder-viz{
  width:100%;height:100%;position:relative;
  background:
    radial-gradient(circle at 30% 40%, rgba(255,212,184,0.6), transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(205,225,232,0.5), transparent 60%),
    radial-gradient(circle at 50% 80%, rgba(201,226,184,0.5), transparent 60%),
    var(--butter);
  display:grid;place-items:center;padding:40px;
}
.featured-image .placeholder-viz .mini-grid{
  display:grid;grid-template-columns:repeat(24,1fr);gap:4px;width:100%;max-width:400px;
}
.featured-image .placeholder-viz .mc{aspect-ratio:1;border-radius:3px;background:rgba(15,42,30,0.08);}
.featured-image .placeholder-viz .mc.on{background:var(--moss);}
.featured-image .placeholder-viz .mc.on.h-1{background:var(--moss-bright);}
.featured-image .editorial-card{
  width:100%;height:100%;position:relative;
  background:
    radial-gradient(circle at 20% 25%, rgba(255,212,184,0.55), transparent 55%),
    radial-gradient(circle at 80% 75%, rgba(234,209,115,0.45), transparent 55%),
    var(--butter);
  display:flex;flex-direction:column;justify-content:center;
  padding:48px 56px;
}
@media (max-width:700px){.featured-image .editorial-card{padding:40px 32px;}}
.editorial-quote{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(28px,3.4vw,42px);line-height:1.08;letter-spacing:-0.035em;
  color:var(--ink);margin:0;
}
.editorial-attribution{
  margin-top:28px;font-family:'Space Mono',monospace;font-size:11px;
  color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.08em;
}
.editorial-rainbow{
  position:absolute;left:48px;right:48px;bottom:32px;height:3px;
  background:var(--rainbow);border-radius:999px;opacity:0.95;
}
@media (max-width:700px){.editorial-rainbow{left:32px;right:32px;bottom:24px;}}
.featured-body{padding:44px 48px;display:flex;flex-direction:column;justify-content:center;gap:16px;}
@media (max-width:700px){.featured-body{padding:32px 28px;}}
.featured-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.featured-pill{display:inline-flex;align-items:center;padding:4px 11px;border-radius:999px;font-family:'Space Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:0.06em;background:var(--cream-deep);color:var(--ink);}
.featured-pill.featured-featured{background:var(--coral);color:var(--cream);}
.featured-title{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(32px,3.8vw,48px);line-height:1;letter-spacing:-0.035em;color:var(--ink);
  position:relative;display:inline-block;padding-bottom:4px;
}
.featured-title a{color:inherit;text-decoration:none;background-image:linear-gradient(90deg,var(--ink),var(--ink));background-repeat:no-repeat;background-size:0% 2px;background-position:0 100%;transition:background-size 0.4s cubic-bezier(0.2,0.8,0.2,1);}
.featured-post:hover .featured-title a{background-image:var(--rainbow);background-size:100% 3px;}
.featured-excerpt{font-size:17px;line-height:1.5;color:var(--ink-soft);letter-spacing:-0.005em;}
.featured-foot{display:flex;align-items:center;gap:14px;padding-top:16px;border-top:1px solid var(--line);font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.04em;flex-wrap:wrap;}
.featured-foot .sep{width:1px;height:10px;background:var(--line-strong);}

/* ============== CATEGORY FILTER ============== */
.cat-filter-wrap{position:relative;z-index:2;max-width:1480px;margin:72px auto 24px;padding:0 28px;}
.cat-filter-label{font-family:'Space Mono',monospace;font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;display:block;}
.cat-pills{display:flex;gap:10px;flex-wrap:wrap;}
.cat-pill{
  font-family:'Inter',sans-serif;font-weight:500;font-size:13px;letter-spacing:-0.005em;
  padding:10px 18px;border-radius:999px;border:1px solid var(--line-mid);
  background:var(--paper);color:var(--ink);cursor:pointer;
  transition:all 0.2s cubic-bezier(0.2,0.8,0.2,1);
}
.cat-pill:hover{border-color:var(--line-strong);transform:translateY(-1px);}
.cat-pill.active{background:var(--moss);color:var(--cream);border-color:var(--moss);}
.cat-pill .count{font-family:'Space Mono',monospace;font-size:10px;margin-left:8px;opacity:0.55;}

/* ============== POST GRID ============== */
.post-grid{position:relative;z-index:2;max-width:1480px;margin:0 auto;padding:24px 28px 90px;display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
@media (max-width:900px){.post-grid{grid-template-columns:1fr;}}
.post-card{
  border-radius:24px;overflow:hidden;
  display:flex;flex-direction:column;
  position:relative;
  transition:transform 0.35s cubic-bezier(0.2,0.8,0.2,1),box-shadow 0.35s;
  min-height:300px;
  background:var(--paper);
  border:1px solid var(--line-mid);
}
.post-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(15,42,30,0.08);}
.post-card.c-playbook{background:var(--peach);border-color:rgba(247,184,148,0.5);}
.post-card.c-data{background:var(--sky);border-color:rgba(169,203,214,0.5);}
.post-card.c-comparison{background:var(--butter);border-color:rgba(234,209,115,0.5);}
.post-card.c-news{background:var(--lilac);border-color:rgba(212,200,232,0.55);}
.post-card.c-guide{background:var(--mint);border-color:rgba(168,206,143,0.5);}
.post-card.hide{display:none;}
.post-card-body{padding:28px;flex:1;display:flex;flex-direction:column;gap:12px;}
.post-card-meta{display:flex;gap:8px;align-items:center;}
.post-card-tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:rgba(15,42,30,0.1);font-family:'Space Mono',monospace;font-size:10px;color:var(--ink);text-transform:uppercase;letter-spacing:0.06em;}
.post-card-title{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:24px;line-height:1.1;letter-spacing:-0.03em;color:var(--ink);margin:2px 0;
}
.post-card-title a{color:inherit;text-decoration:none;}
.post-card-title a:hover{color:var(--moss);}
.post-card-excerpt{font-size:14px;line-height:1.5;color:var(--ink);opacity:0.8;letter-spacing:-0.005em;}
.post-card-foot{display:flex;gap:10px;align-items:center;padding-top:14px;margin-top:auto;border-top:1px solid rgba(15,42,30,0.1);font-family:'Space Mono',monospace;font-size:10px;color:var(--ink);opacity:0.65;text-transform:uppercase;letter-spacing:0.04em;}

/* ============== NEWSLETTER CTA BLOCK ============== */
.cta-block{position:relative;z-index:2;max-width:1480px;margin:0 auto 90px;padding:56px 48px;border-radius:28px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--peach);transition:transform 0.4s cubic-bezier(0.2,0.8,0.2,1);}
.cta-block.newsletter-block{max-width:1180px;}
.cta-block.butter{background:var(--butter);}
.cta-block.sky{background:var(--sky);}
.cta-block.mint{background:var(--mint);}
.cta-block.ink{background:var(--ink);color:var(--cream);}
.cta-block-copy{}
.cta-head{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(32px,4.2vw,52px);line-height:0.98;letter-spacing:-0.04em;color:var(--ink);}
.cta-block.ink .cta-head{color:var(--cream);}
.cta-head .accent{color:var(--moss);position:relative;display:inline-block;padding-bottom:0.12em;}
.cta-head .accent::after{content:"";position:absolute;left:0;right:0;bottom:0;height:0.07em;background:var(--rainbow);border-radius:999px;opacity:0.95;}
.cta-block.ink .cta-head .accent{color:var(--butter);}
.cta-sub{margin-top:14px;font-size:16px;line-height:1.5;color:var(--ink-soft);max-width:420px;}
.cta-block.ink .cta-sub{color:rgba(245,241,232,0.75);}
.cta-block.mobile-stack{}
@media (max-width:820px){.cta-block{grid-template-columns:1fr;padding:40px 32px;gap:28px;margin:0 16px 60px;}}

/* newsletter form inside CTA block */
.newsletter-form{display:flex;flex-direction:column;gap:12px;}
.newsletter-form-row{display:flex;gap:10px;background:var(--cream);border-radius:999px;padding:6px 6px 6px 22px;border:1px solid var(--line-strong);transition:border-color 0.25s,box-shadow 0.25s;}
.newsletter-form-row:focus-within{border-color:var(--moss);box-shadow:0 0 0 4px rgba(26,77,58,0.08);}
.newsletter-form-row input[type=email]{flex:1;border:none;background:transparent;outline:none;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);letter-spacing:-0.005em;padding:8px 0;}
.newsletter-form-row input[type=email]::placeholder{color:var(--ink-faint);}
.newsletter-form-row button{padding:12px 10px 12px 22px;border-radius:999px;background:var(--moss);color:var(--cream);border:none;font-family:'Inter',sans-serif;font-weight:500;font-size:14px;letter-spacing:-0.01em;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:background 0.2s,transform 0.2s;}
.newsletter-form-row button .arr-circle{width:22px;height:22px;border-radius:50%;background:var(--cream);display:grid;place-items:center;color:var(--moss);font-size:10px;transition:transform 0.3s,background 0.3s;}
.newsletter-form-row button:hover{background:var(--ink);}
.newsletter-form-row button:hover .arr-circle{transform:rotate(-45deg);background:var(--butter);}
.newsletter-success{display:none;padding:14px 22px;border-radius:999px;background:var(--moss);color:var(--cream);font-family:'Inter',sans-serif;font-size:14px;font-weight:500;text-align:center;}
.newsletter-success.show{display:block;animation:bubbleIn 0.4s cubic-bezier(0.2,0.8,0.2,1);}
.newsletter-form.sent .newsletter-form-row{display:none;}
@keyframes bubbleIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
.newsletter-legal{font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-faint);letter-spacing:0;}
.cta-block.ink .newsletter-legal{color:rgba(245,241,232,0.5);}

/* ============== ARTICLE TEMPLATE (INDIVIDUAL POSTS) ============== */
.article-shell{max-width:720px;margin:0 auto;padding:130px 28px 60px;position:relative;z-index:2;}
.article-back{display:inline-flex;align-items:center;gap:8px;margin-bottom:32px;font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.06em;text-decoration:none;transition:gap 0.25s,color 0.25s;}
.article-back:hover{gap:12px;color:var(--moss);}
.article-back .arr{transform:rotate(180deg);display:inline-block;}
.article-header{margin-bottom:48px;text-align:left;}
.article-header .post-card-tag{margin-bottom:20px;}
.article-title{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(40px,6.5vw,72px);line-height:0.95;letter-spacing:-0.045em;color:var(--ink);margin-bottom:28px;}
.article-title .accent{color:var(--moss);}
.article-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line);}
.article-meta-avatar{width:36px;height:36px;border-radius:50%;background:var(--moss);color:var(--cream);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:13px;letter-spacing:-0.03em;}
.article-meta-author{font-family:'Inter',sans-serif;font-weight:500;font-size:14px;color:var(--ink);}
.article-meta-misc{font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.04em;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.article-meta-misc .sep{width:1px;height:10px;background:var(--line-strong);}

/* TL;DR box */
.tldr{background:var(--paper);border:1px solid var(--line-mid);border-radius:22px;padding:28px 32px;margin:0 0 48px;position:relative;overflow:hidden;}
.tldr::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--rainbow);}
.tldr-label{font-family:'Space Mono',monospace;font-size:10px;color:var(--moss);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px;display:inline-flex;align-items:center;gap:8px;}
.tldr-label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--moss-bright);box-shadow:0 0 6px var(--moss-bright);}
.tldr-body{font-size:16px;line-height:1.55;color:var(--ink-soft);}
.tldr-body b{color:var(--ink);font-weight:500;}

/* Article body */
.article-body{font-size:18px;line-height:1.7;color:var(--ink);letter-spacing:-0.005em;}
.article-body p{margin:0 0 24px;}
.article-body p b,.article-body p strong{font-weight:500;color:var(--ink);}
.article-body p a,.article-body li a{color:var(--moss);text-decoration:none;background-image:linear-gradient(var(--moss),var(--moss));background-repeat:no-repeat;background-size:100% 1px;background-position:0 100%;transition:color 0.2s,background 0.3s;padding-bottom:1px;}
.article-body p a:hover,.article-body li a:hover{color:var(--ink);background-image:var(--rainbow);background-size:100% 2px;}

.article-body h2{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(28px,3.5vw,36px);line-height:1.05;letter-spacing:-0.035em;
  margin:56px 0 20px;color:var(--ink);
  position:relative;display:inline-block;
  padding-bottom:6px;
}
.article-body h2:first-child{margin-top:0;}
.article-body h2::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:0;
  background:var(--rainbow);border-radius:3px;
  transition:width 0.5s cubic-bezier(0.2,0.8,0.2,1);
}
.article-body h2:hover::after{width:100%;}
.article-body h3{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:22px;line-height:1.2;letter-spacing:-0.025em;margin:40px 0 14px;color:var(--ink);}

.article-body blockquote{
  border-left:3px solid var(--moss);
  background:var(--paper);
  padding:20px 26px;
  margin:32px 0;
  border-radius:0 14px 14px 0;
  font-family:'Space Grotesk',sans-serif;font-style:italic;font-weight:400;
  font-size:19px;line-height:1.45;letter-spacing:-0.02em;color:var(--ink-soft);
}
.article-body blockquote p{margin:0;}
.article-body blockquote b{color:var(--ink);font-weight:500;font-style:normal;}

.article-body ul,.article-body ol{margin:0 0 24px;padding-left:0;list-style:none;}
.article-body ul li,.article-body ol li{padding-left:28px;margin-bottom:10px;position:relative;line-height:1.65;}
.article-body ul li::before{content:"";position:absolute;left:6px;top:0.75em;width:7px;height:7px;background:var(--moss);border-radius:50%;}
.article-body ol{counter-reset:ol-counter;}
.article-body ol li{counter-increment:ol-counter;}
.article-body ol li::before{content:counter(ol-counter)".";position:absolute;left:0;top:0;font-family:'Space Mono',monospace;font-weight:700;color:var(--moss);font-size:14px;letter-spacing:0;}

.article-body img{width:100%;border-radius:16px;border:1px solid var(--line-mid);margin:28px 0;display:block;}
.article-body figure{margin:28px 0;}
.article-body figure img{margin:0;}
.article-body figcaption{margin-top:12px;font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-faint);text-align:center;letter-spacing:0.04em;}

.article-body code{font-family:'Space Mono',monospace;font-size:14px;background:var(--cream-deep);padding:2px 8px;border-radius:5px;color:var(--ink);letter-spacing:0.02em;border:1px solid var(--line);}
.article-body pre{background:var(--cream-deep);border:1px solid var(--line);border-radius:14px;padding:20px 24px;overflow-x:auto;margin:28px 0;font-family:'Space Mono',monospace;font-size:13px;line-height:1.6;color:var(--ink);}
.article-body pre code{background:none;padding:0;border:none;font-size:inherit;}

.article-body hr{border:none;margin:48px 0;display:flex;justify-content:center;position:relative;height:16px;}
.article-body hr::before{content:"· · ·";position:absolute;top:0;left:50%;transform:translateX(-50%);color:var(--ink-faint);letter-spacing:0.4em;font-family:'Space Mono',monospace;}

/* Inline CTA blocks within article body - different styling than full-width ones */
.article-body .inline-cta{
  margin:48px 0;padding:32px 34px;border-radius:22px;
  background:var(--peach);
  display:flex;flex-direction:column;gap:14px;align-items:flex-start;
}
.article-body .inline-cta.butter{background:var(--butter);}
.article-body .inline-cta.sky{background:var(--sky);}
.article-body .inline-cta.mint{background:var(--mint);}
.article-body .inline-cta-head{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:26px;line-height:1.05;letter-spacing:-0.03em;color:var(--ink);margin:0;}
.article-body .inline-cta-head .accent{color:var(--moss);}
.article-body .inline-cta p{font-size:15px;color:var(--ink-soft);margin:0;max-width:560px;}

/* FAQ section inside article */
.article-faq{margin:56px 0;}
.article-faq-head{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:28px;letter-spacing:-0.03em;margin-bottom:20px;}
.article-faq details{border-bottom:1px solid var(--line-mid);padding:22px 0;}
.article-faq summary{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:20px;letter-spacing:-0.025em;line-height:1.3;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:20px;transition:color 0.2s;color:var(--ink);}
.article-faq summary::-webkit-details-marker{display:none;}
.article-faq summary::after{content:"";flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1px solid var(--line-strong);background:linear-gradient(var(--ink-soft),var(--ink-soft)) center/9px 1.5px no-repeat,linear-gradient(var(--ink-soft),var(--ink-soft)) center/1.5px 9px no-repeat;transition:transform 0.3s,border-color 0.3s;margin-top:3px;}
.article-faq details[open] summary::after{transform:rotate(45deg);background:linear-gradient(var(--moss),var(--moss)) center/9px 1.5px no-repeat;border-color:var(--moss);}
.article-faq details[open] summary{color:var(--moss);}
.article-faq-answer{margin-top:12px;color:var(--ink-soft);font-size:15px;line-height:1.65;}

/* Author byline */
.article-byline{margin:64px 0 0;padding:32px 0 0;border-top:1px solid var(--line);position:relative;}
.article-byline::before{content:"";position:absolute;top:-1px;left:0;width:80px;height:3px;background:var(--rainbow);border-radius:2px;}
.article-byline-grid{display:flex;align-items:center;gap:18px;}
.article-byline-avatar{width:56px;height:56px;border-radius:50%;background:var(--moss);color:var(--cream);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:20px;letter-spacing:-0.03em;flex-shrink:0;}
.article-byline-name{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;letter-spacing:-0.025em;color:var(--ink);}
.article-byline-role{font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.04em;margin:3px 0;}
.article-byline-bio{font-size:14px;color:var(--ink-soft);line-height:1.55;max-width:480px;margin-top:4px;}

/* Related posts section */
.related-posts{max-width:1480px;margin:0 auto;padding:80px 28px;position:relative;z-index:2;}
.related-head{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(32px,4vw,48px);line-height:1;letter-spacing:-0.035em;color:var(--ink);margin-bottom:32px;}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width:900px){.related-grid{grid-template-columns:1fr;}}

/* ============== FLOATING SHARE BAR (desktop only) ============== */
.share-bar{
  position:fixed;left:28px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:10px;z-index:40;
  padding:14px 10px;border-radius:999px;
  background:var(--paper);border:1px solid var(--line-mid);
  box-shadow:0 8px 24px rgba(15,42,30,0.06);
}
.share-bar a,.share-bar button{
  width:36px;height:36px;border-radius:50%;
  background:transparent;color:var(--ink-soft);
  display:grid;place-items:center;
  text-decoration:none;border:none;cursor:pointer;
  transition:background 0.2s,color 0.2s,transform 0.2s;
}
.share-bar a:hover,.share-bar button:hover{background:var(--moss);color:var(--cream);transform:translateY(-1px);}
.share-bar .copied{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--ink);color:var(--cream);font-family:'Space Mono',monospace;font-size:10px;padding:5px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:0.06em;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 0.2s;}
.share-bar .copied.show{opacity:1;}
@media (max-width:1200px){.share-bar{display:none;}}

/* ============== ABOUT PAGE BITS ============== */
.about-stage{max-width:860px;margin:0 auto;padding:140px 28px 40px;position:relative;z-index:2;}
.about-intro{margin-bottom:48px;}
.about-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;border-radius:999px;background:var(--paper);border:1px solid var(--line-mid);font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:28px;}
.about-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral);box-shadow:0 0 8px rgba(255,138,102,0.6);}
.about-title{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(48px,7vw,96px);line-height:0.94;letter-spacing:-0.045em;color:var(--ink);margin-bottom:24px;}
.about-title .accent{color:var(--moss);position:relative;display:inline-block;padding-bottom:0.14em;}
.about-title .accent::after{content:"";position:absolute;left:0;right:0;bottom:0;height:0.07em;background:var(--rainbow);border-radius:999px;opacity:0.95;}
.about-signature{display:flex;align-items:center;gap:14px;padding:16px 0 28px;border-bottom:1px solid var(--line);margin-bottom:36px;}
.about-avatar{width:52px;height:52px;border-radius:50%;background:var(--moss);color:var(--cream);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;letter-spacing:-0.03em;}
.about-sig-name{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:16px;letter-spacing:-0.02em;color:var(--ink);}
.about-sig-role{font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.04em;margin-top:3px;}
.about-body{display:flex;flex-direction:column;gap:20px;font-size:18px;line-height:1.65;color:var(--ink-soft);letter-spacing:-0.005em;margin-bottom:48px;}
.about-body p b{color:var(--ink);font-weight:500;}

/* ============== FOOTER ============== */
.site-footer{position:relative;z-index:2;background:var(--ink);color:var(--cream);padding:80px 28px 32px;margin-top:40px;}
.footer-inner{max-width:1480px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(245,241,232,0.12);}
@media (max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:36px;}}
@media (max-width:600px){.footer-top{grid-template-columns:1fr;gap:28px;}}
.footer-brand{display:flex;flex-direction:column;gap:16px;}
.footer-brand .brand-mark{background:var(--cream);color:var(--moss);}
.footer-brand .brand-mark::after{background:var(--coral);box-shadow:0 0 6px var(--coral);}
.footer-brand-name{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;letter-spacing:-0.03em;display:flex;align-items:center;gap:11px;color:var(--cream);}
.footer-tagline{font-family:'Space Grotesk',sans-serif;font-weight:400;font-size:16px;line-height:1.5;color:rgba(245,241,232,0.7);max-width:300px;letter-spacing:-0.015em;}
.footer-status{display:inline-flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:11px;color:rgba(245,241,232,0.65);text-transform:uppercase;letter-spacing:0.06em;padding:6px 12px;border-radius:999px;background:rgba(245,241,232,0.06);width:fit-content;}
.footer-status .dot{width:6px;height:6px;border-radius:50%;background:var(--mint-deep);box-shadow:0 0 6px var(--mint-deep);animation:pulse 2.2s ease-in-out infinite;}
.footer-socials{display:flex;gap:10px;margin-top:4px;}
.footer-socials a{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:rgba(245,241,232,0.08);
  color:rgba(245,241,232,0.7);text-decoration:none;
  transition:background 0.25s,color 0.25s,transform 0.25s;
}
.footer-socials a:hover{background:var(--butter);color:var(--ink);transform:translateY(-1px);}
.footer-socials a svg{display:block;}
.footer-col-head{font-family:'Space Mono',monospace;font-size:10px;color:rgba(245,241,232,0.5);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:18px;}
.footer-col a{display:block;padding:6px 0;color:var(--cream);text-decoration:none;font-size:14px;font-family:'Inter',sans-serif;transition:color 0.2s;}
.footer-col a:hover{color:var(--butter);}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:'Space Mono',monospace;font-size:11px;color:rgba(245,241,232,0.5);text-transform:uppercase;letter-spacing:0.06em;}
.footer-bottom-links{display:flex;gap:24px;flex-wrap:wrap;}
.footer-bottom-links a{color:rgba(245,241,232,0.5);text-decoration:none;transition:color 0.2s;}
.footer-bottom-links a:hover{color:var(--butter);}
.footer-legal{margin-top:32px;padding-top:20px;border-top:1px solid rgba(245,241,232,0.08);font-size:11px;color:rgba(245,241,232,0.4);line-height:1.6;max-width:900px;font-family:'Inter',sans-serif;}

/* reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.9s cubic-bezier(0.2,0.7,0.3,1),transform 0.9s cubic-bezier(0.2,0.7,0.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}

/* ============== CARD VIZ COMPONENTS ============== */
.card-viz{
  width:100%;height:100%;padding:20px 24px;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;
  position:relative;
}
.card-viz-caption{
  font-family:'Space Mono',monospace;font-size:10px;color:var(--ink);opacity:0.6;
  text-transform:uppercase;letter-spacing:0.08em;text-align:center;
}

/* 1. Heatmap viz — Dayparting */
@keyframes hv-fade-in{from{opacity:0;transform:scale(0.6);}to{opacity:1;transform:scale(1);}}
.heatmap-viz .hv-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:3px;
  width:100%;max-width:280px;
}
.heatmap-viz .hv-cell{
  aspect-ratio:1;border-radius:2px;
  background:rgba(15,42,30,0.08);
  opacity:0;transform:scale(0.6);
  animation:hv-fade-in 0.4s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.heatmap-viz .hv-cell.lvl-1{background:rgba(212,200,232,0.7);}
.heatmap-viz .hv-cell.lvl-2{background:rgba(169,203,214,0.85);}
.heatmap-viz .hv-cell.lvl-3{background:rgba(168,206,143,0.9);}
.heatmap-viz .hv-cell.lvl-4{background:rgba(234,209,115,0.95);}
.heatmap-viz .hv-cell.lvl-5{background:var(--coral);}

/* 2. Spend bars viz — Overnight */
@keyframes sv-grow{from{height:0;}to{height:var(--bar-h,40%);}}
.spend-viz .sv-track{
  display:flex;align-items:flex-end;gap:2px;
  width:100%;max-width:280px;height:90px;
  border-bottom:1px solid rgba(15,42,30,0.18);
  padding-bottom:2px;
}
.spend-viz .sv-bar{
  flex:1;border-radius:2px 2px 0 0;
  background:rgba(15,42,30,0.18);
  height:0;
  animation:sv-grow 0.7s cubic-bezier(0.4,0,0.2,1) forwards;
  animation-delay:calc(var(--i,0) * 25ms);
}
.spend-viz .sv-bar.peak{background:var(--coral);}
.spend-viz .sv-bar.day{background:var(--moss);}
.spend-viz .sv-bar.night{background:rgba(15,42,30,0.22);}

/* 3. Timeline viz — Prime Day */
@keyframes tl-fill{from{transform:scaleX(0);}to{transform:scaleX(1);}}
@keyframes tl-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,138,102,0.65);}70%{box-shadow:0 0 0 9px rgba(255,138,102,0);}}
.timeline-viz .tl-wrap{
  position:relative;width:100%;max-width:280px;height:60px;
  display:flex;flex-direction:column;justify-content:center;
}
.timeline-viz .tl-track{
  position:relative;height:3px;background:rgba(15,42,30,0.15);border-radius:999px;
  overflow:visible;
}
.timeline-viz .tl-fill{
  position:absolute;inset:0;background:var(--ink);border-radius:999px;
  transform-origin:left center;transform:scaleX(0);
  animation:tl-fill 1.4s cubic-bezier(0.4,0,0.2,1) 0.3s forwards;
}
.timeline-viz .tl-dot{
  position:absolute;top:50%;width:9px;height:9px;border-radius:50%;
  background:var(--ink);transform:translate(-50%,-50%);
}
.timeline-viz .tl-dot.event{
  background:var(--coral);width:13px;height:13px;
  animation:tl-pulse 2.2s ease-out 1.6s infinite;
}
.timeline-viz .tl-labels{
  margin-top:14px;display:flex;justify-content:space-between;
  font-family:'Space Mono',monospace;font-size:10px;color:var(--ink);opacity:0.7;
  letter-spacing:0.04em;
}

/* 4. Compare viz — Adtomic */
@keyframes cv-in{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
.compare-viz .cv-row{
  display:flex;align-items:stretch;gap:10px;width:100%;max-width:300px;
}
.compare-viz .cv-col{
  flex:1;display:flex;flex-direction:column;gap:4px;
}
.compare-viz .cv-col-label{
  font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--ink);opacity:0.6;margin-bottom:4px;text-align:center;
}
.compare-viz .cv-pill{
  font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:0.04em;
  padding:4px 8px;border-radius:999px;text-align:center;line-height:1.3;
  opacity:0;animation:cv-in 0.4s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.compare-viz .cv-col.suite .cv-pill{
  background:rgba(15,42,30,0.08);color:var(--ink);opacity:0.55;
}
.compare-viz .cv-col.suite .cv-pill{animation-name:cv-in;opacity:0;}
.compare-viz .cv-col.suite .cv-pill.show{opacity:0.55;}
.compare-viz .cv-col.oh .cv-pill{
  background:var(--ink);color:var(--cream);
}
.compare-viz .cv-vs{
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:500;
  color:var(--ink);opacity:0.5;letter-spacing:-0.02em;
}

/* 5. Status viz — Announcing */
@keyframes st-pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(0.7);opacity:0.55;}}
@keyframes st-fill{from{width:0;}to{width:100%;}}
.status-viz .st-card{
  background:rgba(255,255,255,0.5);
  border:1px solid rgba(15,42,30,0.12);
  border-radius:12px;padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;
  width:100%;max-width:240px;
}
.status-viz .st-head{display:flex;align-items:center;gap:10px;}
.status-viz .st-mark{
  width:26px;height:26px;border-radius:7px;background:var(--moss);color:var(--cream);
  display:grid;place-items:center;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:-0.04em;
  flex-shrink:0;
}
.status-viz .st-row{display:flex;align-items:center;gap:8px;flex:1;}
.status-viz .st-dot{
  width:8px;height:8px;border-radius:50%;background:var(--moss-bright);
  box-shadow:0 0 8px var(--moss-bright);
  animation:st-pulse 1.8s ease-in-out infinite;
}
.status-viz .st-text{
  font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:13px;color:var(--ink);
  letter-spacing:-0.015em;
}
.status-viz .st-bar{
  height:5px;border-radius:999px;background:rgba(15,42,30,0.1);overflow:hidden;
}
.status-viz .st-bar-fill{
  height:100%;background:var(--mint-deep);border-radius:999px;
  width:0;animation:st-fill 1.2s cubic-bezier(0.4,0,0.2,1) 0.3s forwards;
}
.status-viz .st-meta{
  font-family:'Space Mono',monospace;font-size:9px;color:var(--ink);opacity:0.55;
  text-transform:uppercase;letter-spacing:0.06em;
}

/* mobile — keep visualizations but trim padding */
@media (max-width:640px){
  .card-viz{padding:16px 18px;}
  .heatmap-viz .hv-grid{max-width:240px;}
  .spend-viz .sv-track{max-width:240px;height:70px;}
  .compare-viz .cv-row{max-width:260px;}
  .compare-viz .cv-pill{font-size:8px;padding:3px 6px;}
}
