/* =====================================================================
   みんなのインディー — Riso Punk shared stylesheet
   Used by: home-riso.html / home-riso-games.html / home-riso-article.html
   ===================================================================== */

:root{
  --ink:#141414;
  --paper:#efe7d6;
  --riso:#1f2bff;
  --riso-2:#0a16d8;
  --riso-soft:#7e88ff;
  --jp:"Zen Kaku Gothic New",sans-serif;
  --lat:"Archivo",sans-serif;
  --mono:"Space Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased}
html,body{overflow-x:hidden}
body{font-family:var(--jp);color:var(--ink);background:var(--paper);line-height:1.5;position:relative}
/* paper grain + halftone wash */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9;mix-blend-mode:multiply;opacity:.5;
  background:radial-gradient(rgba(0,0,0,.16) 1px,transparent 1.4px);background-size:4px 4px}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 30px}
.mono{font-family:var(--mono)}

/* halftone fill used for image placeholders */
.halftone{position:absolute;inset:0;
  background-color:#d8cfbb;
  background-image:
    radial-gradient(var(--riso) 32%,transparent 33%),
    radial-gradient(rgba(0,0,0,.55) 30%,transparent 31%);
  background-size:9px 9px,7px 7px;
  background-position:0 0,3px 4px;
  mix-blend-mode:multiply}

/* ---------- Top strip ---------- */
.strip{background:var(--riso);color:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;overflow:hidden;border-bottom:3px solid var(--ink)}
.strip .t{display:flex;gap:34px;white-space:nowrap;padding:7px 0;animation:sc 26s linear infinite}
.strip .t span{display:inline-flex;gap:34px}
@keyframes sc{to{transform:translateX(-50%)}}

/* ---------- Header ---------- */
header.top{background:var(--paper);border-bottom:3px solid var(--ink);position:relative;z-index:10}
header.top .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
header.top .logo{height:40px}
nav{display:flex;align-items:center;gap:2px}
nav a{font-weight:900;font-size:14px;padding:9px 13px;transition:.1s}
nav a:hover{background:var(--ink);color:var(--paper);transform:rotate(-2deg)}
nav .search{margin-left:8px;font-family:var(--mono);font-size:12px;border:2px solid var(--ink);padding:8px 12px;font-weight:700;background:#fff}
.burger{display:none;width:48px;height:42px;border:2px solid var(--ink);background:#fff;cursor:pointer;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:5px;box-shadow:3px 3px 0 var(--ink)}
.burger span{display:block;width:22px;height:2.5px;background:var(--ink);transition:.2s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Hero (home) ---------- */
.hero{position:relative;border-bottom:3px solid var(--ink);padding:40px 0 50px;z-index:1}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.hero .tape{display:inline-block;background:var(--riso);color:#fff;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:7px 16px;transform:rotate(-2deg);box-shadow:3px 3px 0 var(--ink);margin:4px 0 26px 4px}
.hero h1{font-weight:900;font-size:clamp(30px,4.4vw,46px);line-height:1.4;letter-spacing:-.005em;text-wrap:balance}
.hero h1 .hl{background:var(--riso);color:#fff;padding:.08em 8px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.hero h1 .en{font-family:var(--lat);font-style:italic}
.hero .meta{margin-top:24px;font-family:var(--mono);font-size:12px;display:flex;gap:16px;flex-wrap:wrap;color:#333}
.hero .meta b{color:var(--riso-2)}
.hero .read{margin-top:26px;display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:var(--paper);font-weight:900;font-size:15px;padding:13px 24px;box-shadow:4px 4px 0 var(--riso);transition:.12s}
.hero .read:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--riso)}
.hero .art{position:relative;border:3px solid var(--ink);aspect-ratio:4/3;overflow:hidden;transform:rotate(1.4deg);box-shadow:6px 6px 0 var(--ink)}
.hero .art .stamp{position:absolute;right:0;bottom:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;z-index:2}

/* ---------- Page head (archive / article) ---------- */
.pagehead{position:relative;z-index:1;border-bottom:3px solid var(--ink);padding:36px 0 30px}
.pagehead .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#555;margin-bottom:18px;display:flex;gap:8px;flex-wrap:wrap}
.pagehead .crumb a:hover{color:var(--riso-2)}
.pagehead .crumb .sep{color:#aaa}
.pagehead .big{font-family:var(--lat);font-weight:900;font-size:clamp(48px,9vw,104px);line-height:.94;letter-spacing:-.02em;text-transform:uppercase}
.pagehead .big .o{color:var(--paper);-webkit-text-stroke:2.5px var(--ink)}
.pagehead .sub{display:flex;align-items:center;gap:14px;margin-top:14px;flex-wrap:wrap}
.pagehead .sub h1{font-weight:900;font-size:clamp(17px,2.2vw,22px)}
.pagehead .sub .count{font-family:var(--mono);font-size:12px;color:#444;border:2px solid var(--ink);padding:4px 10px}

/* ---------- Chips (filters) ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px;padding:26px 0 6px;position:relative;z-index:1}
.chip{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.04em;border:2px solid var(--ink);background:#fff;padding:9px 15px;cursor:pointer;transition:.1s;text-transform:uppercase;color:var(--ink)}
.chip:hover{transform:translateY(-2px)}
.chip[aria-pressed="true"]{background:var(--riso);color:#fff}

/* ---------- Section head ---------- */
.sec{position:relative;z-index:1}
.sechead{display:flex;align-items:center;gap:18px;padding:34px 0 22px}
.sechead .big{font-family:var(--lat);font-weight:900;font-size:clamp(34px,5vw,58px);line-height:1;letter-spacing:-.02em;text-transform:uppercase}
.sechead .big .o{color:var(--paper);-webkit-text-stroke:2px var(--ink)}
.sechead .jp{font-weight:900;font-size:16px}
.sechead .rule{flex:1;height:3px;background:var(--ink)}
.sechead .all{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:8px 16px}

/* ---------- Cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;padding-bottom:46px}
.card{background:#fff;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);display:flex;flex-direction:column;transition:.12s}
.card:nth-child(3n-1){transform:rotate(-.7deg)}
.card:nth-child(3n){transform:rotate(.6deg)}
.card:hover{transform:translate(-2px,-3px) rotate(0);box-shadow:8px 9px 0 var(--riso)}
.card .pic{position:relative;aspect-ratio:16/10;border-bottom:3px solid var(--ink);overflow:hidden}
.card .no{position:absolute;left:0;top:0;background:var(--riso);color:#fff;font-family:var(--lat);font-weight:900;font-size:19px;padding:5px 12px;border-right:3px solid var(--ink);border-bottom:3px solid var(--ink);z-index:2}
.card .tag{position:absolute;right:8px;top:8px;background:#fff;border:2px solid var(--ink);font-family:var(--mono);font-weight:700;font-size:11px;padding:3px 8px;transform:rotate(2.5deg);z-index:2}
.card .body{padding:16px 17px 20px;display:flex;flex-direction:column;gap:11px;flex:1}
.card .date{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#666}
.card h3{font-weight:900;font-size:18px;line-height:1.42}
.card .more{margin-top:auto;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;gap:7px;color:var(--riso-2)}

/* ---------- Ad slot (display placements — keeps the zine vibe) ---------- */
.pr-wrap{position:relative;z-index:1;padding-bottom:46px}
.pr-unit{position:relative;display:flex;flex-direction:column;background:#fbf8f0;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);overflow:hidden}
.pr-unit .lab{position:absolute;left:0;top:0;z-index:2;font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:var(--riso);color:#fff;padding:5px 11px;border-right:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.pr-unit .corner{position:absolute;right:8px;top:8px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#999}
.pr-unit .grain{position:absolute;inset:0;opacity:.45;mix-blend-mode:multiply;pointer-events:none;
  background:radial-gradient(rgba(0,0,0,.14) 1px,transparent 1.5px);background-size:6px 6px}
.pr-unit .inner{position:relative;z-index:1;flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:7px;color:#3a3a3a}
.pr-unit .inner .t{font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase}
.pr-unit .inner .s{font-family:var(--mono);font-size:11px;color:#8a8a8a;letter-spacing:.04em}
.pr-unit.lead .inner{min-height:120px;padding:22px}
.pr-unit.rect .inner{min-height:280px;padding:24px}
.pr-unit.feed{min-height:330px;text-align:center}
.pr-unit.feed .inner{min-height:0;padding:24px}

/* ---------- Pager ---------- */
.pager{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;padding:6px 0 64px;position:relative;z-index:1}
.pager a,.pager span{font-family:var(--mono);font-weight:700;font-size:14px;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:2px solid var(--ink);background:#fff;padding:0 12px}
.pager a:hover{background:var(--ink);color:var(--paper)}
.pager .cur{background:var(--riso);color:#fff}
.pager .ends{font-size:11px;letter-spacing:.06em;text-transform:uppercase}

/* ---------- Article ---------- */
.article{position:relative;z-index:1;padding:42px 0 14px}
.article .col{max-width:740px;margin:0 auto}
.article .amap{display:flex;flex-wrap:wrap;gap:12px;align-items:center;font-family:var(--mono);font-size:12px;color:#444;margin-top:20px}
.article .amap .av{width:34px;height:34px;border:2px solid var(--ink);background:var(--riso);position:relative;overflow:hidden}
.article .amap .av .halftone{background-color:var(--riso)}
.article .amap b{color:var(--ink);font-weight:700}
.figure{margin:32px 0;border:3px solid var(--ink);box-shadow:6px 6px 0 var(--ink);position:relative;overflow:hidden}
.figure .ph{position:relative;aspect-ratio:16/9}
.figure figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:#555;padding:11px 13px;border-top:3px solid var(--ink);background:#fff}
.prose p{font-size:17px;line-height:2;margin:0 0 22px;color:#1d1d1d}
.prose .lead{font-size:19px;line-height:1.95;font-weight:500;color:#111}
.prose h2{font-weight:900;font-size:25px;margin:42px 0 16px;display:flex;align-items:center;gap:12px;line-height:1.4}
.prose h2::before{content:"";width:15px;height:24px;background:var(--riso);display:inline-block;border:2px solid var(--ink);flex:none}
.prose h3{font-weight:900;font-size:19px;margin:30px 0 12px}
.prose ul{margin:0 0 22px;list-style:none;display:flex;flex-direction:column;gap:11px}
.prose ul li{position:relative;padding-left:26px;font-size:16px;line-height:1.8}
.prose ul li::before{content:"▶";position:absolute;left:0;top:.2em;color:var(--riso-2);font-size:11px}
.prose a.ilink{color:var(--riso-2);font-weight:700;border-bottom:2px solid var(--riso-soft)}
.pullquote{margin:36px 0;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);padding:26px 0;font-weight:900;font-size:24px;line-height:1.6}
.pullquote .mk{background:var(--riso);color:#fff;padding:0 7px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.specbox{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;margin:32px 0}
.specbox .h{background:var(--ink);color:var(--paper);font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:10px 14px}
.specbox dl{display:grid;grid-template-columns:130px 1fr}
.specbox dt,.specbox dd{padding:11px 14px;border-bottom:1px solid rgba(0,0,0,.12);font-size:14px}
.specbox dt{font-family:var(--mono);color:#555;border-right:1px solid rgba(0,0,0,.12)}
.specbox dd{font-weight:700}
.specbox dl>:nth-last-child(1),.specbox dl>:nth-last-child(2){border-bottom:none}
.share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:34px 0 8px;padding-top:24px;border-top:1px dashed #aaa}
.share .lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#666}
.share a{font-family:var(--mono);font-weight:700;font-size:12px;border:2px solid var(--ink);padding:8px 14px;background:#fff;text-transform:uppercase}
.share a:hover{background:var(--ink);color:var(--paper)}

/* prev / next */
.pnav{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.pnav a{padding:26px 30px;display:flex;flex-direction:column;gap:8px;transition:.12s}
.pnav a:hover{background:var(--ink);color:var(--paper)}
.pnav a+a{border-left:3px solid var(--ink)}
.pnav .dir{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#777}
.pnav a:hover .dir{color:var(--riso-soft)}
.pnav .ti{font-weight:900;font-size:16px;line-height:1.4}
.pnav .next{text-align:right;align-items:flex-end}

/* ---------- Band (follow CTA) ---------- */
.band{position:relative;z-index:1;background:var(--ink);color:var(--paper);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.band .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:38px 30px}
.band h3{font-weight:900;font-size:clamp(22px,4.4vw,30px)}
.band p{font-family:var(--mono);font-size:13px;color:rgba(255,255,255,.7);margin-top:7px}
.band a{background:var(--riso);color:#fff;font-weight:900;font-size:15px;padding:14px 26px;box-shadow:4px 4px 0 var(--paper);white-space:nowrap;transition:.12s}
.band a:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--paper)}

/* ---------- Ad recruit ---------- */
.recruit{position:relative;z-index:1;border-bottom:3px solid var(--ink)}
.recruit .wrap{padding:46px 30px;text-align:center}
.recruit .stamp{display:inline-block;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;background:var(--riso);color:#fff;padding:6px 14px;transform:rotate(-1.5deg);margin-bottom:18px}
.recruit h3{font-weight:900;font-size:clamp(24px,4.6vw,30px)}
.recruit p{font-family:var(--mono);font-size:13px;line-height:1.9;margin-top:12px;color:#333}
.recruit a{margin-top:22px;display:inline-block;background:var(--ink);color:var(--paper);font-weight:900;font-size:15px;padding:14px 28px;box-shadow:4px 4px 0 var(--riso)}

/* ---------- Footer ---------- */
footer{position:relative;z-index:1;background:var(--ink);color:var(--paper);padding:46px 0 30px}
footer .grid2{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:34px}
footer .logo{height:36px;filter:invert(1)}
footer .desc{margin-top:15px;font-size:13px;color:rgba(255,255,255,.62);line-height:1.85;max-width:40ch}
footer h4{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--riso-soft);margin-bottom:13px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:9px;font-size:14px;font-weight:700}
footer li a:hover{color:var(--riso-soft)}
.copy{border-top:1px solid rgba(255,255,255,.2);margin-top:38px;padding-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.45);text-align:center}

/* ---------- Palette switcher (mock control) ---------- */
.palette{position:fixed;bottom:18px;right:18px;z-index:60;display:flex;align-items:center;gap:11px;background:#fff;border:2px solid var(--ink);box-shadow:4px 4px 0 var(--ink);padding:9px 13px}
.palette .lbl{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#555}
.palette .sw{display:flex;gap:8px}
.palette button{width:26px;height:26px;border:2px solid var(--ink);cursor:pointer;padding:0;display:block;transition:transform .1s}
.palette button:hover{transform:translateY(-2px)}
.palette button[aria-pressed="true"]{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink)}

/* ---------- Generic content / legal / about ---------- */
.content{position:relative;z-index:1;padding:42px 0 24px}
.content .col{max-width:780px;margin:0 auto}
.content .col.wide{max-width:1040px}
.lede-block{border-left:6px solid var(--riso);padding:4px 0 4px 20px;margin:0 0 30px}
.lede-block p{font-size:19px;line-height:1.95;font-weight:500;color:#111}
.legal{counter-reset:sec}
.legal section{padding:26px 0;border-bottom:1px solid rgba(0,0,0,.14)}
.legal section:first-of-type{padding-top:6px}
.legal h2{counter-increment:sec;font-weight:900;font-size:20px;margin:0 0 12px;display:flex;align-items:baseline;gap:12px;line-height:1.4}
.legal h2::before{content:counter(sec,decimal-leading-zero);font-family:var(--lat);font-weight:900;font-size:15px;color:#fff;background:var(--riso);border:2px solid var(--ink);padding:1px 8px;flex:none}
.legal p{font-size:15px;line-height:1.95;color:#222;margin:0 0 12px}
.legal ul{margin:0 0 12px;list-style:none;display:flex;flex-direction:column;gap:9px}
.legal ul li{position:relative;padding-left:22px;font-size:15px;line-height:1.8}
.legal ul li::before{content:"▸";position:absolute;left:0;top:0;color:var(--riso-2)}
.legal .upd{font-family:var(--mono);font-size:12px;color:#666;margin-top:22px}

/* ---------- Definition table (operator / tokushoho) ---------- */
.dtable{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;margin:6px 0 8px}
.dtable dl{display:grid;grid-template-columns:200px 1fr}
.dtable dt,.dtable dd{padding:15px 18px;border-bottom:1px solid rgba(0,0,0,.12);font-size:15px;line-height:1.8}
.dtable dt{font-family:var(--mono);font-weight:700;font-size:13px;color:#333;border-right:1px solid rgba(0,0,0,.12);background:#faf7ef}
.dtable dd{font-weight:500}
.dtable dl>:nth-last-child(1),.dtable dl>:nth-last-child(2){border-bottom:none}
.disclose{font-family:var(--mono);font-size:12px;color:#666;background:#faf7ef;border:2px dashed var(--ink);padding:14px 16px;margin-top:14px;line-height:1.7}

/* ---------- Contact form ---------- */
.formgrid{display:grid;grid-template-columns:1.3fr .85fr;gap:40px;align-items:start}
.form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#444}
.field label .req{color:var(--riso-2);margin-left:6px}
.field input,.field textarea,.field select{font-family:var(--jp);font-size:15px;border:2px solid var(--ink);background:#fff;padding:13px 14px;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:4px 4px 0 var(--riso)}
.field textarea{min-height:170px;resize:vertical}
.btn{align-self:flex-start;background:var(--ink);color:var(--paper);font-weight:900;font-size:15px;padding:14px 30px;border:none;cursor:pointer;box-shadow:4px 4px 0 var(--riso);transition:.12s;display:inline-flex;align-items:center;gap:10px}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--riso)}
.infocard{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;padding:22px;margin-bottom:20px}
.infocard h3{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--riso-2);margin-bottom:12px}
.infocard p{font-size:15px;line-height:1.9}
.infocard a.em{font-weight:700;border-bottom:2px solid var(--riso-soft)}

/* ---------- Cards: value / advertise plans ---------- */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:8px 0 10px}
.vcard{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;padding:24px}
.vcard .n{font-family:var(--lat);font-weight:900;font-size:30px;color:var(--riso);line-height:1;-webkit-text-stroke:0;margin-bottom:14px}
.vcard h3{font-weight:900;font-size:18px;margin-bottom:10px}
.vcard p{font-size:14px;line-height:1.85;color:#333}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:8px 0 10px}
.plan{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;display:flex;flex-direction:column}
.plan.feat{background:var(--ink);color:var(--paper)}
.plan .ph{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:14px 18px;border-bottom:3px solid var(--ink)}
.plan.feat .ph{border-color:var(--paper);color:var(--riso-soft)}
.plan .pr{font-family:var(--lat);font-weight:900;font-size:34px;padding:20px 18px 4px;line-height:1}
.plan .pr small{font-family:var(--mono);font-size:12px;font-weight:700;color:#777}
.plan.feat .pr small{color:rgba(255,255,255,.6)}
.plan ul{list-style:none;padding:16px 18px 22px;display:flex;flex-direction:column;gap:11px;font-size:14px;flex:1}
.plan li{position:relative;padding-left:22px;line-height:1.6}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--riso-2);font-weight:700}
.plan.feat li::before{color:var(--riso-soft)}
.plan .cta{margin:0 18px 20px;text-align:center;border:2px solid var(--ink);font-weight:900;font-size:14px;padding:12px;background:var(--riso);color:#fff}
.plan.feat .cta{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ---------- Author profile ---------- */
.profile{position:relative;z-index:1;border-bottom:3px solid var(--ink);padding:38px 0 34px}
.profile .row{display:flex;gap:28px;align-items:flex-start}
.profile .av{width:120px;height:120px;flex:none;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--riso);position:relative;overflow:hidden}
.profile .meta .role{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--riso-2);margin-bottom:8px}
.profile .meta h1{font-weight:900;font-size:clamp(26px,4vw,38px);line-height:1.2}
.profile .meta .bio{margin-top:14px;font-size:15px;line-height:1.9;color:#222;max-width:60ch}
.profile .meta .links{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.profile .meta .links a{font-family:var(--mono);font-weight:700;font-size:12px;border:2px solid var(--ink);padding:8px 14px;background:#fff;text-transform:uppercase}
.profile .meta .links a:hover{background:var(--ink);color:var(--paper)}
.statrow{display:flex;gap:0;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);background:#fff;margin-top:26px}
.statrow .s{flex:1;padding:18px 20px;border-right:1px solid rgba(0,0,0,.14)}
.statrow .s:last-child{border-right:none}
.statrow .s .v{font-family:var(--lat);font-weight:900;font-size:28px;line-height:1}
.statrow .s .k{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#777;margin-top:6px}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .grid{grid-template-columns:repeat(2,1fr);gap:20px}
}
@media(max-width:820px){
  .wrap{padding:0 22px}
  .burger{display:flex}
  header.top .wrap{height:66px}
  header.top .logo{height:34px}
  nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);border-bottom:3px solid var(--ink);box-shadow:0 10px 0 rgba(0,0,0,.06);padding:6px;display:none}
  nav.open{display:flex}
  nav a{font-size:17px;padding:15px 14px;border-bottom:1px solid rgba(0,0,0,.12)}
  nav a:last-of-type{border-bottom:none}
  nav a:hover{transform:none;background:var(--ink);color:var(--paper)}
  nav .search{margin:8px 4px 4px;text-align:center;padding:14px}
  .hero{padding:30px 0 40px}
  .hero .wrap{grid-template-columns:1fr;gap:26px}
  .hero .tape{margin:0 0 20px 2px}
  .hero .art{transform:rotate(.8deg);box-shadow:5px 5px 0 var(--ink)}
  .article .col{max-width:none}
  .specbox dl{grid-template-columns:108px 1fr}
  .band .wrap{flex-direction:column;align-items:flex-start;gap:18px;padding:32px 24px}
  .band a{white-space:normal}
  .formgrid{grid-template-columns:1fr;gap:28px}
  .vgrid{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr;max-width:420px}
  .dtable dl{grid-template-columns:150px 1fr}
  footer .grid2{grid-template-columns:1fr;gap:30px}
}
@media(max-width:600px){
  .wrap{padding:0 16px}
  .strip .t{font-size:10px;gap:24px}
  .hero h1{line-height:1.42}
  .hero .meta{gap:10px 14px}
  .sechead{flex-wrap:wrap;gap:12px;padding:30px 0 18px}
  .sechead .rule{display:none}
  .sechead .all{margin-left:auto}
  .grid{grid-template-columns:1fr;gap:18px}
  .card,.card:nth-child(3n-1),.card:nth-child(3n){transform:none}
  .card:hover{transform:translate(-2px,-3px)}
  .recruit .wrap{padding:40px 22px}
  .band h3{font-size:24px}
  .pagehead{padding:28px 0 24px}
  .prose p{font-size:16px}
  .pullquote{font-size:21px}
  .pnav{grid-template-columns:1fr}
  .pnav a+a{border-left:none;border-top:3px solid var(--ink)}
  .pnav .next{text-align:left;align-items:flex-start}
  .vgrid{grid-template-columns:1fr}
  .profile .row{flex-direction:column;gap:18px}
  .profile .av{width:96px;height:96px}
  .statrow{flex-wrap:wrap}
  .statrow .s{flex:1 0 50%;border-bottom:1px solid rgba(0,0,0,.14)}
  .dtable dl{grid-template-columns:1fr}
  .dtable dt{border-right:none;border-bottom:1px solid rgba(0,0,0,.12)}
  .palette{bottom:12px;right:12px;padding:7px 10px;gap:8px}
  .palette .lbl{display:none}
  .palette button{width:24px;height:24px}
}
