/* ============================================================
   Prasanjith Chanaka — Design System (blog build)
   Tokens extracted from the master design-system file.
   Editorial paper aesthetic: warm paper, green brand,
   Newsreader serif display + Hanken Grotesk sans + IBM Plex Mono.
   ============================================================ */

:root {
    /* Palette */
    --green-50:#E7F6EC; --green-100:#C3E9D0; --green-400:#34B36B;
    --green-500:#1FA35B; --green-600:#157A43; --green-700:#0E5D33;
    --gold-50:#FDF2DF; --gold-300:#F4C870; --gold-500:#E8911C; --gold-600:#C0740E;
    --pink-50:#FCEAF2; --pink-100:#F8CFE0; --pink-300:#F2A7C7; --pink-500:#E5689B; --pink-600:#C84A7E;
    --purple-50:#F3E9F6; --purple-100:#E3CBEA; --purple-400:#9B45AD; --purple-500:#7C2E8C; --purple-600:#61226E;

    /* Surfaces & ink */
    --paper:#FBF8F2; --paper-sunk:#F3EEE4; --surface:#FFFFFF;
    --ink:#1B1B22; --ink-2:#4A4A55; --ink-3:#7C7C88;
    --hairline:#E7E0D4; --hairline-2:#D8CFBE;

    /* Semantic */
    --bg-app:var(--paper); --bg-sunk:var(--paper-sunk);
    --surface-card:var(--surface);
    --brand:var(--green-500); --brand-hover:var(--green-600); --brand-press:var(--green-700); --brand-tint:var(--green-50);
    --accent:var(--purple-500); --accent-tint:var(--purple-50);
    --highlight:var(--gold-500); --highlight-tint:var(--gold-50);
    --pop:var(--pink-500); --pop-tint:var(--pink-50);
    --text-strong:var(--ink); --text-body:var(--ink-2); --text-muted:var(--ink-3);
    --text-link:var(--green-600); --text-on-brand:#FFFFFF;
    --border-subtle:var(--hairline); --border-strong:var(--hairline-2);
    --focus-ring:var(--green-400);
    --danger:#D23B3B; --warning:#E8911C; --success:#1FA35B; --info:#7C2E8C;

    /* Type */
    --font-display:'Newsreader',Georgia,'Times New Roman',serif;
    --font-sans:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;
    --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',Menlo,monospace;
    --text-xs:0.75rem; --text-sm:0.875rem; --text-base:1rem; --text-md:1.125rem;
    --text-lg:1.375rem; --text-xl:1.75rem; --text-2xl:2.25rem; --text-3xl:3rem;
    --text-4xl:4rem; --text-5xl:5.25rem;
    --leading-tight:1.08; --leading-snug:1.22; --leading-normal:1.5; --leading-relaxed:1.65;
    --tracking-tight:-0.02em; --tracking-normal:0; --tracking-wide:0.04em; --tracking-mono:0.06em;
    --weight-regular:400; --weight-medium:500; --weight-semibold:600; --weight-bold:700; --weight-extra:800;

    /* Space / radius / shadow */
    --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
    --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px; --space-10:128px;
    --radius-xs:4px; --radius-sm:8px; --radius-md:12px; --radius-lg:18px; --radius-xl:28px; --radius-pill:999px;
    --shadow-xs:0 1px 2px rgba(43,33,18,0.06); --shadow-sm:0 2px 6px rgba(43,33,18,0.07);
    --shadow-md:0 6px 18px rgba(43,33,18,0.09); --shadow-lg:0 18px 44px rgba(43,33,18,0.12);
    --shadow-focus:0 0 0 3px var(--green-100);

    /* Layout */
    --container:1120px; --container-wide:1320px; --container-read:720px;
    --gutter:24px; --section-y:96px;
    --dur-fast:120ms; --dur-base:200ms; --dur-slow:360ms;
    --ease-out:cubic-bezier(0.22,1,0.36,1); --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
}

/* ---------------------------------------------------------- Base */
*,*::before,*::after { box-sizing:border-box; }
* { margin:0; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
    font-family:var(--font-sans);
    font-size:var(--text-base);
    line-height:var(--leading-normal);
    color:var(--text-body);
    background:var(--bg-app);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;               /* no horizontal scroll */
}
img,svg,video { display:block; max-width:100%; height:auto; }
a { color:var(--text-link); text-decoration:none; transition:color var(--dur-fast) var(--ease-out); }
a:hover { color:var(--brand-press); text-decoration:underline; text-underline-offset:2px; }
:focus-visible { outline:2px solid var(--focus-ring); outline-offset:2px; border-radius:var(--radius-xs); }

h1,h2,h3,h4 { font-family:var(--font-display); color:var(--text-strong); font-weight:var(--weight-semibold); line-height:var(--leading-snug); letter-spacing:var(--tracking-tight); }
h1 { font-size:clamp(2.25rem,5vw,var(--text-4xl)); line-height:var(--leading-tight); }
h2 { font-size:clamp(1.75rem,3.5vw,var(--text-3xl)); }
h3 { font-size:clamp(1.375rem,2.5vw,var(--text-xl)); }
code,pre,kbd { font-family:var(--font-mono); }

/* ------------------------------------------------------- Layout */
.container { width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container-read { width:100%; max-width:var(--container-read); margin-inline:auto; padding-inline:var(--gutter); }

/* Skip link (a11y) */
.skip-link { position:absolute; left:-9999px; top:0; background:var(--brand); color:#fff; padding:var(--space-2) var(--space-4); border-radius:var(--radius-sm); z-index:100; }
.skip-link:focus { left:var(--space-3); top:var(--space-3); }

/* --------------------------------------------------------- Nav */
.site-header { position:sticky; top:0; z-index:50; background:color-mix(in srgb,var(--paper) 88%,transparent); backdrop-filter:blur(10px); border-bottom:1px solid var(--border-subtle); }
.site-header .container { display:flex; align-items:center; justify-content:space-between; min-height:64px; }
.brand-mark { font-family:var(--font-display); font-weight:var(--weight-bold); font-size:var(--text-lg); color:var(--text-strong); letter-spacing:var(--tracking-tight); }
.brand-mark:hover { text-decoration:none; }
.site-nav { display:flex; gap:var(--space-5); align-items:center; }
.site-nav a { color:var(--text-body); font-weight:var(--weight-medium); font-size:var(--text-sm); }
.site-nav a:hover { color:var(--brand); text-decoration:none; }
.site-nav a[aria-current="page"] { color:var(--brand-press); font-weight:var(--weight-semibold); }

/* --------------------------------------------------- Footer */
.site-footer { margin-top:var(--space-10); border-top:1px solid var(--border-subtle); background:var(--bg-sunk); }
.site-footer .container { display:flex; flex-wrap:wrap; gap:var(--space-4); justify-content:space-between; align-items:center; padding-block:var(--space-6); color:var(--text-muted); font-size:var(--text-sm); }
.site-footer a { color:var(--text-muted); }

/* --------------------------------------------------- Buttons */
.btn { display:inline-flex; align-items:center; gap:var(--space-2); font-weight:var(--weight-semibold); font-size:var(--text-sm); padding:var(--space-3) var(--space-5); border-radius:var(--radius-pill); border:1px solid transparent; cursor:pointer; transition:transform var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out); }
.btn:hover { text-decoration:none; }
.btn-primary { background:var(--brand); color:var(--text-on-brand); }
.btn-primary:hover { background:var(--brand-hover); color:#fff; transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--text-strong); border-color:var(--border-strong); }
.btn-ghost:hover { background:var(--surface); color:var(--text-strong); }

/* ---------------------------------------------------- Chips/badges */
.chip { display:inline-flex; align-items:center; font-family:var(--font-mono); font-size:var(--text-xs); letter-spacing:var(--tracking-mono); text-transform:uppercase; padding:2px var(--space-3); border-radius:var(--radius-pill); background:var(--brand-tint); color:var(--brand-press); }
.chip-accent { background:var(--accent-tint); color:var(--purple-600); }
.chip-pop { background:var(--pop-tint); color:var(--pink-600); }
.chip-gold { background:var(--highlight-tint); color:var(--gold-600); }

/* ============================================ Blog index */
.blog-hero { padding-block:var(--space-9) var(--space-7); }
.blog-hero .eyebrow { font-family:var(--font-mono); text-transform:uppercase; letter-spacing:var(--tracking-mono); font-size:var(--text-xs); color:var(--brand); }
.blog-hero h1 { margin-top:var(--space-3); max-width:16ch; }
.blog-hero p { margin-top:var(--space-4); font-size:var(--text-md); color:var(--text-muted); max-width:60ch; }

.post-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:var(--space-6); padding-bottom:var(--space-9); }

.post-card { display:flex; flex-direction:column; background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-xs); transition:box-shadow var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out); }
.post-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.post-card a { color:inherit; }
.post-card a:hover { text-decoration:none; }
.post-card__media { aspect-ratio:16/9; background:var(--bg-sunk); overflow:hidden; }
.post-card__media img { width:100%; height:100%; object-fit:cover; }
.post-card__body { display:flex; flex-direction:column; gap:var(--space-3); padding:var(--space-5); flex:1; }
.post-card__title { font-family:var(--font-display); font-size:var(--text-lg); line-height:var(--leading-snug); color:var(--text-strong); font-weight:var(--weight-semibold); }
.post-card:hover .post-card__title { color:var(--brand-press); }
.post-card__excerpt { font-size:var(--text-sm); color:var(--text-muted); line-height:var(--leading-normal); }
.post-card__meta { margin-top:auto; display:flex; gap:var(--space-3); align-items:center; font-family:var(--font-mono); font-size:var(--text-xs); color:var(--text-muted); letter-spacing:var(--tracking-wide); }

/* ============================================ Article (single) */
.article-header { padding-block:var(--space-8) var(--space-5); }
.article-header .kicker { display:flex; gap:var(--space-2); flex-wrap:wrap; margin-bottom:var(--space-4); }
.article-header h1 { max-width:20ch; }
.article-lede { margin-top:var(--space-4); font-family:var(--font-display); font-size:var(--text-lg); line-height:var(--leading-relaxed); color:var(--text-body); max-width:60ch; }
.article-meta { margin-top:var(--space-5); display:flex; gap:var(--space-4); align-items:center; flex-wrap:wrap; font-family:var(--font-mono); font-size:var(--text-xs); letter-spacing:var(--tracking-wide); color:var(--text-muted); }
.article-cover { margin-block:var(--space-6); }
.article-cover img { width:100%; border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); }

/* Article body typography (block content) */
.article-body { font-size:var(--text-md); line-height:var(--leading-relaxed); color:var(--text-body); }
.article-body > * + * { margin-top:var(--space-5); }
.article-body h2 { margin-top:var(--space-8); }
.article-body h3 { margin-top:var(--space-6); }
.article-body p { max-width:68ch; }
.article-body a { text-decoration:underline; text-underline-offset:2px; text-decoration-color:var(--green-100); }
.article-body a:hover { text-decoration-color:var(--brand); }
.article-body ul,.article-body ol { padding-left:var(--space-5); max-width:68ch; }
.article-body li + li { margin-top:var(--space-2); }
.article-body strong { color:var(--text-strong); font-weight:var(--weight-semibold); }

/* -------------------------------------------------- Blocks */
.post-rich-text > * + * { margin-top:var(--space-4); }

figure.post-image { margin-block:var(--space-6); }
figure.post-image img { width:100%; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); }
figure.post-image figcaption { margin-top:var(--space-2); font-size:var(--text-sm); color:var(--text-muted); text-align:center; font-style:italic; }

pre.post-code { background:#17171E; color:#EDE7DA; padding:var(--space-5); border-radius:var(--radius-md); overflow-x:auto; font-size:var(--text-sm); line-height:var(--leading-normal); box-shadow:var(--shadow-sm); }
pre.post-code code { font-family:var(--font-mono); }
:not(pre) > code { background:var(--paper-sunk); color:var(--accent); padding:2px 6px; border-radius:var(--radius-xs); font-size:0.9em; }

blockquote.post-quote { border-left:3px solid var(--brand); padding:var(--space-2) var(--space-5); background:var(--brand-tint); border-radius:0 var(--radius-md) var(--radius-md) 0; }
blockquote.post-quote p { font-family:var(--font-display); font-size:var(--text-lg); color:var(--text-strong); max-width:none; }
blockquote.post-quote cite { display:block; margin-top:var(--space-2); font-family:var(--font-mono); font-size:var(--text-xs); font-style:normal; color:var(--text-muted); }

.post-gallery { margin-block:var(--space-6); display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:var(--space-3); }
.post-gallery img { width:100%; height:100%; object-fit:cover; border-radius:var(--radius-md); box-shadow:var(--shadow-xs); }

aside.post-cta { margin-block:var(--space-7); padding:var(--space-6); background:var(--accent-tint); border:1px solid var(--purple-100); border-radius:var(--radius-lg); text-align:center; }
aside.post-cta h3 { color:var(--purple-600); }
aside.post-cta p { margin:var(--space-3) 0 var(--space-5); color:var(--text-body); max-width:none; }
.post-cta-button { display:inline-flex; padding:var(--space-3) var(--space-6); border-radius:var(--radius-pill); background:var(--accent); color:#fff; font-weight:var(--weight-semibold); }
.post-cta-button:hover { background:var(--purple-600); color:#fff; text-decoration:none; }

.post-embed { margin-block:var(--space-6); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); }

/* Tags footer */
.article-tags { margin-top:var(--space-8); padding-top:var(--space-5); border-top:1px solid var(--border-subtle); display:flex; gap:var(--space-2); flex-wrap:wrap; }

/* ------------------------------------------------- Responsive */
@media (max-width:640px) {
    :root { --gutter:16px; --section-y:64px; }
    .site-nav { gap:var(--space-4); }
    .article-body p,.article-body ul,.article-body ol { max-width:none; }
}

/* ============================================ Homepage */
.home-hero { padding-block:var(--space-9) var(--space-7); }
.home-hero .eyebrow { font-family:var(--font-mono); text-transform:uppercase; letter-spacing:var(--tracking-mono); font-size:var(--text-xs); color:var(--brand); }
.home-hero h1 { margin-top:var(--space-4); max-width:18ch; font-size:clamp(2.5rem,6vw,var(--text-5xl)); }
.home-hero h1 em { font-style:italic; color:var(--brand-press); }
.home-hero__lede { margin-top:var(--space-5); font-family:var(--font-display); font-size:var(--text-lg); line-height:var(--leading-relaxed); color:var(--text-body); max-width:56ch; }
.home-hero__actions { margin-top:var(--space-6); display:flex; gap:var(--space-3); flex-wrap:wrap; }
.home-tags { margin-top:var(--space-6); display:flex; gap:var(--space-2); flex-wrap:wrap; list-style:none; padding:0; }

.home-section { padding-block:var(--space-8) 0; }
.section-head { display:flex; align-items:baseline; justify-content:space-between; gap:var(--space-4); margin-bottom:var(--space-6); flex-wrap:wrap; }
.section-link { font-family:var(--font-mono); font-size:var(--text-sm); color:var(--brand); white-space:nowrap; }
.muted-note { color:var(--text-muted); }

.home-cta { margin-block:var(--space-8); padding:var(--space-8); background:var(--brand-tint); border:1px solid var(--green-100); border-radius:var(--radius-xl); text-align:center; }
.home-cta h2 { color:var(--brand-press); }
.home-cta p { margin:var(--space-3) auto var(--space-5); color:var(--text-body); max-width:48ch; }

/* ============================================ Project case study */
.breadcrumb { font-family:var(--font-mono); font-size:var(--text-xs); letter-spacing:var(--tracking-wide); color:var(--text-muted); margin-bottom:var(--space-4); }
.tech-list { display:flex; gap:var(--space-2); flex-wrap:wrap; list-style:none; padding:0; margin-top:var(--space-5); }
.project-links { margin-top:var(--space-6); display:flex; gap:var(--space-3); flex-wrap:wrap; }
.case-study .case-section { margin-top:var(--space-8); }
.case-study .case-section h2 { margin-bottom:var(--space-4); }
.case-study .case-section ul { padding-left:var(--space-5); }
.case-study .case-section li + li { margin-top:var(--space-2); }

/* ============================================ Contact form */
.contact-form { display:flex; flex-direction:column; gap:var(--space-5); margin-top:var(--space-6); max-width:560px; }
.contact-form .field { display:flex; flex-direction:column; gap:var(--space-2); }
.contact-form label { font-weight:var(--weight-semibold); font-size:var(--text-sm); color:var(--text-strong); }
.contact-form input, .contact-form textarea {
    font-family:var(--font-sans); font-size:var(--text-base); color:var(--text-strong);
    padding:var(--space-3) var(--space-4); background:var(--surface);
    border:1px solid var(--border-strong); border-radius:var(--radius-sm);
    transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);
}
.contact-form input:focus, .contact-form textarea:focus { outline:none; border-color:var(--brand); box-shadow:var(--shadow-focus); }
.contact-form button { align-self:flex-start; }
.contact-links { margin-top:var(--space-6); display:flex; gap:var(--space-4); font-family:var(--font-mono); font-size:var(--text-sm); }

.alert-success { padding:var(--space-4) var(--space-5); background:var(--green-50); border:1px solid var(--green-100); border-radius:var(--radius-md); color:var(--green-700); margin-bottom:var(--space-5); }
.alert-error { padding:var(--space-4) var(--space-5); background:var(--pink-50); border:1px solid var(--pink-100); border-radius:var(--radius-md); color:var(--pink-600); margin-bottom:var(--space-5); }
.alert-error ul { padding-left:var(--space-5); }

@media (prefers-reduced-motion:reduce) {
    * { transition:none !important; scroll-behavior:auto !important; }
}
