/* ============================================================
   Watashi Games — "Ink Studio" design system
   Shared by home.php, colorizer.php, article.php
   ============================================================ */

/* ---- Display face: Archivo (self-hosted, Latin only) ---- */
@font-face{
  font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;
  src:url('/assets/fonts/archivo-latin-700-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;
  src:url('/assets/fonts/archivo-latin-800-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;
  src:url('/assets/fonts/archivo-latin-ext-800-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* ---- Tokens ---- */
:root{
  --ground:#e9e6dc; --surface:#f4f2ea; --surface-2:#efece2;
  --text:#161009; --text-soft:#5c5442; --line:#cdc7b6; --line-strong:#161009;
  --accent:#e02c1b; --accent-deep:#a81c12; --accent-ink:#ffffff;
  --cobalt:#2432b8; --screen:#c7c1b0;
  --shadow:6px 6px 0 var(--line-strong);
  --display:'Archivo','Helvetica Neue',Helvetica,Arial,system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:ui-monospace,'SF Mono','Cascadia Code',Menlo,Consolas,monospace;
  --maxw:1180px;
}
@media (prefers-color-scheme:dark){
  :root{
    --ground:#131009; --surface:#1d190f; --surface-2:#221d12;
    --text:#f2ecdd; --text-soft:#a89d84; --line:#342d1d; --line-strong:#000;
    --accent:#ff4a34; --accent-deep:#e02c1b; --accent-ink:#160b06;
    --cobalt:#7d88ff; --screen:#2e2818; --shadow:6px 6px 0 #000;
  }
}
:root[data-theme="light"]{
  --ground:#e9e6dc; --surface:#f4f2ea; --surface-2:#efece2;
  --text:#161009; --text-soft:#5c5442; --line:#cdc7b6; --line-strong:#161009;
  --accent:#e02c1b; --accent-deep:#a81c12; --accent-ink:#ffffff;
  --cobalt:#2432b8; --screen:#c7c1b0; --shadow:6px 6px 0 var(--line-strong);
}
:root[data-theme="dark"]{
  --ground:#131009; --surface:#1d190f; --surface-2:#221d12;
  --text:#f2ecdd; --text-soft:#a89d84; --line:#342d1d; --line-strong:#000;
  --accent:#ff4a34; --accent-deep:#e02c1b; --accent-ink:#160b06;
  --cobalt:#7d88ff; --screen:#2e2818; --shadow:6px 6px 0 #000;
}

/* ---- Reset / base (override Carrd warm bg) ---- */
body:before{background:var(--ground) !important;background-image:none !important}
body:after{background:var(--ground) !important}
#wrapper,#main,#main > .inner,body{background:var(--ground) !important}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);font-family:var(--body);font-size:18px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%}
::selection{background:var(--accent);color:var(--accent-ink)}

#ink-halftone{position:fixed;inset:0;width:100%;height:100%;z-index:0;opacity:.45;pointer-events:none}
.ink-wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;position:relative;z-index:1}
.ink-mono{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}

/* ---- Nav bar ---- */
.ink-bar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--ground) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:2px solid var(--line-strong)}
.ink-bar-in{max-width:var(--maxw);margin:0 auto;padding:10px 22px;display:flex;align-items:center;gap:20px}
.ink-brand{display:flex;align-items:center;gap:11px;text-decoration:none;font-family:var(--display);font-weight:800;letter-spacing:-.02em;color:var(--text)}
.ink-brand img{width:40px;height:40px;border-radius:9px;display:block}
.ink-brand b{font-size:1.12rem}
.ink-nav{display:flex;gap:24px;margin-left:auto}
.ink-nav a{text-decoration:none;font-weight:600;font-size:.95rem;color:var(--text-soft);padding:4px 0;position:relative}
.ink-nav a:hover{color:var(--text)}
.ink-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);transition:right .2s}
.ink-nav a:hover::after,.ink-nav a[aria-current="page"]::after{right:0}
.ink-nav a[aria-current="page"]{color:var(--text)}
.ink-toggle{background:var(--surface);border:2px solid var(--line-strong);border-radius:8px;width:38px;height:38px;
  cursor:pointer;display:grid;place-items:center;color:var(--text);flex:0 0 auto}
.ink-toggle:hover{background:var(--accent);color:var(--accent-ink)}
.ink-toggle:focus-visible,.ink-langbtn:focus-visible{outline:3px solid var(--cobalt);outline-offset:2px}
/* language switcher */
.ink-lang{position:relative;flex:0 0 auto}
.ink-langbtn{display:flex;align-items:center;gap:6px;padding:7px 11px;font-family:var(--mono);font-size:.68rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--text);background:var(--surface);border:2px solid var(--line-strong);
  border-radius:8px;cursor:pointer}
.ink-langbtn:hover{background:var(--accent);color:var(--accent-ink)}
.ink-langmenu{display:none;position:absolute;top:calc(100% + 6px);min-width:170px;max-height:340px;overflow-y:auto;
  margin:0;padding:5px;list-style:none;background:var(--surface);border:2px solid var(--line-strong);border-radius:10px;
  box-shadow:var(--shadow);z-index:60}
.ink-langmenu li a{display:block;padding:7px 12px;border-radius:6px;font-size:.85em;font-weight:600;color:var(--text);text-decoration:none}
.ink-langmenu li a:hover{background:var(--surface-2)}
.ink-langmenu li a[aria-current="true"]{color:var(--accent)}
/* hamburger + mobile menu */
.ink-burger{display:none;background:var(--surface);border:2px solid var(--line-strong);border-radius:8px;width:38px;height:38px;
  cursor:pointer;place-items:center;color:var(--text);flex:0 0 auto}
.ink-burger:hover{background:var(--accent);color:var(--accent-ink)}
.ink-burger:focus-visible{outline:3px solid var(--cobalt);outline-offset:2px}
.ink-burger .ink-burger-close{display:none}
.ink-burger[aria-expanded="true"] .ink-burger-open{display:none}
.ink-burger[aria-expanded="true"] .ink-burger-close{display:block}
.ink-mobile{display:none;flex-direction:column;border-top:2px solid var(--line-strong);
  background:color-mix(in srgb,var(--ground) 96%,transparent);padding:6px 22px 14px}
.ink-mobile.open{display:flex}
.ink-mobile a{text-decoration:none;color:var(--text);font-weight:600;font-size:1.05rem;padding:14px 4px;border-bottom:1px solid var(--line)}
.ink-mobile a:last-child{border-bottom:none}
.ink-mobile a:hover,.ink-mobile a:focus-visible{color:var(--accent)}
@media(max-width:760px){.ink-nav{display:none}.ink-burger{display:grid}}
@media(max-width:420px){.ink-brand b{display:none}}

/* ---- Ticker ---- */
.ink-ticker{background:var(--accent);color:var(--accent-ink);border-bottom:2px solid var(--line-strong);overflow:hidden;white-space:nowrap}
.ink-ticker-in{display:inline-block;padding:7px 0;animation:ink-slide 30s linear infinite;will-change:transform}
.ink-ticker-in span{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin:0 24px}
@keyframes ink-slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ink-ticker-in{animation:none}}

/* ---- Buttons ---- */
.ink-btn{font-family:var(--body);font-weight:700;font-size:1rem;text-decoration:none;padding:14px 26px;
  border:2px solid var(--line-strong);border-radius:11px;display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  transition:transform .14s ease,box-shadow .14s ease}
.ink-btn:focus-visible{outline:3px solid var(--cobalt);outline-offset:3px}
.ink-btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow)}
.ink-btn-primary:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--line-strong)}
.ink-btn-ghost{background:var(--surface);color:var(--text)}
.ink-btn-ghost:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}

/* ---- Section frame ---- */
.ink-sec{padding:56px 0}
.ink-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;
  border-bottom:2px solid var(--line-strong);padding-bottom:14px}
.ink-sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,4vw,2.5rem);letter-spacing:-.03em;margin:0;line-height:1;color:var(--text)}
.ink-sec-head .idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--text-soft);text-transform:uppercase}

/* ---- Panels (manga grid) ---- */
.ink-panels{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.ink-panel{background:var(--surface);border:2.5px solid var(--line-strong);border-radius:14px;overflow:hidden;position:relative;
  display:flex;flex-direction:column;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:transform .16s ease,box-shadow .16s ease}
.ink-panel:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--line-strong)}
.ink-panel:focus-visible{outline:3px solid var(--cobalt);outline-offset:3px}
.ink-p-lg{grid-column:span 4}.ink-p-sm{grid-column:span 2}.ink-p-md{grid-column:span 3}
@media(max-width:860px){.ink-panels{grid-template-columns:repeat(2,1fr)}.ink-p-lg,.ink-p-md,.ink-p-sm{grid-column:span 2}}
.ink-p-art{position:relative;display:block;aspect-ratio:16/10;border-bottom:2.5px solid var(--line-strong);overflow:hidden;background:#0c0e1a}
.ink-p-lg .ink-p-art{aspect-ratio:16/8}
.ink-p-art>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ink-p-art.contain{background:var(--surface-2)}
.ink-p-art.contain>img{object-fit:contain;padding:14px}
.ink-tag{position:absolute;top:12px;left:12px;z-index:3;background:var(--line-strong);color:#fff;font-family:var(--mono);
  font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:4px 9px;border-radius:6px}
.ink-tag.new{background:var(--accent);color:var(--accent-ink)}
.ink-tag.tool{background:var(--cobalt);color:#fff}
.ink-p-body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:11px;flex:1}
.ink-p-body h3{font-family:var(--display);font-weight:800;font-size:1.5rem;letter-spacing:-.02em;margin:0;line-height:1.05;color:var(--text)}
.ink-p-lg .ink-p-body h3{font-size:1.85rem}
.ink-p-body p{margin:0;color:var(--text-soft);font-size:.98rem;line-height:1.55}
.ink-p-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}
.ink-price{font-family:var(--display);font-weight:800;font-size:1.15rem;color:var(--text)}
.ink-price.free{color:var(--accent)}
.ink-badge{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;border:1.5px solid var(--line);
  border-radius:5px;padding:3px 7px;color:var(--text-soft)}
.ink-badge.soon{border-color:var(--accent);color:var(--accent);font-weight:700}
.ink-badge.free{border-color:#1f9d57;color:#1f9d57;font-weight:700}
.ink-p-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:12px}
.ink-p-links span,.ink-p-links a{font-family:var(--mono);font-size:.64rem;letter-spacing:.07em;text-transform:uppercase;
  color:var(--text);text-decoration:none;border:2px solid var(--line-strong);border-radius:8px;padding:7px 12px;line-height:1;
  background:var(--surface-2);transition:background .15s,color .15s,border-color .15s}
.ink-p-links span:first-child,.ink-p-links a:first-child{background:var(--accent);color:var(--accent-ink)}
.ink-p-links a:first-child:hover{background:var(--accent-deep)}
.ink-p-links a:not(:first-child):hover{border-color:var(--accent);color:var(--accent)}
.ink-p-title{text-decoration:none;display:inline-block}
.ink-p-title:hover h3{color:var(--accent)}
.ink-ext{font-family:var(--mono);font-size:.66rem;letter-spacing:.06em;color:var(--cobalt);margin-top:auto;padding-top:6px}

/* colorizer split tile */
.ink-clz{position:absolute;inset:0}
.ink-clz .bw{position:absolute;inset:0}
.ink-clz .bw img,.ink-clz .color img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ink-clz .color{position:absolute;inset:0;clip-path:polygon(52% 0,100% 0,100% 100%,42% 100%)}
.ink-clz .seam{position:absolute;top:0;bottom:0;left:47%;width:3px;background:var(--accent);transform:skewX(-9deg);z-index:2}
.ink-clz .lab{position:absolute;bottom:10px;z-index:3;font-family:var(--mono);font-size:.56rem;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);padding:3px 8px;border-radius:5px}

/* ---- Final CTA ---- */
.ink-final{border:2.5px solid var(--line-strong);border-radius:18px;background:var(--surface);box-shadow:var(--shadow);
  padding:clamp(34px,6vw,64px);text-align:center;position:relative;overflow:hidden}
.ink-final::before{content:"私";position:absolute;right:-20px;bottom:-60px;font-family:"Hiragino Mincho ProN","Yu Mincho",serif;
  font-size:clamp(180px,30vw,340px);color:var(--accent);opacity:.06;line-height:1;pointer-events:none}
.ink-final h2{font-family:var(--display);font-weight:800;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.03em;margin:0 0 14px;line-height:1;position:relative;color:var(--text)}
.ink-final p{color:var(--text-soft);max-width:46ch;margin:0 auto 28px;position:relative}
.ink-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* ---- Footer ---- */
.ink-footer{border-top:2px solid var(--line-strong);margin-top:66px;padding:36px 0 56px}
.ink-foot-in{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.ink-socials{display:flex;gap:10px;flex-wrap:wrap}
.ink-socials a{width:42px;height:42px;border:2px solid var(--line-strong);border-radius:10px;display:grid;place-items:center;
  text-decoration:none;font-family:var(--mono);font-size:.62rem;font-weight:700;color:var(--text);transition:.14s}
.ink-socials a:hover{background:var(--accent);color:var(--accent-ink);transform:translateY(-2px)}
.ink-socials a:focus-visible{outline:3px solid var(--cobalt);outline-offset:2px}
.ink-foot-note{color:var(--text-soft);font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase}

/* ---- Scroll reveal ---- */
.ink-reveal{opacity:0;transform:translateY(16px)}
.ink-reveal.in{opacity:1;transform:none;transition:opacity .5s ease,transform .5s ease}
@media(prefers-reduced-motion:reduce){.ink-reveal{opacity:1 !important;transform:none !important;transition:none}}

/* ---- Hero ---- */
.ink-hero{padding:56px 0 46px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
@media(max-width:900px){.ink-hero{grid-template-columns:1fr;gap:26px;padding:40px 0 34px}}
.ink-eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--accent);margin-bottom:18px}
.ink-eyebrow::before{content:"";width:34px;height:2px;background:var(--accent)}
.ink-hero-h1{font-family:var(--display);font-weight:800;line-height:.99;letter-spacing:-.035em;
  font-size:clamp(2.5rem,6vw,5rem);margin:0 0 22px;text-wrap:balance;max-width:14ch;color:var(--text)}
.ink-hero-h1 .red{color:var(--accent);position:relative;white-space:nowrap}
.ink-hero-h1 .red::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.13em;background:var(--accent);opacity:.28}
.ink-hero-lead{font-size:clamp(1.02rem,2vw,1.24rem);color:var(--text-soft);max-width:50ch;line-height:1.6;margin:0 0 28px}
.ink-hero-meta{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.ink-hero-meta div{display:flex;flex-direction:column;gap:2px}
.ink-hero-meta .n{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.02em;color:var(--text)}
.ink-hero-meta .l{color:var(--text-soft)}
.ink-hero-art{border:2.5px solid var(--line-strong);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);
  background:var(--surface);position:relative;transform:rotate(1.2deg)}
.ink-hero-art img{display:block;width:100%;height:auto}
.ink-hero-art .cap{position:absolute;left:12px;top:12px;background:var(--line-strong);color:#fff;
  padding:5px 10px;border-radius:6px;font-size:.62rem;z-index:4}
@media(max-width:900px){.ink-hero-art{transform:none}}

/* Hero before/after split (real Colorizer output) */
.ink-hero-split{--split:47%;aspect-ratio:3/4;background:#0c0e1a}
.ink-hero-split .ink-split-color,.ink-hero-split .ink-split-bw img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%}
.ink-hero-split .ink-split-bw{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--split)) 0 0)}
.ink-hero-split .ink-split-seam{position:absolute;top:0;bottom:0;left:var(--split);width:3px;background:var(--accent);box-shadow:0 0 0 1px rgba(0,0,0,.35);z-index:3}
.ink-hero-split .ink-split-lab{position:absolute;bottom:12px;z-index:4;color:#fff;background:rgba(0,0,0,.55);
  padding:4px 9px;border-radius:5px;font-size:.56rem}

/* ---- Trailers ---- */
.ink-trailers{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.ink-trailers{grid-template-columns:1fr}}
.ink-trailer{background:var(--surface);border:2.5px solid var(--line-strong);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.ink-frame{position:relative;aspect-ratio:16/9;border-bottom:2.5px solid var(--line-strong)}
.ink-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.ink-trailer-cap{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px}
.ink-trailer-cap b{font-family:var(--display);font-weight:800;font-size:1.2rem;letter-spacing:-.01em}
.ink-btn-sm{padding:8px 16px;font-size:.85rem;border-radius:9px}

/* ---- Dispatches ---- */
.ink-dispatch{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.ink-dispatch{grid-template-columns:1fr}}
.ink-disp{background:var(--surface);border:2px solid var(--line-strong);border-radius:12px;padding:22px;text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:10px;transition:transform .14s,box-shadow .14s}
.ink-disp:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.ink-disp:focus-visible{outline:3px solid var(--cobalt);outline-offset:3px}
.ink-disp .k{color:var(--accent)}
.ink-disp h4{font-family:var(--display);font-weight:800;font-size:1.15rem;letter-spacing:-.01em;margin:0;line-height:1.2;color:var(--text)}
.ink-disp p{margin:0;color:var(--text-soft);font-size:.92rem}
.ink-disp .rt{margin-top:auto;color:var(--text-soft)}

/* ---- Colorizer: steps ---- */
.ink-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:860px){.ink-steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.ink-steps{grid-template-columns:1fr}}
.ink-step{background:var(--surface);border:2px solid var(--line-strong);border-radius:12px;padding:22px 20px;box-shadow:var(--shadow)}
.ink-step-n{font-family:var(--display);font-weight:800;font-size:1.8rem;color:var(--accent);line-height:1;margin-bottom:.4rem}
.ink-step h3{font-family:var(--display);font-weight:800;font-size:1.1rem;letter-spacing:-.01em;margin:0 0 .5rem;color:var(--text)}
.ink-step p{margin:0;color:var(--text-soft);font-size:.92rem;line-height:1.55}

/* ---- Colorizer: gallery (hover reveal) ---- */
.ink-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:640px){.ink-gallery{grid-template-columns:1fr}}
.ink-gcard{position:relative;border:2.5px solid var(--line-strong);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/4}
.ink-gcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ink-gc-bw{position:absolute;inset:0;transition:opacity .5s ease}
.ink-gcard:hover .ink-gc-bw{opacity:0}
.ink-gc-lab{position:absolute;bottom:12px;left:12px;z-index:3;color:#fff;background:rgba(0,0,0,.55);padding:4px 9px;border-radius:5px;font-size:.56rem;transition:opacity .3s}
.ink-gc-lab-color{opacity:0}.ink-gcard:hover .ink-gc-lab-color{opacity:1}.ink-gcard:hover .ink-gc-lab-bw{opacity:0}

/* ---- Colorizer: features ---- */
.ink-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.ink-features{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ink-features{grid-template-columns:1fr}}
.ink-feature{background:var(--surface);border:2px solid var(--line-strong);border-radius:12px;padding:20px;box-shadow:var(--shadow)}
.ink-feature.wide{grid-column:1/-1}
.ink-feature-ic{font-size:1.5rem;line-height:1;margin-bottom:.5rem}
.ink-feature h3{font-family:var(--display);font-weight:800;font-size:1.05rem;letter-spacing:-.01em;margin:0 0 .4rem;color:var(--text)}
.ink-feature p{margin:0;color:var(--text-soft);font-size:.9rem;line-height:1.55}

/* ---- Colorizer: comparison ---- */
.ink-tablewrap{overflow-x:auto;border:2px solid var(--line-strong);border-radius:12px;box-shadow:var(--shadow)}
.ink-compare{width:100%;border-collapse:collapse;font-size:.95rem;background:var(--surface)}
.ink-compare th,.ink-compare td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
.ink-compare thead th{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft)}
.ink-compare tbody tr:last-child td{border-bottom:none}
.ink-compare td:first-child{font-weight:600;color:var(--text)}
.ink-compare td.yes{color:var(--accent);font-weight:600}
.ink-compare td.no{color:var(--text-soft)}
.ink-mini-title{font-family:var(--display);font-weight:800;text-align:center;font-size:1.3rem;margin:34px 0 4px;color:var(--text)}
.ink-mini-sub{text-align:center;color:var(--text-soft);margin:0 0 18px;font-size:.95rem}
.ink-translate{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:680px;margin:0 auto}
.ink-translate figure{margin:0;border:2px solid var(--line-strong);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.ink-translate img{display:block;width:100%;height:auto}
.ink-translate figcaption{padding:8px 12px;color:var(--text-soft);text-align:center;background:var(--surface)}

/* ---- Colorizer: pricing ---- */
.ink-pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.ink-pricing{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.ink-pricing{grid-template-columns:1fr}}
.ink-price{position:relative;background:var(--surface);border:2px solid var(--line-strong);border-radius:12px;padding:24px 20px;text-align:center;box-shadow:var(--shadow)}
.ink-price.feat{border-color:var(--accent);border-width:2.5px}
.ink-pop{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--accent-ink);padding:3px 12px;border-radius:6px;font-size:.6rem;white-space:nowrap}
.ink-price h3{font-family:var(--display);font-weight:800;font-size:1.05rem;margin:0 0 .3rem;color:var(--text)}
.ink-price-v{font-family:var(--display);font-weight:800;font-size:1.9rem;letter-spacing:-.02em;color:var(--accent);margin-bottom:.3rem}
.ink-price p{margin:0;color:var(--text-soft);font-size:.85rem;line-height:1.4}

/* ---- Colorizer: FAQ ---- */
.ink-faq{max-width:820px;margin:0 auto}
.ink-faq-item{border-bottom:1.5px solid var(--line)}
.ink-faq-item summary{font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--text);padding:16px 30px 16px 0;cursor:pointer;list-style:none;position:relative}
.ink-faq-item summary::-webkit-details-marker{display:none}
.ink-faq-item summary::after{content:"+";position:absolute;right:2px;top:14px;font-size:1.4rem;color:var(--accent);transition:transform .2s}
.ink-faq-item[open] summary::after{transform:rotate(45deg)}
.ink-faq-item p{margin:0 0 18px;color:var(--text-soft);line-height:1.7}

/* ---- Blog index ---- */
.ink-cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:16px}
.ink-featured{display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:var(--surface);border:2.5px solid var(--line-strong);
  border-radius:16px;overflow:hidden;box-shadow:var(--shadow);text-decoration:none;color:inherit;margin-bottom:8px;
  transition:transform .16s ease,box-shadow .16s ease}
.ink-featured:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--line-strong)}
.ink-featured:focus-visible{outline:3px solid var(--cobalt);outline-offset:3px}
.ink-featured-img{position:relative;min-height:220px;border-right:2.5px solid var(--line-strong);background:#0c0e1a}
.ink-featured-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%}
.ink-featured-body{padding:26px 28px;display:flex;flex-direction:column;gap:12px;justify-content:center}
.ink-featured-body h2{font-family:var(--display);font-weight:800;font-size:1.6rem;letter-spacing:-.02em;line-height:1.1;margin:0;color:var(--text)}
.ink-featured-body p{margin:0;color:var(--text-soft);line-height:1.55}
@media(max-width:720px){.ink-featured{grid-template-columns:1fr}.ink-featured-img{min-height:200px;border-right:none;border-bottom:2.5px solid var(--line-strong)}}
/* reading progress */
#reading-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:60;transition:width .1s linear}

/* ---- Mobile tweaks ---- */
@media(max-width:560px){
  .ink-cmp-grid{grid-template-columns:1fr}
  .ink-translate{grid-template-columns:1fr}
  .ink-sec{padding:40px 0}
  .ink-hero{padding:32px 0 30px}
  .ink-sec-head{flex-wrap:wrap}
  .ink-hero-meta{gap:20px}
}
@media(max-width:420px){
  .ink-bar-in{gap:12px;padding:10px 16px}
  .ink-wrap{padding:0 16px}
  .ink-langbtn span{display:none}
  .ink-btn{padding:12px 20px;font-size:.95rem}
}

/* ---- Article page ---- */
.ink-crumb{padding:20px 0 0;color:var(--text-soft);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.ink-crumb a{color:var(--text-soft);text-decoration:none}
.ink-crumb a:hover{color:var(--accent)}
.ink-crumb span{color:var(--line)}
.ink-crumb .cur{color:var(--text)}
.ink-art-hero{max-width:760px;margin:0 auto;padding:26px 0 8px;text-align:center}
.ink-back{display:inline-block;color:var(--text-soft);text-decoration:none;margin-bottom:16px}
.ink-back:hover{color:var(--accent)}
.ink-art-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4.6vw,3.1rem);letter-spacing:-.03em;line-height:1.08;margin:0 0 16px;text-wrap:balance;color:var(--text)}
.ink-art-sub{font-size:1.15rem;color:var(--text-soft);line-height:1.6;margin:0 0 20px}
.ink-byline{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-soft);font-size:.9rem}
.ink-byline img{border-radius:50%;border:2px solid var(--accent)}
.ink-byline .dot{color:var(--line)}
.ink-art-heroimg{max-width:820px;margin:24px auto 0;border:2.5px solid var(--line-strong);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.ink-art-heroimg img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;object-position:center 22%}
.ink-toc{max-width:760px;margin:34px auto;border:2px solid var(--line-strong);border-radius:12px;background:var(--surface);padding:20px 26px;box-shadow:var(--shadow)}
.ink-toc-h{color:var(--text-soft);margin:0 0 10px}
.ink-toc ol{margin:0;padding-left:1.3em;color:var(--text-soft)}
.ink-toc li{margin:6px 0}
.ink-toc a{color:var(--text-soft);text-decoration:none}
.ink-toc a:hover{color:var(--accent)}
.ink-article{max-width:720px;margin:0 auto}
.ink-article section{padding:14px 0}
.ink-article h2{font-family:var(--display);font-weight:800;font-size:clamp(1.4rem,3vw,1.9rem);letter-spacing:-.02em;line-height:1.2;
  margin:24px 0 14px;padding-left:14px;border-left:4px solid var(--accent);color:var(--text)}
.ink-article p{font-size:1.12rem;line-height:1.85;color:var(--text);margin:0 0 1.3rem}
.ink-article p:first-of-type{font-size:1.2rem}
.ink-article strong,.ink-article b{color:var(--text);font-weight:700}
.ink-article a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.ink-article a:hover{text-decoration:none}
.ink-article img{width:100%;height:auto;border:2px solid var(--line-strong);border-radius:12px;margin:1.4rem 0}
.ink-cmp{margin:1.6rem 0}
.ink-cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ink-cmp-grid>div{position:relative}
.ink-cmp-grid img{width:100%;height:auto;border:2px solid var(--line-strong);border-radius:12px;margin:0;display:block}
.ink-cmp-lab{position:absolute;top:10px;left:10px;color:#fff;background:rgba(0,0,0,.55);padding:3px 8px;border-radius:5px;font-size:.56rem}
.ink-cmp-lab-c{background:var(--accent);color:var(--accent-ink)}
.ink-prompt{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px;border:1.5px solid var(--accent);
  background:color-mix(in srgb,var(--accent) 7%,var(--surface));border-radius:9px;padding:9px 14px}
.ink-prompt-l{color:var(--accent);font-weight:700;flex:0 0 auto}
.ink-prompt-t{font-style:italic;color:var(--text);font-size:.98rem}
.ink-cmp figcaption{color:var(--text-soft);font-size:.9rem;font-style:italic;text-align:center;margin-top:10px}
.ink-final-lead{font-size:1.2rem;color:var(--text);max-width:44ch;margin:0 auto 22px;position:relative}
.ink-alsoby{color:var(--text-soft);text-align:center;margin:32px 0 10px}
.ink-alsoby-card{max-width:420px;margin:0 auto;text-align:center;align-items:center}

/* ---- RTL ---- */
[dir="rtl"] .ink-article h2{padding-left:0;padding-right:14px;border-left:none;border-right:4px solid var(--accent)}
[dir="rtl"] .ink-toc ol{padding-left:0;padding-right:1.3em}
[dir="rtl"] .ink-compare th,[dir="rtl"] .ink-compare td{text-align:right}
[dir="rtl"] .ink-faq-item summary{padding:16px 0 16px 30px}
[dir="rtl"] .ink-faq-item summary::after{right:auto;left:2px}
[dir="rtl"] .ink-gc-lab{left:auto;right:12px}
[dir="rtl"] .ink-nav{margin-left:0;margin-right:auto}
[dir="rtl"] .ink-p-links span,[dir="rtl"] .ink-p-links a,[dir="rtl"] .ink-ext{direction:rtl}
[dir="rtl"] .ink-final::before{right:auto;left:-20px}
[dir="rtl"] .ink-eyebrow::before{margin-left:0}
[dir="rtl"] .ink-hero-art{transform:rotate(-1.2deg)}
