/* Cairn — shared brand styles. Imported in every page. */
:root{
  --paper:#F4EFE5;            /* warm kraft */
  --paper2:#EFE8D9;
  --ink:#1F1B14;
  --moss:#2C4F3A;             /* primary green */
  --moss-deep:#1F3C2A;
  --stone:#B89A6C;            /* warm tan accent */
  --stone-deep:#8E754D;
  --sky:#5F86B0;              /* rare cool accent */
  --sage:#E3E6DC;             /* callout bg */
  --ember:#A24E2F;            /* urgent callout */
  --ink70:rgba(31,27,20,.72);
  --ink55:rgba(31,27,20,.55);
  --ink40:rgba(31,27,20,.40);
  --hair:rgba(31,27,20,.16);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Source Sans 3',Seravek,Arial,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.66;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:880px;margin:0 auto;padding:0 28px;}
.wide{max-width:1080px;margin:0 auto;padding:0 28px;}

/* nav */
nav{border-bottom:.75pt solid var(--hair);background:var(--paper);position:sticky;top:0;z-index:50;}
nav .wide{display:flex;align-items:center;justify-content:space-between;height:68px;}
.wordmark{
  font-family:'Fraunces',Georgia,serif;
  font-weight:550;font-size:20px;letter-spacing:.20em;
  color:var(--moss);text-decoration:none;display:flex;gap:10px;align-items:center;
}
.wordmark .mark{width:22px;height:22px;display:inline-block;}
nav .links{display:flex;gap:24px;align-items:center;}
nav .links a{color:var(--moss);text-decoration:none;font-size:15px;font-weight:600;}
nav .links a:hover{text-decoration:underline;text-decoration-color:var(--stone);text-underline-offset:5px;text-decoration-thickness:1.5px;}
nav .buy{font-weight:700;border:1.5px solid var(--moss);padding:8px 16px;border-radius:0;}

/* type */
.eyebrow{
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--stone-deep);font-weight:700;
}
h1{
  font-family:'Fraunces',Georgia,serif;font-weight:500;color:var(--moss);
  font-size:50px;line-height:1.04;margin:18px 0 18px;letter-spacing:-.01em;
}
h2{
  font-family:'Fraunces',Georgia,serif;font-weight:500;color:var(--moss);
  font-size:28px;margin:40px 0 12px;line-height:1.15;
}
h3{
  font-family:'Fraunces',Georgia,serif;font-weight:550;color:var(--moss);
  font-size:21px;margin:28px 0 8px;line-height:1.2;
}
p{margin-bottom:16px;}
ul,ol{padding-left:1.3em;margin-bottom:16px;}
li{margin-bottom:9px;}
a{color:var(--moss);text-decoration:underline;text-decoration-color:var(--stone);text-underline-offset:3px;text-decoration-thickness:1.2px;}
strong{font-weight:700;color:var(--ink);}
em{font-style:italic;}

/* hero */
header.top{padding:60px 0 28px;}
.standfirst{font-size:21px;color:var(--ink70);max-width:34em;}
.byline{font-size:14px;color:var(--ink55);margin:6px 0 30px;}

/* blog index list */
.list{padding:14px 0 80px;}
.row{
  display:flex;gap:32px;align-items:center;
  text-decoration:none;color:inherit;padding:30px 0;
  border-top:.75pt solid var(--hair);
}
.row:first-child{border-top:none;}
.row .art{flex:0 0 170px;}
.row .art img{width:100%;height:auto;display:block;border:.75pt solid var(--hair);transition:transform .3s ease;}
.row:hover .art img{transform:scale(1.03) rotate(-.4deg);}
.row .cat{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-deep);font-weight:700;}
.row h2{font-size:26px;margin:8px 0 8px;}
.row:hover h2{text-decoration:underline;text-decoration-color:var(--stone);text-underline-offset:5px;text-decoration-thickness:1.5px;}
.row p{color:var(--ink70);font-size:16px;max-width:36em;margin:0;}

/* article body */
article{padding:54px 0 30px;}
article .figure{margin:28px 0;}
article .figure img{width:100%;border:.75pt solid var(--hair);}
article .figure figcaption{font-size:13.5px;color:var(--ink55);margin-top:8px;font-style:italic;}
article .standfirst{font-size:21px;color:var(--ink70);margin:0 0 12px;}
article .byline{border-bottom:.75pt solid var(--hair);padding-bottom:24px;margin-bottom:30px;}

/* callout boxes */
.pull{
  background:var(--sage);border-top:2.5px solid var(--moss);
  padding:20px 22px;margin:24px 0;
}
.pull .who{font-size:12px;letter-spacing:.18em;color:var(--moss);font-weight:700;text-transform:uppercase;margin-bottom:8px;}
.pull p{font-family:'Fraunces',Georgia,serif;font-size:19px;line-height:1.55;margin:0;color:var(--ink);}
.flag{
  background:#F8EFEA;border-top:2.5px solid var(--ember);
  padding:18px 22px;margin:22px 0;
}
.flag .who{font-size:12px;letter-spacing:.18em;color:var(--ember);font-weight:700;text-transform:uppercase;margin-bottom:8px;}
.src{font-size:14px;color:var(--ink55);line-height:1.55;}

/* app promo box */
.appbox{
  background:var(--moss);color:var(--paper);
  padding:34px 34px 38px;margin:48px 0 16px;
}
.appbox .eyebrow{color:#E4C58C;}
.appbox h2{color:var(--paper);margin:10px 0 10px;font-size:28px;}
.appbox p{color:rgba(244,239,229,.85);}
.btn{
  display:inline-block;background:#E4C58C;color:var(--moss);
  text-decoration:none;font-weight:700;font-size:17px;padding:14px 26px;
  margin-top:10px;
}
.btn:hover{background:#F5D89C;}

/* home */
.hero{
  padding:68px 0 30px;
  border-bottom:.75pt solid var(--hair);
}
.hero h1{font-size:62px;letter-spacing:-.015em;max-width:14em;}
.hero .standfirst{font-size:22px;max-width:38em;margin-top:18px;}
.cta-row{margin-top:30px;display:flex;gap:16px;flex-wrap:wrap;}
.cta-row .btn{background:var(--moss);color:var(--paper);}
.cta-row .btn.ghost{background:transparent;color:var(--moss);border:1.5px solid var(--moss);}

.section{padding:56px 0;border-bottom:.75pt solid var(--hair);}
.section h2.bighead{font-size:38px;margin:0 0 10px;}
.section .sub{font-size:18px;color:var(--ink70);max-width:34em;}

/* feature grid */
.fgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:32px;}
.fgrid .card{
  background:var(--paper2);padding:26px 26px 28px;
  border:.75pt solid var(--hair);
}
.fgrid .card h3{margin:0 0 8px;color:var(--moss);font-size:22px;}
.fgrid .card p{margin:0;color:var(--ink70);font-size:16.5px;}

/* apps grid */
.appgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px;}
.appgrid .acard{
  background:var(--paper2);border:.75pt solid var(--hair);
  padding:24px;text-decoration:none;color:inherit;
}
.appgrid .acard h3{font-size:21px;color:var(--moss);margin:8px 0 4px;}
.appgrid .acard .icon{display:block;width:64px;height:64px;background:var(--sage);border:.75pt solid var(--hair);display:grid;place-items:center;font-size:32px;}
.appgrid .acard .status{font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-deep);font-weight:700;}
.appgrid .acard p{margin:6px 0 0;color:var(--ink70);font-size:15.5px;}
.appgrid .acard.live{background:#EFE6CF;}
.appgrid .acard.live .status{color:var(--moss);}

/* footer */
footer{border-top:.75pt solid var(--hair);margin-top:0;background:var(--paper2);}
footer .wide{padding:32px 28px;display:flex;gap:22px;flex-wrap:wrap;font-size:14px;color:var(--ink70);align-items:center;}
footer .wordmark{font-size:16px;letter-spacing:.20em;}
footer a{color:var(--ink70);text-decoration:none;}
footer a:hover{color:var(--moss);text-decoration:underline;}

@media(max-width:760px){
  body{font-size:17px;}
  .hero h1{font-size:42px;}
  h1{font-size:38px;}
  h2{font-size:24px;}
  .section h2.bighead{font-size:28px;}
  .fgrid,.appgrid{grid-template-columns:1fr;}
  .row{gap:18px;padding:22px 0;}
  .row .art{flex:0 0 104px;}
  .row h2{font-size:20px;}
  .row p{display:none;}
  nav .links a:not(.buy){display:none;}
}

/* fonts */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Source+Sans+3:ital,wght@0,400;0,600;0,700;1,400&display=swap');

.acard .icon{line-height:0;display:block;margin-bottom:14px;}
.acard .icon img{width:62px;height:62px;display:block;}

/* ============ expandable game cards (Game / Science / Result) ============ */
.gamegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px;align-items:start;}
@media(max-width:900px){.gamegrid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.gamegrid{grid-template-columns:1fr;}}
.gcard{display:flex;flex-direction:column;background:#EFE8D9;border:.75pt solid var(--hair);padding:22px 22px 20px;text-decoration:none;color:inherit;border-radius:2px;transition:box-shadow .25s ease,transform .25s ease,border-color .25s ease;}
.gcard:hover,.gcard:focus-within{box-shadow:0 14px 34px rgba(31,27,20,.13);transform:translateY(-3px);border-color:var(--stone);}
.gcard.live{background:#EAE0C6;}
.gcard .ghead{display:flex;align-items:flex-start;gap:14px;}
.gcard .ghead img{width:56px;height:56px;display:block;flex:0 0 56px;}
.gcard .gtop{flex:1;}
.gcard .status{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-deep);font-weight:700;}
.gcard.live .status{color:var(--moss);}
.gcard h3{font-size:22px;color:var(--moss);margin:3px 0 2px;line-height:1.1;}
.gcard .dom{font-size:13px;color:var(--ink55);font-weight:600;}
.gcard .blurb{margin:14px 0 0;color:var(--ink70);font-size:15.5px;line-height:1.5;min-height:4.5em;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
/* the reveal */
.gmore{overflow:hidden;}
@media(hover:hover){
  .gmore{max-height:0;opacity:0;transition:max-height .35s ease,opacity .3s ease,margin .35s ease;margin-top:0;}
  .gcard:hover .gmore,.gcard:focus-within .gmore{max-height:640px;opacity:1;margin-top:16px;}
}
@media(hover:none){.gmore{max-height:none;opacity:1;margin-top:16px;}}
.facets{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;border-top:.75pt solid var(--hair);border-bottom:.75pt solid var(--hair);padding:12px 0;margin-bottom:14px;}
.facets div{font-size:12.5px;color:var(--ink70);line-height:1.32;}
.facets .fl{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-deep);font-weight:700;margin-bottom:3px;}
.stars{display:flex;align-items:center;gap:7px;margin-bottom:10px;}
.stars .s{color:var(--stone);font-size:11px;letter-spacing:1px;font-weight:700;}
.stars .pip{font-size:15px;letter-spacing:2px;}
.stars .pip .on{color:#E0A92E;}
.stars .pip .off{color:var(--ink40);}
.quote{font-size:14px;line-height:1.5;color:var(--ink);margin:0 0 10px;padding-left:13px;border-left:2px solid var(--stone);}
.quote .by{display:block;font-size:11.5px;color:var(--ink55);font-weight:600;margin-top:3px;}
.quote.kid{border-left-color:var(--moss);}
.sass{font-size:12.5px;color:var(--stone-deep);font-style:italic;line-height:1.45;margin:10px 0 14px;}
.gcard .more-link{font-size:14px;font-weight:700;color:var(--moss);text-decoration:none;}
.gcard .more-link:hover{text-decoration:underline;text-underline-offset:4px;}
.gnote{font-size:13px;color:var(--ink55);line-height:1.55;margin-top:26px;border-top:.75pt solid var(--hair);padding-top:16px;}

/* ============ per-game page: age ladder + companion ============ */
.agechips{display:flex;gap:8px;margin:14px 0 4px;flex-wrap:wrap;}
.agechips span{font-size:13px;font-weight:700;color:var(--moss);background:var(--sage);border:.75pt solid var(--hair);padding:5px 13px;border-radius:20px;}
.ageband{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:26px;}
@media(max-width:680px){.ageband{grid-template-columns:1fr;}}
.agecard{background:#fff;border:.75pt solid var(--hair);padding:22px;}
.agecard .ah{display:flex;align-items:baseline;gap:10px;margin-bottom:14px;}
.agecard .an{font-family:'Fraunces',Georgia,serif;font-size:38px;color:var(--moss);line-height:1;font-weight:600;}
.agecard .al{font-size:13px;color:var(--ink55);font-weight:600;}
.agecard .bit{margin:0 0 12px;}
.agecard .bit:last-child{margin-bottom:0;}
.agecard .lab{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:3px;}
.agecard .lab.dev{color:var(--stone-deep);}
.agecard .lab.game{color:var(--moss);}
.agecard .lab.home{color:var(--ember);}
.agecard .bit p{margin:0;font-size:15px;color:var(--ink70);line-height:1.5;}
.reviews{background:var(--sage);border:.75pt solid var(--hair);padding:26px;margin-top:30px;}
.reviews .stars{margin-bottom:16px;}
.reviews .quote{font-size:16px;}
.noreviews{background:var(--sage);border:.75pt solid var(--hair);padding:26px;margin-top:30px;font-size:16px;color:var(--ink70);line-height:1.55;}

/* ---- scene illustrations (Canva) ---- */
.gbanner{height:158px;margin:-22px -22px 16px;overflow:hidden;background:var(--paper2);border-bottom:.75pt solid var(--hair);}
.gcard.live .gbanner{background:#E4D9BE;}
.gbanner img{width:100%;height:100%;object-fit:cover;object-position:center 56%;display:block;transition:transform .5s ease;}
.gcard:hover .gbanner img,.gcard:focus-within .gbanner img{transform:scale(1.045);}
.gcard .ghead .gi{width:46px;height:46px;flex:0 0 46px;}
.scene-hero{margin:26px 0 6px;text-align:center;}
.scene-hero img{max-width:430px;width:100%;height:auto;display:inline-block;border:.75pt solid var(--hair);border-radius:3px;background:var(--paper2);box-shadow:0 10px 30px rgba(31,27,20,.10);}
/* ---- homepage illustrated hero ---- */
.herowrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;}
@media(max-width:820px){.herowrap{grid-template-columns:1fr;gap:18px;}.herofig{order:-1;}}
.herofig img{width:100%;height:auto;display:block;border:.75pt solid var(--hair);border-radius:4px;box-shadow:0 18px 44px rgba(31,27,20,.14);}

/* ---- App Store comparison ---- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:30px;border:.75pt solid var(--hair);}
@media(max-width:640px){.compare{grid-template-columns:1fr;}}
.compare .col{padding:30px 28px;}
.compare .them{background:#efe8d9;}
.compare .us{background:var(--moss);color:var(--paper);}
.compare h3{font-size:14px;letter-spacing:.04em;margin:0 0 18px;text-transform:uppercase;font-weight:700;}
.compare .them h3{color:var(--ember);}
.compare .us h3{color:var(--gold,#FFD27A);}
.compare ul{list-style:none;margin:0;padding:0;}
.compare li{font-size:16px;line-height:1.4;padding:11px 0 11px 30px;position:relative;border-top:.75pt solid var(--hair);}
.compare .us li{border-top-color:rgba(244,239,229,.18);color:rgba(244,239,229,.92);}
.compare li:first-child{border-top:none;}
.compare .them li::before{content:"\2715";position:absolute;left:0;color:var(--ember);font-weight:700;}
.compare .us li::before{content:"\2713";position:absolute;left:0;color:#9be0ad;font-weight:700;}
/* ---- email capture ---- */
.capture{background:var(--moss-deep);color:var(--paper);padding:46px 34px;text-align:center;margin-top:8px;border-radius:3px;}
.capture h2{color:var(--paper);font-size:30px;margin:0 0 10px;}
.capture p{color:rgba(244,239,229,.82);max-width:32em;margin:0 auto 22px;font-size:17px;}
.capture .btn{display:inline-block;}
.capture .fine{font-size:13px;color:rgba(244,239,229,.6);margin-top:16px;}

/* ============================================================
   DESIGN ELEVATION PASS (June 11, 2026) — bespoke editorial polish.
   Appended last so it intentionally refines the base rules above.
   ============================================================ */
body{
  background-image:url('/img/grain.png');
  background-repeat:repeat;
  font-feature-settings:"liga" 1,"calt" 1;
}
:root{ --gold:#FFB700; --gold-soft:#E4C58C; }

/* Fraunces optical sizing everywhere it is used */
.wordmark,h1,h2,h3,.pull p,.an,.scene-hero figcaption{font-optical-sizing:auto;}

/* eyebrow gets a short stone rule: an editorial signature */
.eyebrow{display:inline-flex;align-items:center;gap:11px;}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--stone);flex:0 0 24px;}
.appbox .eyebrow::before{background:var(--gold-soft);}

/* display type: more confident, tighter, with room to breathe */
.hero h1{font-size:clamp(44px,6vw,72px);line-height:1.0;letter-spacing:-.02em;font-weight:540;}
.hero h1 em{font-style:italic;color:var(--stone-deep);}
.section h2.bighead{font-size:clamp(30px,4vw,42px);letter-spacing:-.015em;line-height:1.08;}
.standfirst{line-height:1.5;}

/* glassy sticky nav */
nav{background:rgba(244,239,229,.82);backdrop-filter:saturate(1.15) blur(8px);-webkit-backdrop-filter:saturate(1.15) blur(8px);}
nav .buy{transition:background .18s ease,color .18s ease;}
nav .buy:hover{background:var(--moss);color:var(--paper);text-decoration:none;}

/* crafted buttons: lift + shadow + animated arrow */
.btn{border-radius:2px;transition:transform .18s ease,box-shadow .2s ease,background .18s ease;}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(31,27,20,.18);}
.cta-row .btn.ghost:hover{background:var(--moss);color:var(--paper);}

/* section rhythm: alternating warmth + generous space */
.section{padding:74px 0;}
.section.alt{background:var(--paper2);}
.hero{padding:76px 0 36px;}

/* the new card science/game bullets, with a stone-pebble marker */
.gsec{margin-bottom:14px;}
.glabel{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-deep);font-weight:700;margin-bottom:8px;}
.gsec:nth-of-type(2) .glabel{color:var(--moss);}
.stonelist{list-style:none;padding:0;margin:0;}
.stonelist li{position:relative;padding-left:20px;margin-bottom:7px;font-size:14.5px;line-height:1.42;color:var(--ink70);}
.stonelist li::before{content:"";position:absolute;left:0;top:8px;width:10px;height:7px;border-radius:60%;background:var(--stone);}
.gsec:nth-of-type(2) .stonelist li::before{background:var(--gold);}
.gcard .gmore .stars{margin:14px 0 8px;padding-top:12px;border-top:.75pt solid var(--hair);}
@media(hover:hover){ .gcard:hover .gmore,.gcard:focus-within .gmore{max-height:900px;} }

/* elevated footer: a quiet moss band to close every page */
footer{background:var(--moss);border-top:none;}
footer .wide{padding:40px 28px;color:rgba(244,239,229,.7);}
footer .wordmark{color:var(--paper);}
footer a{color:rgba(244,239,229,.82);}
footer a:hover{color:#fff;text-decoration:underline;text-underline-offset:4px;}
footer span{color:rgba(244,239,229,.5);}

/* refined figure captions + rules */
hr,.rule{border:none;border-top:.75pt solid var(--hair);}

/* personality aside at the end of a card's game list */
.gaside{margin:9px 0 2px;padding-left:20px;position:relative;font-size:14px;font-weight:700;color:var(--moss);line-height:1.4;}
.gaside::before{content:"";position:absolute;left:0;top:5px;width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(255,183,0,.20);}
.gcard .gmore .stonelist li strong{color:var(--ink);font-weight:700;}

/* ---- The Problem page ---- */
.problem-lede{font-size:clamp(22px,2.6vw,27px);line-height:1.45;color:var(--ink);max-width:20em;font-family:'Fraunces',Georgia,serif;font-weight:480;margin:14px 0 4px;}
.statband{display:grid;grid-template-columns:repeat(3,1fr);border:.75pt solid var(--hair);margin:40px 0;background:var(--paper2);}
@media(max-width:760px){.statband{grid-template-columns:1fr;}}
.stat{padding:34px 26px;border-right:.75pt solid var(--hair);}
.stat:last-child{border-right:none;}
@media(max-width:760px){.stat{border-right:none;border-bottom:.75pt solid var(--hair);} .stat:last-child{border-bottom:none;}}
.stat .n{font-family:'Fraunces',Georgia,serif;font-size:clamp(46px,5vw,60px);line-height:.95;color:var(--ember);font-weight:560;letter-spacing:-.02em;font-optical-sizing:auto;}
.stat .l{font-size:16px;color:var(--ink);margin:12px 0 0;font-weight:600;line-height:1.38;}
.stat .ssrc{font-size:12px;color:var(--ink55);margin-top:9px;letter-spacing:.01em;}
.case h2{font-size:clamp(24px,3vw,32px);margin:46px 0 10px;}
.case p{font-size:18px;color:var(--ink70);max-width:34em;}
.case .jab{font-family:'Fraunces',Georgia,serif;font-style:italic;color:var(--stone-deep);font-size:20px;margin-top:6px;}
.turn{background:var(--moss);color:var(--paper);padding:56px 0;margin-top:56px;}
.turn .wrap{max-width:880px;}
.turn .eyebrow{color:var(--gold-soft);}
.turn h2{color:var(--paper);font-size:clamp(28px,3.4vw,38px);margin:10px 0 14px;max-width:16em;}
.turn p{color:rgba(244,239,229,.86);font-size:18px;max-width:34em;}
.turn .promises{list-style:none;padding:0;margin:22px 0 28px;display:grid;grid-template-columns:1fr 1fr;gap:10px 26px;max-width:30em;}
@media(max-width:600px){.turn .promises{grid-template-columns:1fr;}}
.turn .promises li{position:relative;padding-left:24px;color:var(--paper);font-weight:600;font-size:16px;margin:0;}
.turn .promises li::before{content:"";position:absolute;left:0;top:8px;width:10px;height:7px;border-radius:60%;background:var(--gold);}
.turn .btn{background:var(--gold-soft);color:var(--moss);}
.turn .btn.ghost{background:transparent;color:var(--paper);border:1.5px solid rgba(244,239,229,.5);}

/* trademark marks */
.tm{font-size:0.5em;vertical-align:super;letter-spacing:0;font-weight:600;margin-left:1px;line-height:0;}
footer .tmnote{display:block;flex-basis:100%;width:100%;font-size:11.5px;color:rgba(244,239,229,.5);margin-top:14px;letter-spacing:.02em;line-height:1.5;}
