/* howtocodeai.com — professional design system v2 */
:root{
  --bg:#FFFFFF;
  --bg-alt:#F7F9FC;
  --card:#FFFFFF;
  --ink:#0E1726;
  --muted:#51607A;
  --accent:#2050E0;
  --accent-deep:#1A3FB5;
  --accent-soft:#EDF2FE;
  --good:#0E7A46;
  --good-soft:#E8F5EE;
  --bad:#C02626;
  --bad-soft:#FBEFEF;
  --warn-soft:#FDF4E7;
  --warn-ink:#9A5B10;
  --line:#E4E9F1;
  --shadow-sm:0 1px 2px rgba(14,23,38,.06),0 1px 3px rgba(14,23,38,.08);
  --shadow-md:0 4px 14px rgba(14,23,38,.08),0 1px 3px rgba(14,23,38,.06);
  --shadow-lg:0 12px 32px rgba(14,23,38,.12);
  --r:10px;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --display:'Schibsted Grotesk','Albert Sans',-apple-system,sans-serif;
  --body:'Albert Sans',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased}
a{color:var(--accent-deep);text-decoration:none}
a:hover{color:var(--accent)}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.narrow{max-width:760px}

/* ---------- header ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:16px;flex-wrap:wrap}
.brand{font-family:var(--display);font-weight:700;font-size:1.12rem;color:var(--ink);letter-spacing:-.02em}
.brand .tld{color:var(--accent)}
.brand .cursor{display:none}
nav.main{display:flex;gap:6px;font-size:.92rem;font-weight:600}
nav.main a{color:var(--muted);padding:7px 13px;border-radius:8px;transition:background .15s,color .15s}
nav.main a:hover{color:var(--ink);background:var(--bg-alt)}
nav.main a.active{color:var(--accent-deep);background:var(--accent-soft)}

/* ---------- hero ---------- */
.hero{padding:96px 0 84px;background:#0B1220;background-image:radial-gradient(900px 420px at 78% -10%,rgba(54,104,255,.28),transparent 60%),radial-gradient(700px 380px at -10% 110%,rgba(54,104,255,.14),transparent 60%);position:relative}
.hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:44px 44px;pointer-events:none;mask-image:radial-gradient(ellipse at 70% 0%,black 30%,transparent 75%)}
.hero .wrap{position:relative;z-index:1}
.kicker{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-deep);margin-bottom:18px;font-weight:700}
.kicker a{color:inherit}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.3rem,5.2vw,3.7rem);line-height:1.07;letter-spacing:-.03em;max-width:19ch;color:#fff}
.hero h1 em{font-style:normal;color:#6E9BFF}
.hero .lede{margin-top:22px;font-size:1.18rem;color:#A6B2C9;max-width:58ch}
.hero .lede a{color:#BFD2FF;text-decoration:underline;text-underline-offset:3px}
.hero .kicker{color:#7FA6FF}
.hero-ctas{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;font-weight:600;font-size:.95rem;padding:13px 24px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink);box-shadow:var(--shadow-sm);transition:all .15s}
.btn:hover{border-color:#C9D3E4;box-shadow:var(--shadow-md);transform:translateY(-1px);color:var(--ink)}
.hero .btn{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);color:#E9EEF8;box-shadow:none}
.hero .btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);color:#fff}
.hero .btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.hero .btn.primary:hover{background:#3D6BFF;border-color:#3D6BFF}
.hero-stats{display:flex;gap:42px;margin-top:46px;flex-wrap:wrap}
.hero-stats .stat b{display:block;font-family:var(--display);font-weight:700;font-size:1.7rem;color:#fff;letter-spacing:-.02em}
.hero-stats .stat span{font-size:.85rem;color:#8C99B3}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}

/* ---------- sections ---------- */
section.band{padding:64px 0;border-bottom:1px solid var(--line)}
section.band:nth-of-type(even){background:var(--bg-alt)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:30px;flex-wrap:wrap}
h2.sec{font-family:var(--display);font-weight:700;font-size:1.75rem;letter-spacing:-.02em}
.sec-link{font-weight:600;font-size:.92rem}
.sec-link::after{content:' →'}

/* ---------- tutorial cards ---------- */
.grid{display:grid;gap:22px}
.grid.cols3{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:26px;display:flex;flex-direction:column;gap:12px;transition:all .15s}
a.card{color:var(--ink)}
a.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#D5DEEC;color:var(--ink)}
.card .meta{display:flex;gap:8px;flex-wrap:wrap;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.pill{border-radius:999px;padding:4px 11px;background:var(--bg-alt);color:var(--muted);border:1px solid var(--line)}
.pill.diff-beginner,.pill.diff-beginner-{background:var(--good-soft);border-color:transparent;color:var(--good)}
.pill.diff-intermediate{background:var(--warn-soft);border-color:transparent;color:var(--warn-ink)}
.card h3{font-family:var(--display);font-size:1.25rem;line-height:1.3;font-weight:700;letter-spacing:-.015em}
.card p{font-size:.95rem;color:var(--muted)}
.card .go{margin-top:auto;font-size:.88rem;font-weight:600;color:var(--accent-deep)}

/* ---------- tracker table ---------- */
.table-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:var(--card);box-shadow:var(--shadow-sm)}
table.tracker{width:100%;border-collapse:collapse;font-size:.92rem;min-width:760px}
table.tracker th{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);text-align:left;padding:13px 18px;border-bottom:1px solid var(--line);background:var(--bg-alt);white-space:nowrap}
table.tracker td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:top}
table.tracker tr:last-child td{border-bottom:none}
table.tracker tr:hover td{background:#FAFBFE}
td.price{font-family:var(--mono);font-weight:700;white-space:nowrap;font-size:.88rem}
td.toolname a{font-weight:700;color:var(--ink)}
td.toolname a:hover{color:var(--accent-deep)}
.cat-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent-deep);white-space:nowrap}
.free-yes{color:var(--good);font-weight:700}
.verified{font-family:var(--mono);font-size:.74rem;color:var(--muted);white-space:nowrap}

/* ---------- changelog ---------- */
.change{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);align-items:baseline;flex-wrap:wrap}
.change .date{font-family:var(--mono);font-size:.78rem;color:var(--muted);min-width:104px}
.change .delta{font-family:var(--mono);font-size:.76rem;font-weight:700;padding:3px 10px;border-radius:6px}
.delta.up{color:var(--bad);background:var(--bad-soft)}
.delta.down{color:var(--good);background:var(--good-soft)}
.delta.note{color:var(--muted);background:var(--bg-alt)}

/* ---------- article ---------- */
article.tut{padding:60px 0 80px}
.tut .kicker{margin-bottom:14px}
.tut h1{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.2vw,2.7rem);line-height:1.14;letter-spacing:-.025em;max-width:26ch}
.tut .standfirst{margin-top:18px;font-size:1.14rem;color:var(--muted);max-width:60ch}
.factbox{margin:32px 0;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-alt);padding:22px 26px;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px}
.factbox .fb{font-size:.93rem}
.factbox .fb b{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-deep);margin-bottom:4px}
.tut-body{max-width:740px}
.tut-body h2{font-family:var(--display);font-weight:700;font-size:1.45rem;margin:44px 0 14px;letter-spacing:-.02em}
.tut-body p{margin:0 0 18px;color:#27324A}
.panel{border:1px solid var(--line);border-radius:var(--r);background:var(--card);box-shadow:var(--shadow-sm);padding:8px 24px;margin:18px 0}
.promptbox{margin:24px 0;border:1px solid #C8D6F8;border-left:4px solid var(--accent);border-radius:0 var(--r) var(--r) 0;background:var(--accent-soft);padding:20px 22px;position:relative}
.promptbox::before{content:'PROMPT — COPY & EDIT';display:block;font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.12em;color:var(--accent-deep);margin-bottom:10px}
.promptbox p{font-family:var(--mono);font-size:.85rem;line-height:1.65;margin:0;white-space:pre-wrap;color:#1B2A52}
.tipbox{margin:24px 0;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-alt);padding:16px 20px;font-size:.95rem}
.tipbox b{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--accent-deep);display:block;margin-bottom:5px}
pre.codeblock{margin:24px 0;background:#0E1726;color:#E4EBF7;padding:20px 22px;overflow-x:auto;font-family:var(--mono);font-size:.84rem;line-height:1.65;border-radius:var(--r);box-shadow:var(--shadow-md)}

/* ---------- tool detail ---------- */
.plan-row{display:flex;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.plan-row:last-child{border-bottom:none}
.plan-row .pname{font-weight:600}
.plan-row .pprice{font-family:var(--mono);font-weight:700}
.plan-row .pnotes{flex-basis:100%;font-size:.88rem;color:var(--muted)}
.warnbox{margin:24px 0;border:1px solid #F0CFA0;border-left:4px solid #D97706;border-radius:0 var(--r) var(--r) 0;background:var(--warn-soft);padding:16px 20px;font-size:.95rem}
.warnbox b{color:var(--warn-ink);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;display:block;margin-bottom:5px}

/* ---------- footer ---------- */
footer.site{padding:52px 0 60px;background:#0E1726;color:#9AA7BF}
footer.site .wrap{display:flex;justify-content:space-between;gap:28px;flex-wrap:wrap}
footer.site a{color:#D7DFEC}
footer.site a:hover{color:#fff}
footer.site .fbrand{font-family:var(--display);font-weight:700;font-size:1.05rem;color:#fff}
footer.site .fbrand+p{font-size:.9rem}
footer.site .cols{display:flex;gap:56px;flex-wrap:wrap}
footer.site .cols div{display:flex;flex-direction:column;gap:9px;font-size:.9rem}
footer.site .cols b{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6B7A96}
footer.site .legal{flex-basis:100%;margin-top:28px;padding-top:22px;border-top:1px solid #233047;font-size:.8rem;color:#6B7A96}
footer.site .legal a{color:#9AA7BF;text-decoration:underline}

@media(max-width:640px){
  .hero{padding:56px 0 48px}
  section.band{padding:46px 0}
  body{font-size:16px}
}

/* ---------- comparison pages ---------- */
table.tracker.vs{min-width:560px}
table.tracker.vs tbody th{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);text-align:left;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--bg-alt);white-space:nowrap;vertical-align:top}
table.tracker.vs td{width:40%}
.price-cell{font-family:var(--mono);font-weight:700}
.vs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin:20px 0}
.vs-card{border:1px solid var(--line);border-radius:var(--r);background:var(--card);box-shadow:var(--shadow-sm);padding:22px 24px}
.vs-card h3{font-family:var(--display);font-size:1.05rem;font-weight:700;margin-bottom:12px;letter-spacing:-.01em}
.vs-card ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;font-size:.93rem;color:#27324A}

/* ---------- copy button ---------- */
.promptbox{padding-right:84px}
.copy-btn{position:absolute;top:14px;right:14px;font-family:var(--body);font-weight:600;font-size:.78rem;padding:6px 12px;border-radius:7px;border:1px solid #B9CBF5;background:#fff;color:var(--accent-deep);cursor:pointer;transition:all .15s}
.copy-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.copy-btn.done{background:var(--good);border-color:var(--good);color:#fff}
@media(max-width:520px){.promptbox{padding-right:22px}.copy-btn{position:static;display:block;margin-top:12px}}

/* ---------- tutorial index & category cards ---------- */
.toc-pill{text-decoration:none;font-size:.8rem;font-weight:600;padding:8px 14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#E9EEF8;border-radius:999px}
.toc-pill:hover{background:rgba(255,255,255,.14);color:#fff}
.cat-links{list-style:none;padding:0;margin:4px 0 12px;display:flex;flex-direction:column;gap:7px}
.cat-links a{font-size:.9rem;font-weight:600}
