/* ════════════════════════════════════════════════════════════════════════
   FairShot blog — light-glass 1080×1080 square carousels + page layout.
   Square slides are ALWAYS light themed (Instagram-ready) regardless of the
   site's dark/light toggle. Page chrome (nav/footer) follows site.css.
   ════════════════════════════════════════════════════════════════════════ */

.blog-wrap{max-width:1080px;margin:0 auto;padding:0 28px}
.blog-head{text-align:center;max-width:680px;margin:0 auto 34px}
.blog-head h1{font-size:clamp(34px,5vw,54px);margin:14px 0 0}
.blog-head p{color:var(--text2);font-size:16.5px;margin-top:16px}

/* ── Feed: filter chips + grid of cover tiles ── */
.feed-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:760px;margin:0 auto 34px}
.chipf{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  padding:8px 16px;border-radius:999px;cursor:pointer;color:var(--text2);
  background:var(--glass);border:1px solid var(--glass-border);
  transition:transform .15s var(--ease-spring),border-color .2s,color .2s,background .2s;
}
.chipf:hover{color:var(--text);border-color:var(--border2)}
.chipf:active{transform:scale(.95)}
.chipf.active{background:var(--accent-grad);color:var(--on-accent);border-color:transparent;box-shadow:0 6px 18px var(--glow)}

.blog-feed.feed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(216px,1fr));gap:18px}
.tile{
  display:flex;flex-direction:column;text-align:left;padding:0;
  font-family:inherit;color:inherit;cursor:pointer;
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:18px;overflow:hidden;box-shadow:var(--float-sm);
  transition:transform .3s var(--ease-fluid),box-shadow .3s,border-color .3s;
}
.tile:hover{transform:translateY(-6px);box-shadow:var(--float);border-color:var(--border2)}
.tile:active{transform:translateY(-6px) scale(.99)}
.tile-cover{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:var(--surface2)}
.tile-cover .slide{position:absolute;top:0;left:0;transform-origin:top left}
.tile .s-page{display:none}
.tile-meta{padding:14px 16px 17px;display:flex;flex-direction:column;gap:7px}
.tile-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tile-cat{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent)}
.tile-count{font-size:11px;color:var(--text3)}
.tile-meta h3{font-family:'Inter',sans-serif;font-size:15.5px;font-weight:600;line-height:1.32;color:var(--text)}
.tile-date{font-size:12px;color:var(--text3)}

/* ── Reader (full-bleed lightbox that opens a post) ── */
.reader{
  position:fixed;inset:0;z-index:200;display:none;
  background:var(--bg);
  opacity:0;transition:opacity .28s var(--ease-fluid);
}
.reader.open{display:block;opacity:1;animation:readerIn .4s var(--ease-fluid) both}
@keyframes readerIn{from{opacity:0}to{opacity:1}}
.reader-scroll{position:absolute;inset:0;overflow-y:auto;padding:clamp(54px,8vh,96px) 0 40px}
.reader-meta{max-width:820px;margin:clamp(20px,4vh,40px) auto 0;padding:0 24px;display:flex;flex-direction:column;gap:8px}
.reader-meta .date{font-size:12.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text3)}
.reader-meta h2{font-size:clamp(24px,3.6vw,36px)}
.reader-meta .caption{color:var(--text2);font-size:15px;white-space:pre-wrap;line-height:1.6;margin-top:4px}
.reader .export-block{max-width:880px;margin:32px auto 0;padding:0 24px}
.reader-close{
  position:fixed;top:16px;right:18px;z-index:210;
  width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:var(--text);background:var(--glass-strong);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--float-sm);
  transition:transform .2s var(--ease-spring),border-color .2s;
}
.reader-close:hover{border-color:var(--border2)}
.reader-close:active{transform:scale(.9)}
.reader-close svg{width:20px;height:20px}

/* ── Carousel ── */
.carousel{
  --slide-scale:.34;
  display:flex;gap:16px;overflow-x:auto;padding:6px 2px 18px;
  scroll-snap-type:x mandatory;scrollbar-width:thin;
}
@media (min-width:560px){.carousel{--slide-scale:.40}}
@media (min-width:920px){.carousel{--slide-scale:.44}}
.slide-frame{
  position:relative;flex:0 0 auto;scroll-snap-align:center;
  width:calc(1080px * var(--slide-scale));
  height:calc(1080px * var(--slide-scale));
  border-radius:22px;overflow:hidden;
  box-shadow:var(--float);
}

/* ── The 1080×1080 square itself (rendered full size, scaled for preview) ── */
.slide{
  --sq-bg:#f5f5f7;
  --sq-bg2:#ffffff;
  --sq-surface:rgba(255,255,255,.72);
  --sq-border:rgba(0,0,0,.10);
  --sq-text:#1d1d1f;
  --sq-text2:#6e6e73;
  --sq-text3:#aeaeb2;
  --sq-accent:#5d8fc4;
  --sq-accent2:#d9a800;
  --sq-grad:linear-gradient(135deg,#b3cce9 0%,#8fb3dc 30%,#d9b25c 70%,#f2c200 100%);

  position:absolute;top:0;left:0;
  width:1080px;height:1080px;
  transform:scale(var(--slide-scale));transform-origin:top left;
  /* NB: no color-mix()/background-clip:text inside .slide — html2canvas can't
     parse them. Use plain rgba() and solid accent colors so PNG export is faithful. */
  background:
    radial-gradient(42% 38% at 84% 12%, rgba(130,174,219,.17) 0%, rgba(130,174,219,0) 70%),
    radial-gradient(46% 40% at 12% 92%, rgba(255,195,0,.13) 0%, rgba(255,195,0,0) 72%),
    linear-gradient(160deg, var(--sq-bg2), var(--sq-bg));
  color:var(--sq-text);
  font-family:'Inter',system-ui,sans-serif;
  padding:96px 92px;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.slide *{box-sizing:border-box}
.slide h2,.slide h3{font-family:'DM Serif Display',Georgia,serif;font-weight:400;line-height:1.04;letter-spacing:-.01em}
.slide .accent-it{font-style:italic;color:var(--sq-accent)}

/* top brand row + bottom handle row, shared by all slides */
.slide .s-top{display:flex;align-items:center;gap:14px;margin-bottom:auto}
.slide .s-mark{width:40px;height:40px;color:var(--sq-accent);flex-shrink:0}
.slide .s-brand{font-size:25px;font-weight:300;letter-spacing:.2px}
.slide .s-brand b{font-weight:700;font-style:italic;color:var(--sq-accent)}
.slide .s-eyebrow{
  margin-left:auto;font-size:18px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--sq-accent);background:var(--sq-surface);border:1px solid var(--sq-border);
  padding:10px 20px;border-radius:999px;
}
.slide .s-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:40px}
.slide .s-handle{font-size:21px;font-weight:600;color:var(--sq-text3)}
.slide .s-page{
  font-size:19px;font-weight:700;color:var(--sq-text3);
  background:var(--sq-surface);border:1px solid var(--sq-border);
  padding:8px 16px;border-radius:999px;
}

/* body block sits between top and foot, vertically centred */
.slide .s-body{flex:1;display:flex;flex-direction:column;justify-content:center;padding:48px 0}

/* optional supporting "detail" line under the main content */
.slide .s-detail{
  margin-top:38px;padding-left:28px;
  border-left:5px solid var(--sq-accent);
  font-size:25px;line-height:1.5;color:var(--sq-text3);max-width:48ch;
}
.slide[data-kind="stat"] .s-detail,
.slide[data-kind="cta"] .s-detail{
  border-left:none;padding-left:0;margin-top:26px;
  margin-left:auto;margin-right:auto;text-align:center;
}

/* template: cover */
.slide[data-kind="cover"] h2{font-size:96px;margin-bottom:30px}
.slide[data-kind="cover"] .sub{font-size:34px;color:var(--sq-text2);font-weight:500;max-width:22ch}

/* template: point */
.slide .s-num{font-family:'DM Serif Display',serif;font-size:120px;line-height:1;color:var(--sq-accent);opacity:.9;margin-bottom:26px}
.slide[data-kind="point"] h3{font-size:62px;margin-bottom:30px}
.slide[data-kind="point"] .s-text{font-size:36px;line-height:1.42;color:var(--sq-text2)}

/* template: stat */
.slide[data-kind="stat"]{text-align:center}
.slide[data-kind="stat"] .s-body{align-items:center}
.slide .s-stat{font-family:'DM Serif Display',serif;font-size:300px;line-height:.9;color:var(--sq-accent)}
.slide .s-unit{font-size:40px;font-weight:700;margin-top:8px}
.slide[data-kind="stat"] .s-text{font-size:32px;color:var(--sq-text2);margin-top:30px;max-width:24ch}

/* template: list */
.slide[data-kind="list"] h3{font-size:56px;margin-bottom:46px}
.slide .s-list{display:flex;flex-direction:column;gap:30px}
.slide .s-list li{display:flex;gap:26px;align-items:flex-start;font-size:38px;line-height:1.3;color:var(--sq-text)}
.slide .s-list .tick{
  flex:0 0 auto;width:54px;height:54px;border-radius:50%;margin-top:4px;
  background:var(--sq-grad);display:flex;align-items:center;justify-content:center;
}
.slide .s-list .tick svg{width:30px;height:30px;color:#fff}

/* template: quote */
.slide[data-kind="quote"] .s-body{justify-content:center}
.slide .s-quote{font-family:'DM Serif Display',serif;font-size:72px;line-height:1.18;letter-spacing:-.01em}
.slide .s-quote::before{content:"“";color:var(--sq-accent)}
.slide .s-quote::after{content:"”";color:var(--sq-accent)}
.slide .s-by{font-size:26px;font-weight:600;color:var(--sq-text3);margin-top:34px}

/* template: cta */
.slide[data-kind="cta"]{
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(91,99,255,.22) 0%, rgba(91,99,255,0) 70%),
    linear-gradient(160deg,#fff,var(--sq-bg2));
  text-align:center;
}
.slide[data-kind="cta"] .s-body{align-items:center}
.slide[data-kind="cta"] h3{font-size:76px;margin-bottom:30px}
.slide[data-kind="cta"] .s-text{font-size:36px;color:var(--sq-text2);max-width:22ch;margin-bottom:48px}
.slide .s-cta-handle{
  font-size:40px;font-weight:700;color:#fff;background:var(--sq-grad);
  padding:22px 46px;border-radius:999px;display:inline-block;
  box-shadow:0 18px 50px rgba(91,99,255,.40);
}

/* ════════════════════════════════════════════════════════════════════════
   Website "canvas" — a continuous, full-bleed horizontal canvas (dark, theme
   aware). Content floats freely with parallax depth and scroll-reveal as you
   scroll left↔right. No paged cards — that is the download version's job.
   ════════════════════════════════════════════════════════════════════════ */
.canvas{
  --scene-w:clamp(290px,64vw,560px);
  position:relative;width:100%;height:min(52vh,420px);
  overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;                 /* settle centred on each scene */
  scrollbar-width:none;cursor:grab;
  -webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.canvas::-webkit-scrollbar{display:none}
/* leading/trailing space so the first & last scenes can centre too */
.canvas-track{position:relative;height:100%;display:flex;padding-inline:max(0px,calc((100% - var(--scene-w)) / 2))}
/* drifting ambient aura for depth, parallaxed by --sx */
.canvas-track::before{
  content:"";position:absolute;z-index:0;top:0;bottom:0;left:-20%;right:-20%;pointer-events:none;
  background:
    radial-gradient(20% 42% at 16% 34%, color-mix(in srgb,var(--accent) 26%,transparent), transparent 70%),
    radial-gradient(22% 46% at 50% 68%, color-mix(in srgb,var(--accent2) 22%,transparent), transparent 72%),
    radial-gradient(18% 40% at 82% 30%, color-mix(in srgb,var(--accent) 20%,transparent), transparent 70%);
  transform:translateX(calc(var(--sx,0) * 1px));
}
.scene{position:relative;flex:0 0 var(--scene-w);height:100%;scroll-snap-align:center}

/* a free-floating canvas item, positioned by % within its scene */
.ci{position:absolute;z-index:1;max-width:86%;will-change:transform,opacity,filter}
.ci.center{left:0!important;width:100%;max-width:none;text-align:center;padding:0 6%}
.ci-eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  border:1px solid var(--glass-border);background:var(--glass);padding:7px 14px;border-radius:999px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.ci-hero{font-family:'DM Serif Display',serif;font-size:clamp(31px,5.6vw,62px);line-height:1.03;letter-spacing:-.015em;color:var(--text)}
.ci .accent-it{font-style:italic;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ci-sub{font-size:clamp(15px,1.9vw,20px);line-height:1.4;color:var(--text2)}
.ci-ghost{font-family:'DM Serif Display',serif;font-size:clamp(96px,17vw,190px);line-height:.8;color:var(--accent);opacity:.12;z-index:0}
.ci-head{font-family:'DM Serif Display',serif;font-size:clamp(25px,4vw,44px);line-height:1.08;color:var(--text)}
.ci-text{font-size:clamp(14px,1.7vw,19px);line-height:1.5;color:var(--text2)}
.ci-detail{font-size:clamp(12.5px,1.4vw,16px);line-height:1.5;color:var(--text3);padding-left:16px;border-left:3px solid var(--accent)}
.ci.center.ci-detail{border-left:none;padding-left:0}
.ci-stat{font-family:'DM Serif Display',serif;font-size:clamp(92px,16vw,180px);line-height:.85;
  background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ci-unit{font-size:clamp(18px,2.3vw,30px);font-weight:700;color:var(--text)}
.ci-quote{font-family:'DM Serif Display',serif;font-size:clamp(24px,3.6vw,42px);line-height:1.22;color:var(--text)}
.ci-quote::before{content:"\201C";color:var(--accent)}
.ci-quote::after{content:"\201D";color:var(--accent)}
.ci-by{font-size:clamp(14px,1.7vw,18px);font-weight:600;color:var(--text3)}
.ci-listblock{display:flex;flex-direction:column;gap:clamp(10px,1.3vw,16px)}
.ci-listblock .li{display:flex;gap:13px;align-items:flex-start;font-size:clamp(14px,1.8vw,21px);color:var(--text);line-height:1.3}
.ci-listblock .tk{flex:0 0 auto;width:clamp(22px,2.6vw,32px);height:clamp(22px,2.6vw,32px);border-radius:50%;
  background:var(--accent-grad);display:flex;align-items:center;justify-content:center;margin-top:2px}
.ci-listblock .tk svg{width:58%;height:58%;color:var(--on-accent)}
.ci-pill{display:inline-block;font-size:clamp(15px,1.8vw,21px);font-weight:700;color:var(--on-accent);
  background:var(--accent-grad);padding:13px 28px;border-radius:999px;box-shadow:0 14px 40px var(--glow)}

/* Apple-style scene indicators (dots that elongate for the current scene) */
.canvas-dots{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin:18px auto 0;padding:0 16px;max-width:92%}
.cdot{
  width:8px;height:8px;padding:0;border:none;border-radius:999px;cursor:pointer;
  background:var(--text3);opacity:.4;
  transition:width .4s var(--ease-spring),opacity .3s,background .3s;
}
.cdot:hover{opacity:.7}
.cdot.active{width:26px;opacity:1;background:var(--accent-grad)}

@media (prefers-reduced-motion:reduce){
  .ci{transform:none!important;filter:none!important;opacity:1!important}
  .canvas-track::before{transform:none!important}
}

/* ── Studio: the download version (clean export squares + tools) ── */
.export-block{margin-top:30px;padding-top:22px;border-top:1px dashed var(--border2)}
.export-label{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);margin-bottom:14px}
.export-label svg{width:15px;height:15px;color:var(--accent)}
.export-block .export-strip{--slide-scale:.20}
@media (min-width:560px){.export-block .export-strip{--slide-scale:.22}}

/* ── Studio mode (owner only) ── */
.studio-banner{
  max-width:880px;margin:0 auto 30px;padding:14px 22px;border-radius:var(--r);
  background:var(--glass-strong);border:1px solid var(--glass-border);
  display:flex;align-items:center;gap:14px;font-size:14px;color:var(--text2);
  box-shadow:var(--float-sm);
}
.studio-banner b{color:var(--accent)}
.studio-banner .grow{flex:1}
.slide-frame .dl{
  position:absolute;top:10px;right:10px;z-index:3;
  display:flex;align-items:center;gap:7px;
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;
  color:#fff;background:rgba(20,18,30,.62);border:1px solid rgba(255,255,255,.18);
  padding:7px 12px;border-radius:999px;cursor:pointer;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:background .2s,transform .15s var(--ease-spring);
}
.slide-frame .dl:hover{background:rgba(20,18,30,.82)}
.slide-frame .dl:active{transform:scale(.94)}
.slide-frame .dl svg{width:15px;height:15px}
.post-tools{display:flex;gap:10px;flex-wrap:wrap}
.post-tools button{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  padding:9px 16px;border-radius:999px;cursor:pointer;
  background:var(--glass);border:1px solid var(--glass-border);color:var(--text);
  transition:transform .15s var(--ease-spring),border-color .2s;
}
.post-tools button:hover{border-color:var(--border2)}
.post-tools button:active{transform:scale(.95)}

@media (max-width:680px){
  .blog-wrap{padding:0 18px}
}
