/* self-hosted fonts */
/* Hanken Grotesk 400 normal · latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Hanken Grotesk 400 normal · latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-400-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Hanken Grotesk 500 normal · latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Hanken Grotesk 500 normal · latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Hanken Grotesk 600 normal · latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Hanken Grotesk 600 normal · latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Hanken Grotesk 700 normal · latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-700-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Hanken Grotesk 700 normal · latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/assets/fonts/hanken-grotesk-700-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 400 italic · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/newsreader-400-italic-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 400 italic · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/newsreader-400-italic-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 500 italic · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/newsreader-500-italic-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 500 italic · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/newsreader-500-italic-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 300 normal · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(/assets/fonts/newsreader-300-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 300 normal · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(/assets/fonts/newsreader-300-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 400 normal · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/newsreader-400-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 400 normal · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/newsreader-400-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 500 normal · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/newsreader-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 500 normal · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/fonts/newsreader-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Newsreader 600 normal · latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/newsreader-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Newsreader 600 normal · latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/newsreader-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Source Serif 4 400 italic · latin-ext */
@font-face {
  font-family: 'Source Serif 4';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-400-italic-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Source Serif 4 400 italic · latin */
@font-face {
  font-family: 'Source Serif 4';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-400-italic-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Source Serif 4 400 normal · latin-ext */
@font-face {
  font-family: 'Source Serif 4';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-400-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Source Serif 4 400 normal · latin */
@font-face {
  font-family: 'Source Serif 4';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-400-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Source Serif 4 600 normal · latin-ext */
@font-face {
  font-family: 'Source Serif 4';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Source Serif 4 600 normal · latin */
@font-face {
  font-family: 'Source Serif 4';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/fonts/source-serif-4-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ============================================================
   CIRCLE OF GOOD — Handmade / canvas system
   ============================================================ */
:root{
  --purple:#7143AD;
  --purple-ink:#7143AD;
  --purple-deep:#4A2A77;
  --purple-wash:#ECE6F2;

  --paper:#F4F1E8;           /* refined warm ivory */
  --paper-2:#EAE5D8;
  --card:#FCFAF4;
  --ink:#171514;             /* true editorial near-black */
  --ink-2:#46423C;
  --mute:#8C8576;
  --line:#DED8C9;
  --line-ink:rgba(255,255,255,.14);

  --display:"Newsreader", Georgia, serif;
  --serif:"Source Serif 4", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, sans-serif;
  --script:"Newsreader", Georgia, serif;

  --maxw:1240px;
  --gutter:clamp(20px,5vw,76px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
:root[data-mood="night"]{ --paper:#171514; --paper-2:#100F0E; --card:#211E1B; --ink:#F4F1E8; --ink-2:#CFC9BD; --mute:#928B7D; --line:rgba(255,255,255,.13); --purple-ink:#B89AE0; }

*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--serif); background:var(--paper); color:var(--ink);
  line-height:1.55; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
  position:relative;
}
/* canvas weave texture */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background-color:var(--paper);
  background-image:
    repeating-linear-gradient(0deg, rgba(120,100,70,.022) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(90deg, rgba(120,100,70,.022) 0 1px, transparent 1px 5px);
}
/* paper grain */
body::after{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.35; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
}
img,svg,video,iframe{ display:block; max-width:100%; }
/* <picture> must be transparent to layout so a wrapped <img> keeps its CSS sizing */
picture{ display:contents; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
::selection{ background:var(--purple); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.pad{ padding-block:clamp(30px,3.6vw,56px); }
section{ position:relative; }

/* ---------- Type ---------- */
.kicker{ font-family:var(--sans); font-weight:600; font-size:clamp(.74rem,.9vw,.82rem); letter-spacing:.24em; text-transform:uppercase; color:var(--purple-ink); line-height:1; display:inline-flex; align-items:center; gap:.7em; }
.kicker::before{ content:""; width:28px; height:1px; background:var(--purple-ink); opacity:.6; }
.kicker.solo::before{ display:none; }
h1,h2,h3{ font-family:var(--display); font-weight:500; line-height:1.02; letter-spacing:-.018em; color:var(--ink); }
.t1{ font-size:clamp(2.6rem,6vw,5rem); }
.t2{ font-size:clamp(2rem,4vw,3.3rem); }
.t3{ font-size:clamp(1.5rem,2.4vw,2.1rem); }
.script{ font-family:var(--display); font-weight:500; color:var(--purple-ink); letter-spacing:-.01em; line-height:1; }
.s1{ font-family:var(--display); font-weight:500; color:var(--ink); font-size:clamp(3rem,8vw,6.4rem); line-height:1; letter-spacing:-.02em; }
/* "What we are working on" (Our Work) — sized to stay on one line at every width */
.phero h1.owfit{ font-size:clamp(1.4rem,7.6vw,6.2rem) !important; }
/* Values hero lead — drop the 60ch cap so it sits on one line on desktop (wraps on phones) */
.phero .vlead{ max-width:none; }
.lead{ font-size:clamp(1.1rem,1.4vw,1.35rem); line-height:1.6; color:var(--ink-2); max-width:60ch; text-wrap:pretty; }
.muted{ color:var(--mute); } .pp{ color:var(--purple-ink); }
em,.it{ font-style:italic; }

/* underline keyword (subtle) */
.uline{ position:relative; display:inline-block; white-space:nowrap; }
.uline svg{ position:absolute; left:-1%; bottom:-.22em; width:102%; height:.4em; overflow:visible; }
.uline svg path{ fill:none; stroke:var(--purple); stroke-width:2; stroke-linecap:round; }
/* circle-a-word: retired for editorial look */
.hand{ position:relative; display:inline; font-style:italic; color:var(--purple-ink); }
.hand svg{ display:none; }

/* ---------- Doodles (restrained) ---------- */
.doodle{ position:absolute; overflow:visible; pointer-events:none; z-index:5; }
.doodle path{ fill:none; stroke:var(--purple); stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; }
.doodle.fillp{ display:none; }

/* ---------- Buttons (typographic, editorial) ---------- */
.dbtn{ display:inline-flex; align-items:center; gap:0; position:relative; overflow:hidden; padding:1.15em 2.1em; font-family:var(--sans); font-weight:600; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; background:var(--ink); white-space:nowrap; box-shadow:inset 0 0 0 1px var(--ink); transition:color .4s var(--ease), letter-spacing .45s var(--ease), box-shadow .4s; }
.dbtn>*{ position:relative; z-index:1; }
.dbtn .ar,.dbtn .dbtn__c{ display:none !important; }
.dbtn::before{ content:""; position:absolute; inset:0; z-index:0; background:var(--purple); transform:translateY(102%); transition:transform .55s var(--ease-out); }
.dbtn:hover::before{ transform:none; }
.dbtn:hover{ letter-spacing:.24em; }
.dbtn span{ position:relative; display:inline-block; }
.dbtn span::after{ content:""; position:absolute; left:0; right:100%; bottom:-.5em; height:1px; background:currentColor; opacity:.55; transition:right .5s var(--ease) .04s; }
.dbtn:hover span::after{ right:0; }
.dbtn--lg{ font-size:.86rem; padding:1.3em 2.4em; }
.dbtn--ondark{ background:#fff; color:var(--ink); box-shadow:inset 0 0 0 1px #fff; } .dbtn--ondark::before{ background:var(--purple); } .dbtn--ondark:hover{ color:#fff; }
.dbtn--ghost{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1px var(--line); } .dbtn--ghost::before{ background:var(--purple); } .dbtn--ghost:hover{ color:#fff; box-shadow:inset 0 0 0 1px var(--purple); }

/* arrow text-link */
.alink{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--sans); font-weight:600; font-size:.92rem; letter-spacing:.02em; color:var(--ink); position:relative; padding-bottom:3px; white-space:nowrap; }
.alink svg{ transition:transform .35s var(--ease); }
.alink:hover svg{ transform:translate(3px,-3px); }
.alink::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:1.5px; background:var(--purple); transform:scaleX(1); transform-origin:right; transition:transform .4s var(--ease); }
.alink:hover::after{ transform:scaleX(0); transform-origin:left; }

/* ---------- Reveal ---------- */
html.js .rv{ opacity:0; transform:translateY(24px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
html.js .rv.in{ opacity:1; transform:none; }
.rv[data-d="1"]{ transition-delay:.08s; } .rv[data-d="2"]{ transition-delay:.16s; }
.rv[data-d="3"]{ transition-delay:.24s; } .rv[data-d="4"]{ transition-delay:.32s; } .rv[data-d="5"]{ transition-delay:.40s; }
html.js .clip{ overflow:hidden; } html.js .clip>*{ display:block; transform:translateY(110%); transition:transform 1s var(--ease-out); }
html.js .clip.in>*{ transform:none; }
@media (prefers-reduced-motion:reduce){ html.js .rv{ opacity:1!important; transform:none!important; } }

/* ---------- B&W photo (colors on hover) ---------- */
.bw{ filter:grayscale(1) contrast(1.04) brightness(.99); transition:filter .7s var(--ease); }
.bw:hover{ filter:grayscale(0) contrast(1); }
/* photo frame */
.photo{ position:relative; background:var(--card); padding:10px; box-shadow:0 18px 44px rgba(23,21,20,.14); border:1px solid var(--line); }
.photo image-slot,.photo .ph,.photo img{ width:100%; display:block; height:auto; }
/* content photos carry width/height attrs for CLS; let aspect-ratio drive height */
.photo img[style*="aspect-ratio"]{ height:auto; }
.tilt{ transition:transform .5s var(--ease), box-shadow .5s; }
.tilt:hover{ transform:translateY(-5px); box-shadow:0 26px 56px rgba(23,21,20,.2); }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; inset:0 0 auto 0; z-index:1000; padding-block:10px; background:var(--ink); box-shadow:none; transition:transform .45s var(--ease), padding .4s var(--ease), box-shadow .5s; }
.nav.solid{ background:var(--ink); box-shadow:0 1px 0 rgba(255,255,255,.1); padding-block:8px; }
.nav.hide{ transform:translateY(-100%); }
.nav__row{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand img{ height:50px; width:auto; transition:height .4s var(--ease); }
.nav.solid .brand img{ height:44px; }
.nav__links{ display:flex; align-items:center; gap:clamp(13px,1.7vw,30px); }
.nav__links a{ font-family:var(--sans); font-weight:500; font-size:.8rem; letter-spacing:.05em; text-transform:uppercase; color:rgba(255,255,255,.7); position:relative; padding:2px 0; line-height:1; white-space:nowrap; }
.nav__links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-3px; height:1.5px; background:var(--purple); transition:right .4s var(--ease); }
.nav__links a:hover,.nav__links a.on{ color:#fff; } .nav__links a:hover::after,.nav__links a.on::after{ right:0; }
.nav .dbtn{ padding:.85em 1.3em; font-size:.72rem; letter-spacing:.16em; background:var(--purple); box-shadow:inset 0 0 0 1px var(--purple); }
.nav .dbtn::before{ background:#fff; }
.nav .dbtn:hover{ color:var(--ink); letter-spacing:.2em; }
.burger{ display:none; width:46px; height:46px; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.burger span{ width:22px; height:2px; background:#fff; border-radius:2px; }
@media (max-width:920px){ .nav__links,.nav__cta .full{ display:none; } .burger{ display:flex; } }
.mmenu{ position:fixed; inset:0; z-index:1500; background:var(--ink); color:var(--paper); display:flex; flex-direction:column; justify-content:center; padding:var(--gutter); gap:2px; clip-path:circle(0% at 92% 4%); transition:clip-path .7s var(--ease-out); pointer-events:none; }
.mmenu.open{ clip-path:circle(150% at 92% 4%); pointer-events:auto; }
.mmenu a{ font-family:var(--display); font-weight:500; font-size:clamp(2.4rem,10vw,4rem); color:var(--paper); padding:6px 0; line-height:1.05; letter-spacing:-.02em; }
.mmenu a:hover{ color:var(--purple-ink); }
.mmenu .x{ position:absolute; top:20px; right:var(--gutter); width:48px; height:48px; display:flex; align-items:center; justify-content:center; font-size:1.6rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ min-height:auto; display:flex; align-items:center; padding-top:clamp(104px,12vh,138px); padding-bottom:clamp(28px,4vh,48px); }
.hero__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; width:100%; }
.hero__eb{ margin-bottom:18px; }
.hero h1{ font-size:clamp(3rem,7vw,6rem); font-weight:600; }
.hero h1 .ln{ display:block; overflow:hidden; padding-bottom:.14em; }
html.js .hero h1 .ln>span{ display:block; transform:translateY(112%); transition:transform 1.05s var(--ease-out); }
html.js .hero.show h1 .ln>span{ transform:none; }
.hero h1 .big{ font-family:var(--display); font-style:italic; font-weight:500; color:var(--purple-ink); font-size:clamp(3.4rem,9vw,8rem); display:inline-block; line-height:1; letter-spacing:-.02em; }
.hero__lead{ margin-top:24px; max-width:44ch; }
.hero__cta{ margin-top:30px; display:flex; flex-wrap:wrap; gap:24px; align-items:center; }
.hero__side{ position:relative; }
.hero__heart{ position:absolute; right:-2%; top:-8%; width:96px; z-index:6; }
.hero__tag{ position:absolute; left:-22px; bottom:26px; z-index:7; background:var(--ink); color:var(--paper); padding:16px 20px; box-shadow:0 14px 30px rgba(23,21,20,.28); }
.hero__tag b{ font-family:var(--display); font-style:italic; font-weight:500; font-size:2rem; display:block; line-height:1; color:#fff; }
.hero__tag span{ font-size:.78rem; color:rgba(255,255,255,.72); letter-spacing:.02em; }
.hmtag{ display:none; }   /* mobile-only ₹208 copy (shown above Donate on phones) */
.hero__scroll{ position:absolute; left:var(--gutter); bottom:22px; font-family:var(--sans); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--mute); display:flex; align-items:center; gap:10px; }
.hero__scroll .ln{ width:42px; height:2px; background:var(--mute); position:relative; overflow:hidden; }
.hero__scroll .ln::after{ content:""; position:absolute; inset:0; background:var(--purple); transform:translateX(-100%); animation:slide 2.2s var(--ease) infinite; }
@keyframes slide{ 50%{ transform:translateX(0); } 100%{ transform:translateX(100%); } }
@media (max-width:880px){ .hero__grid{ grid-template-columns:1fr; } .hero__side{ display:none; } .hero{ padding-top:120px; } }

/* marquee — editorial */
.marq{ background:var(--ink); color:#fff; padding:18px 0; overflow:hidden; }
.marq__t{ display:flex; gap:46px; width:max-content; white-space:nowrap; animation:marq 32s linear infinite; }
.marq__t>span{ display:flex; align-items:center; gap:46px; font-family:var(--sans); font-weight:500; font-size:.92rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.92); }
.marq__t>span::after{ content:""; width:26px; height:26px; flex:none; opacity:.95; background:url("/assets/img/marq.webp") center/contain no-repeat; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(32px,6vw,90px); align-items:start; }
.about__l{ position:sticky; top:118px; }
.about__l .t2{ margin-top:12px; }
.about__copy p{ font-size:clamp(1.18rem,1.6vw,1.5rem); line-height:1.62; color:var(--ink-2); margin-bottom:1em; text-wrap:pretty; }
.about__copy p strong{ color:var(--ink); font-weight:700; }
.about__copy .big{ font-family:var(--display); font-style:italic; font-weight:500; font-size:clamp(2rem,3.6vw,3rem); line-height:1.12; color:var(--ink); margin:0 0 .6em; letter-spacing:-.01em; }
.about__mini{ margin-top:34px; display:flex; gap:28px; flex-wrap:wrap; }
.about__mini .it b{ font-family:var(--script); font-weight:700; font-size:3rem; color:var(--purple-ink); display:block; line-height:.9; }
.about__mini .it span{ font-size:.95rem; color:var(--mute); margin-top:6px; display:block; max-width:18ch; }
@media (max-width:820px){ .about__grid{ grid-template-columns:1fr; } .about__l{ position:static; } }

/* ============================================================
   PORTFOLIO  (zine poster)
   ============================================================ */
.port__head{ text-align:left; max-width:760px; margin:0 0 clamp(20px,2.6vw,40px); }
.pcard{ background:var(--card); border:1px solid var(--line); box-shadow:0 14px 40px rgba(33,28,21,.1); position:relative; margin-bottom:clamp(18px,2.4vw,30px); display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(22px,3.2vw,48px); align-items:center; padding:clamp(16px,1.8vw,26px); }
.pcard--flip{ grid-template-columns:1.18fr .82fr; }
.pcard--flip .pcard__photo{ order:2; }
@media (max-width:760px){ .pcard,.pcard--flip{ grid-template-columns:1fr; } .pcard--flip .pcard__photo{ order:0; } }
.pcard__photo{ position:relative; }
.pcard__photo .photo img,.pcard__photo .ph{ aspect-ratio:4/3; background:var(--paper-2); }
.pcard__kick{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); }
.pcard__title{ font-family:var(--display); font-style:italic; font-weight:500; color:var(--purple-ink); font-size:clamp(1.9rem,3vw,2.7rem); line-height:.98; letter-spacing:-.01em; margin:4px 0 10px; }
.pcard__lead{ font-size:clamp(1rem,1.2vw,1.12rem); line-height:1.55; color:var(--ink-2); }
.pcard__stats{ display:flex; gap:32px; margin:16px 0 14px; }
.pstat .n{ font-family:var(--display); font-style:italic; font-weight:500; font-size:clamp(2rem,3.2vw,2.8rem); color:var(--purple-ink); line-height:.85; }
.pstat .l{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); margin-top:7px; }
.pcard__tags{ display:flex; flex-wrap:wrap; gap:8px; }
.tag{ font-family:var(--sans); font-weight:500; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--purple-ink); padding:5px 11px; border:1px solid var(--line); }
/* 3-step flow */
.flow{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:18px; padding-top:16px; border-top:1px dashed var(--line); }
.flow__step{ font-family:var(--serif); font-size:.9rem; color:var(--ink); line-height:1.25; }
.flow__step b{ color:var(--purple-ink); font-family:var(--display); font-style:italic; font-weight:500; font-size:1.1rem; display:block; }
.flow__arrow{ width:42px; height:22px; flex:none; }
.flow__arrow path{ fill:none; stroke:var(--purple); stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round; }

/* ============================================================
   IMPACT — ledger / receipt + slider
   ============================================================ */
.impact__head{ max-width:820px; margin-bottom:clamp(22px,2.6vw,38px); }
.calc{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(26px,4vw,56px); align-items:start; }
@media (max-width:900px){ .calc{ grid-template-columns:1fr; } }
.ledger{ background:var(--card); border:1px solid var(--line); padding:clamp(26px,3.4vw,46px); position:relative; box-shadow:0 18px 50px rgba(33,28,21,.1); }
.ledger::after{ content:""; position:absolute; left:0; right:0; bottom:-12px; height:12px; background:
  radial-gradient(circle at 8px 0, transparent 7px, var(--card) 7px) repeat-x; background-size:16px 12px; filter:drop-shadow(0 4px 3px rgba(33,28,21,.06)); }
.ledger__label{ font-family:var(--sans); font-weight:600; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--purple-ink); display:inline-block; }
.ledger__big{ font-family:var(--serif); font-weight:700; font-size:clamp(3.4rem,6vw,5.4rem); line-height:.85; margin-top:8px; }
.ledger__big .cur{ color:var(--purple-ink); }
.ledger__per{ color:var(--mute); }
.bd{ margin-top:30px; display:flex; flex-direction:column; gap:18px; }
.bd__row .top{ display:flex; justify-content:space-between; align-items:baseline; font-size:1rem; margin-bottom:8px; }
.bd__row .top b{ font-family:var(--script); font-weight:700; font-size:1.4rem; color:var(--ink); }
.bar{ height:10px; background:var(--purple-wash); overflow:hidden; }
.bar>i{ display:block; height:100%; width:0; transition:width 1.3s var(--ease-out); }
.bar.a>i{ background:var(--purple); } .bar.b>i{ background:var(--ink); }
.slider{ margin-top:32px; padding-top:26px; border-top:1px dashed var(--line); }
.slider label{ font-family:var(--sans); font-weight:600; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--purple-ink); }
.range{ -webkit-appearance:none; appearance:none; width:100%; height:6px; background:var(--purple-wash); margin-top:16px; outline:none; }
.range::-webkit-slider-thumb{ -webkit-appearance:none; width:30px; height:30px; border-radius:50%; background:var(--purple); border:5px solid var(--card); box-shadow:0 4px 12px rgba(113,67,173,.4); cursor:grab; }
.range::-webkit-slider-thumb:active{ cursor:grabbing; transform:scale(1.1); }
.range::-moz-range-thumb{ width:30px; height:30px; border-radius:50%; background:var(--purple); border:5px solid var(--card); cursor:grab; }
.calc__out{ margin-top:26px; display:flex; justify-content:space-between; align-items:flex-end; gap:18px; }
.calc__out .tot{ font-family:var(--serif); font-weight:700; font-size:clamp(2.6rem,4.4vw,3.6rem); line-height:.9; color:var(--purple-ink); }
.calc__out .cap{ font-size:.9rem; color:var(--mute); margin-top:6px; }
.calc__out .kids b{ font-family:var(--script); font-weight:700; font-size:2.6rem; color:var(--ink); display:block; line-height:.8; }
.tiers{ display:flex; flex-direction:column; gap:16px; }
.tier{ display:flex; align-items:center; gap:20px; padding:20px 22px; background:var(--card); border:1px solid var(--line); cursor:pointer; transition:transform .35s var(--ease), box-shadow .35s; position:relative; }
.tier:hover,.tier.active{ transform:translateX(4px); box-shadow:0 14px 34px rgba(23,21,20,.1); border-color:var(--purple); }
.tier__amt{ font-family:var(--script); font-weight:700; font-size:clamp(2rem,3vw,2.7rem); color:var(--purple-ink); min-width:4.2ch; line-height:.85; }
.tier__t b{ display:block; font-weight:600; font-size:1.05rem; } .tier__t span{ color:var(--mute); font-size:.95rem; }
.tier__ar{ margin-left:auto; flex:none; color:var(--purple); transition:transform .35s var(--ease); }
.tier:hover .tier__ar{ transform:translate(4px,-4px); }
.disc{ margin-top:22px; font-size:.82rem; font-style:italic; color:var(--mute); max-width:60ch; }

/* live impact dot-meter */
.cmeter__box{ margin:16px 0 2px; }
.cmeter{ display:flex; gap:7px; flex-wrap:wrap; }
.cdot{ width:13px; height:13px; border-radius:50%; background:var(--purple-wash); transition:background .25s var(--ease), transform .25s var(--ease); }
.cdot.on{ background:var(--purple); transform:scale(1.06); }
.cmeter__cap{ margin-top:11px; font-family:var(--sans); font-size:.82rem; letter-spacing:.01em; color:var(--mute); }
.impact--mini .cmeter__box{ margin:13px 0 2px; }
.impact--mini .cdot{ width:11px; height:11px; }

/* ============================================================
   VALUES
   ============================================================ */
.values__head{ max-width:760px; margin-bottom:clamp(20px,2.6vw,38px); }
.vrow{ display:grid; grid-template-columns:90px 1fr 1.1fr; gap:clamp(16px,3vw,52px); padding:clamp(26px,3.4vw,44px) 0; border-top:1px solid var(--line); align-items:start; }
.vrow:last-child{ border-bottom:1px solid var(--line); }
.vrow__n{ font-family:var(--script); font-weight:700; font-size:clamp(2.4rem,3vw,3.2rem); color:var(--purple-ink); line-height:.8; }
.vrow__t{ font-family:var(--serif); font-weight:600; font-size:clamp(1.6rem,2.6vw,2.3rem); line-height:1.05; }
.vrow__b{ color:var(--ink-2); font-size:clamp(1.02rem,1.3vw,1.18rem); line-height:1.6; align-self:center; text-wrap:pretty; }
.vrow:hover .vrow__t{ color:var(--purple-ink); }
@media (max-width:760px){ .vrow{ grid-template-columns:52px 1fr; } .vrow__b{ grid-column:1/-1; padding-left:68px; align-self:auto; } }

/* ============================================================
   FILM
   ============================================================ */
.film__head{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(24px,4vw,56px); align-items:end; margin-bottom:clamp(34px,4vw,58px); }
@media (max-width:760px){ .film__head{ grid-template-columns:1fr; } }
.film__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,4vw,42px); }
@media (max-width:760px){ .film__grid{ grid-template-columns:1fr; } }
.vframe{ position:relative; background:var(--card); padding:10px 10px 42px; box-shadow:0 18px 46px rgba(23,21,20,.14); border:1px solid var(--line); }
.vframe .scr{ position:relative; aspect-ratio:16/9; background:#000; overflow:hidden; }
.vframe iframe{ width:100%; height:100%; border:0; }
.vframe .cap{ position:absolute; left:12px; bottom:13px; font-family:var(--sans); font-weight:500; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mute); }

/* ============================================================
   DONATE
   ============================================================ */
.donate{ text-align:center; overflow:hidden; }
.donate__inner{ max-width:860px; margin:0 auto; position:relative; z-index:2; }
.donate .s1{ margin:8px 0 22px; line-height:.92; }
.donate p{ font-size:1.2rem; color:var(--ink-2); max-width:50ch; margin:18px auto 34px; }
.trust{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px 26px; margin-top:40px; }
.chip{ display:flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:500; font-size:.86rem; letter-spacing:.04em; color:var(--ink-2); }
.chip svg{ color:var(--purple); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--ink); color:rgba(255,255,255,.66); padding:clamp(34px,4vw,48px) 0 18px; position:relative; overflow:hidden; }
.foot__cta{ position:relative; z-index:1; display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; padding-bottom:22px; margin-bottom:22px; border-bottom:1px solid rgba(255,255,255,.14); }
.foot__cta h2{ color:#fff; font-size:clamp(1.4rem,2.6vw,2.1rem); font-style:italic; font-weight:400; }
.foot__wm{ position:absolute; right:-46px; bottom:-56px; width:220px; height:220px; opacity:.08; background:url("/assets/img/wmark.webp") center/contain no-repeat; filter:brightness(0) invert(1); }
.foot__wm>*{ display:none; }
.foot__in{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; padding-bottom:20px; }
.foot__in img{ height:64px; }
.foot__nav{ display:flex; flex-wrap:wrap; gap:clamp(14px,2vw,28px); }
.foot__nav a{ font-family:var(--sans); font-weight:500; font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.7); transition:.25s; white-space:nowrap; }
.foot__nav a:hover{ color:#fff; }
.foot__social{ display:flex; gap:9px; }
.foot__social a{ width:36px; height:36px; display:flex; align-items:center; justify-content:center; color:#fff; box-shadow:inset 0 0 0 1px rgba(255,255,255,.22); transition:.3s; }
.foot__social a:hover{ background:var(--purple); box-shadow:inset 0 0 0 1px var(--purple); }
.foot__bottom{ position:relative; z-index:1; display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; padding-top:16px; border-top:1px solid rgba(255,255,255,.14); font-size:.8rem; color:rgba(255,255,255,.5); }
.foot__bottom .lk{ display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.foot__bottom a{ color:rgba(255,255,255,.62); transition:.25s; }
.foot__bottom a:hover{ color:#fff; }
@media (max-width:620px){ .foot__in{ flex-direction:column; align-items:flex-start; gap:18px; } }

/* ---------- Watermarks & scattered doodles ---------- */
.wmark{ position:absolute; pointer-events:none; z-index:0; opacity:.06;
  background:url("/assets/img/wmark.webp") center/contain no-repeat; }
section>.wrap{ position:relative; z-index:1; }
.scatter{ display:none; }
.float{ animation:none; }

/* ---------- Sub-page hero, teasers, CTA band ---------- */
.phero{ padding-top:clamp(106px,11vw,140px); padding-bottom:clamp(14px,1.8vw,26px); text-align:center; position:relative; }
.phero .kicker{ margin-bottom:8px; }
.phero .lead{ margin:18px auto 0; }
.tease{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,30px); }
@media (max-width:780px){ .tease{ grid-template-columns:1fr; } }
.tcard{ background:var(--card); border:1px solid var(--line); padding:clamp(26px,3vw,40px); position:relative; transition:transform .4s var(--ease), box-shadow .4s; display:flex; flex-direction:column; }
.tcard:hover{ transform:translateY(-6px); box-shadow:0 22px 54px rgba(23,21,20,.13); border-color:var(--purple); }
.tcard .cmark{ display:none; }
.tcard h3{ font-family:var(--display); font-weight:500; color:var(--ink); font-size:clamp(1.7rem,2.6vw,2.3rem); margin-bottom:12px; line-height:1.05; letter-spacing:-.01em; }
.tcard p{ color:var(--ink-2); line-height:1.55; margin-bottom:20px; flex:1; }
.cmark path{ fill:none; stroke:currentColor; stroke-width:3.2; stroke-linecap:round; stroke-linejoin:round; }
.cmark circle[fill]{ fill:currentColor; stroke:none; }
.cta{ text-align:center; padding-block:clamp(36px,4.5vw,64px); position:relative; }
.cta .s1{ margin:8px 0 22px; line-height:.92; }
.cta p{ font-size:1.2rem; color:var(--ink-2); max-width:48ch; margin:0 auto 30px; }

/* ---------- Stat band ---------- */
.stats{ border-block:1px solid var(--line); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stats__grid .st{ padding:clamp(20px,2.8vw,34px) clamp(16px,2vw,28px); text-align:center; border-left:1px solid var(--line); }
.stats__grid .st:first-child{ border-left:none; }
.stats__grid .st .n{ font-family:var(--display); font-weight:500; font-size:clamp(2.6rem,5vw,4rem); line-height:1; color:var(--ink); letter-spacing:-.02em; }
.stats__grid .st .n .pp{ color:var(--purple-ink); }
.stats__grid .st .l{ font-family:var(--sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); margin-top:12px; }
@media (max-width:720px){ .stats__grid{ grid-template-columns:1fr 1fr; } .stats__grid .st:nth-child(odd){ border-left:none; } .stats__grid .st:nth-child(n+3){ border-top:1px solid var(--line); } }

/* ---------- Contact / form ---------- */
.contact__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(32px,6vw,80px); align-items:start; }
@media (max-width:820px){ .contact__grid{ grid-template-columns:1fr; } }
.contact__aside .lead{ margin-bottom:30px; }
/* keep "Reach us directly." on one line inside the narrow aside column */
.contact__aside .t2{ font-size:clamp(2rem,3.7vw,2.9rem); }
.cinfo{ display:flex; flex-direction:column; gap:2px; margin-top:26px; }
.cinfo a{ display:flex; align-items:center; gap:14px; padding:16px 0; border-top:1px solid var(--line); color:var(--ink); transition:color .25s, padding .25s; }
.cinfo a:last-child{ border-bottom:1px solid var(--line); }
.cinfo a:hover{ color:var(--purple-ink); padding-left:6px; }
.cinfo a svg{ flex:none; color:var(--purple); }
.cinfo a .ci__l{ font-family:var(--sans); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mute); display:block; margin-bottom:3px; }
.cinfo a .ci__v{ font-size:1.05rem; white-space:nowrap; }
.form{ background:var(--card); border:1px solid var(--line); padding:clamp(26px,3.4vw,46px); }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .form__row{ grid-template-columns:1fr; } }
.field{ margin-bottom:20px; position:relative; }
.field label{ display:block; font-family:var(--sans); font-weight:600; font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); margin-bottom:9px; }
.field input,.field select,.field textarea{ width:100%; font-family:var(--serif); font-size:1.02rem; color:var(--ink); background:var(--paper); border:1px solid var(--line); padding:.85em 1em; transition:border-color .25s, box-shadow .25s; }
.field textarea{ resize:vertical; min-height:130px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--purple); box-shadow:0 0 0 3px var(--purple-wash); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%237143AD' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1em center; padding-right:2.6em; }
.form .dbtn{ border:none; cursor:pointer; }
.form__ok{ display:none; text-align:center; padding:clamp(30px,4vw,52px) 20px; }
.form__ok.show{ display:block; }
.form__ok .tick{ width:64px; height:64px; margin:0 auto 20px; border-radius:50%; background:var(--purple-wash); display:flex; align-items:center; justify-content:center; }
.form__ok .tick svg{ color:var(--purple); }
.form__ok h3{ font-family:var(--display); font-style:italic; font-weight:400; font-size:1.9rem; margin-bottom:8px; }
.form__ok p{ color:var(--ink-2); }
.form.sent .form__inner{ display:none; }

/* ---------- FAQ accordion ---------- */
.faq{ max-width:820px; margin:0 auto; }
.faq__item{ border-top:1px solid var(--line); }
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:clamp(20px,2.4vw,30px) 0; text-align:left; font-family:var(--display); font-weight:500; font-size:clamp(1.2rem,2vw,1.6rem); color:var(--ink); letter-spacing:-.01em; }
.faq__q .ic{ flex:none; width:30px; height:30px; position:relative; }
.faq__q .ic::before,.faq__q .ic::after{ content:""; position:absolute; left:50%; top:50%; width:14px; height:2px; background:var(--purple); transform:translate(-50%,-50%); transition:transform .35s var(--ease); }
.faq__q .ic::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq__item.open .faq__q .ic::after{ transform:translate(-50%,-50%) rotate(0); }
.faq__item.open .faq__q{ color:var(--purple-ink); }
.faq__a{ overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.faq__a p{ padding:0 0 clamp(20px,2.4vw,28px); color:var(--ink-2); line-height:1.65; max-width:64ch; }

/* ---------- Values cards ---------- */
.vgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,1.8vw,22px); }
.vcard{ background:var(--card); border:1px solid var(--line); padding:clamp(22px,2.2vw,32px); display:flex; flex-direction:column; gap:14px; position:relative; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.vcard::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:var(--purple); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); }
.vcard:hover{ transform:translateY(-6px); box-shadow:0 22px 54px rgba(23,21,20,.12); border-color:var(--purple); }
.vcard:hover::after{ transform:scaleX(1); }
.vcard__n{ font-family:var(--sans); font-weight:600; font-size:.72rem; letter-spacing:.18em; color:var(--mute); }
.vcard__ic{ width:46px; height:46px; color:var(--purple); transition:transform .45s var(--ease); }
.vcard:hover .vcard__ic{ transform:rotate(-6deg) scale(1.08); }
.vcard__ic [fill="none"],.vcard__ic path,.vcard__ic circle,.vcard__ic line{ fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.vcard__ic .dot{ fill:currentColor; stroke:none; }
.vcard h3{ font-family:var(--display); font-weight:500; font-size:clamp(1.25rem,1.7vw,1.6rem); line-height:1.1; letter-spacing:-.01em; }
.vcard p{ color:var(--ink-2); line-height:1.55; font-size:.96rem; }
.vcard--lead{ grid-column:1 / -1; flex-direction:row; align-items:center; gap:clamp(24px,4vw,60px); background:var(--ink); border-color:var(--ink); }
.vcard--lead::after{ background:var(--purple-bright,#a586d8); }
.vcard--lead .vcard__ic{ width:88px; height:88px; flex:none; color:#a586d8; }
.vcard--lead .vcard__n{ color:rgba(255,255,255,.45); }
.vcard--lead h3{ color:#fff; font-size:clamp(1.8rem,3vw,2.6rem); }
.vcard--lead p{ color:rgba(255,255,255,.74); font-size:1.1rem; max-width:56ch; }
.vcard--lead .vcard__txt{ display:flex; flex-direction:column; gap:12px; }
@media (max-width:880px){ .vgrid{ grid-template-columns:1fr 1fr; } }
@media (max-width:540px){ .vgrid{ grid-template-columns:1fr; } .vcard--lead{ flex-direction:column; align-items:flex-start; } }

/* ---------- Legal (privacy / terms) ---------- */
.legal{ max-width:760px; margin:0 auto; }
.legal__meta{ font-family:var(--sans); font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); margin-bottom:30px; padding-bottom:22px; border-bottom:1px solid var(--line); }
.legal h2{ font-family:var(--display); font-weight:500; font-size:clamp(1.35rem,2.2vw,1.9rem); letter-spacing:-.01em; margin:38px 0 12px; }
.legal h2 .no{ color:var(--purple-ink); font-style:italic; margin-right:.3em; }
.legal p,.legal li{ color:var(--ink-2); line-height:1.72; font-size:1.02rem; }
.legal p{ margin-bottom:14px; }
.legal ul{ list-style:none; margin:0 0 16px; padding:0; display:flex; flex-direction:column; gap:10px; }
.legal li{ position:relative; padding-left:22px; }
.legal li::before{ content:""; position:absolute; left:0; top:.62em; width:8px; height:8px; border:1.5px solid var(--purple); border-radius:50%; }
.legal a{ color:var(--purple-ink); text-decoration:underline; text-underline-offset:3px; }
.legal strong{ color:var(--ink); }

/* ---------- About: approach row ---------- */
.about__intro{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px); align-items:center; }
@media (max-width:820px){ .about__intro{ grid-template-columns:1fr; } }
.about__intro .big{ font-family:var(--display); font-style:italic; font-weight:500; font-size:clamp(1.9rem,3.4vw,3rem); line-height:1.16; color:var(--ink); letter-spacing:-.01em; margin-bottom:.6em; }
.about__intro p{ font-size:clamp(1.05rem,1.4vw,1.25rem); line-height:1.65; color:var(--ink-2); margin-bottom:1em; }

/* ---------- About: process ---------- */
.process{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(28px,5vw,80px); align-items:stretch; }
@media (max-width:840px){ .process{ grid-template-columns:1fr; } .process__intro{ position:static !important; } }
.process__intro{ position:sticky; top:104px; align-self:start; }
.process__intro .t2{ margin:6px 0 16px; }
.process__intro p{ color:var(--ink-2); line-height:1.6; margin-bottom:24px; max-width:34ch; }
.psteps{ border-top:1px solid var(--line); display:flex; flex-direction:column; height:100%; }
.pstep{ display:grid; grid-template-columns:clamp(56px,7vw,92px) 1fr; gap:clamp(18px,2.4vw,36px); padding:clamp(16px,1.8vw,24px) 0; border-bottom:1px solid var(--line); align-items:center; position:relative; flex:1 0 auto; }
.pstep__n{ font-family:var(--display); font-style:italic; font-weight:500; font-size:clamp(2.2rem,4vw,3.4rem); line-height:.9; color:#cdbfe2; transition:color .4s var(--ease), transform .4s var(--ease); }
.pstep:hover .pstep__n{ color:var(--purple-ink); transform:translateY(-2px); }
.pstep h3{ font-family:var(--display); font-weight:500; font-size:clamp(1.35rem,2.1vw,1.85rem); letter-spacing:-.01em; margin-bottom:8px; transition:color .3s; }
.pstep:hover h3{ color:var(--purple-ink); }
.pstep p{ color:var(--ink-2); line-height:1.62; max-width:54ch; }
.pstep::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background:var(--purple); transform:scaleX(0); transform-origin:left; transition:transform .6s var(--ease); }
.pstep:hover::after{ transform:scaleX(1); }

/* ---------- Home 'What we do' compact ---------- */
.explore-mini h2{ font-size:clamp(1.5rem,2.4vw,2.2rem); line-height:1.05; }
.explore-mini .tease{ gap:clamp(12px,1.4vw,18px); }
.explore-mini .tcard{ padding:clamp(16px,1.6vw,24px); }
.explore-mini .tcard h3{ font-size:clamp(1.15rem,1.6vw,1.45rem); margin-bottom:7px; }
.explore-mini .tcard p{ font-size:.88rem; line-height:1.5; margin-bottom:12px; }
.explore-mini .tcard .alink{ font-size:.92rem !important; }

/* ---------- Home impact compact ---------- */
.impact--mini .impact__head{ margin-bottom:clamp(16px,1.8vw,26px); }
.impact--mini .impact__head h2{ font-size:clamp(1.5rem,2.8vw,2.4rem); }
.impact--mini .impact__head .lead{ margin-top:12px !important; font-size:1.02rem; }
.impact--mini .calc{ gap:clamp(18px,2.6vw,38px); }
.impact--mini .ledger{ padding:clamp(18px,2.2vw,30px); }
.impact--mini .ledger__big{ font-size:clamp(2.6rem,4.6vw,4rem); }
.impact--mini .bd{ margin-top:20px; gap:13px; }
.impact--mini .slider{ margin-top:20px; padding-top:16px; }
.impact--mini .tiers{ gap:10px; }
.impact--mini .tier{ padding:13px 18px; }
.impact--mini .tier__amt{ font-size:clamp(1.4rem,2.1vw,1.85rem); }
.impact--mini .tier__t b{ font-size:.96rem; }
.impact--mini .tier__t span{ font-size:.85rem; }
.impact--mini .disc{ margin-top:16px; }

/* ---------- Our Work intro ---------- */
.work-intro{ display:grid; grid-template-columns:1.25fr .75fr; gap:clamp(24px,4vw,60px); align-items:center; padding-bottom:clamp(20px,2.4vw,32px); border-bottom:1px solid var(--line); margin-bottom:clamp(24px,3.2vw,44px); }
@media (max-width:760px){ .work-intro{ grid-template-columns:1fr; align-items:start; gap:16px; text-align:center; } }
.work-intro h2{ font-family:var(--display); font-weight:500; font-size:clamp(2rem,4.4vw,3.6rem); line-height:1; letter-spacing:-.02em; margin-top:10px; }
.work-intro h2 em{ font-style:italic; color:var(--purple-ink); }
.work-intro .lead{ color:var(--ink-2); padding-bottom:.35em; }

/* ---------- Motion / hand off ---------- */
html.no-motion *,html.no-motion *::before,html.no-motion *::after{ animation:none!important; transition-duration:.001s!important; }
html.no-motion .rv,html.no-motion .clip>*{ opacity:1!important; transform:none!important; }
html.no-motion .hero h1 .ln>span{ transform:none!important; }
html.no-motion [data-draw]{ stroke-dashoffset:0!important; }
html.no-hand .doodle,html.no-hand .uline svg,html.no-hand .hand svg,html.no-hand .wmark,html.no-hand .scatter{ display:none!important; }

/* ---------- Mobile fixes ---------- */
html{ overflow-x:hidden; }
@media (max-width:760px){
  .wmark,.doodle{ display:none !important; }
  .phero h1{ font-size:clamp(2.3rem,10vw,3.2rem) !important; }
  .calc__out{ flex-wrap:wrap; }
  .stats__grid .st .n{ font-size:clamp(2rem,9vw,2.6rem); }
  .pcard__title{ font-size:clamp(1.7rem,7vw,2.3rem); }
}
@media (max-width:420px){
  .stats__grid{ grid-template-columns:1fr 1fr; }
  .form__row{ grid-template-columns:1fr; }
}

/* ---------- Tweaks ---------- */
#tweaks{ position:fixed; right:20px; bottom:20px; z-index:12000; width:300px; max-width:calc(100vw - 32px); background:var(--card); color:var(--ink); border:1px solid var(--line); box-shadow:0 24px 70px rgba(33,28,21,.3); overflow:hidden; display:none; }
#tweaks.show{ display:block; }
#tweaks .h{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--line); cursor:grab; }
#tweaks .h b{ font-family:var(--sans); font-weight:700; font-size:1rem; letter-spacing:.04em; color:var(--ink); }
#tweaks .h button{ width:28px; height:28px; display:flex; align-items:center; justify-content:center; color:var(--mute); }
#tweaks .b{ padding:16px; display:flex; flex-direction:column; gap:18px; }
#tweaks .g>label{ font-family:var(--sans); font-weight:600; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); display:block; margin-bottom:8px; }
#tweaks .sw{ display:flex; gap:8px; }
#tweaks .sw button{ flex:1; padding:9px 6px; box-shadow:inset 0 0 0 1.5px var(--line); font-size:.84rem; font-weight:600; color:var(--ink-2); }
#tweaks .sw button.on{ box-shadow:inset 0 0 0 1.5px var(--purple); color:var(--purple-ink); background:var(--purple-wash); }
#tweaks .tg{ display:flex; align-items:center; justify-content:space-between; }
#tweaks .tg span{ font-size:.96rem; }
#tweaks .tg button{ width:46px; height:26px; border-radius:100px; background:var(--line); position:relative; transition:.25s; }
#tweaks .tg button::after{ content:""; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:.25s; }
#tweaks .tg button.on{ background:var(--purple); } #tweaks .tg button.on::after{ left:23px; }
#tweaks input[type=text]{ width:100%; padding:9px 12px; box-shadow:inset 0 0 0 1.5px var(--line); font:inherit; font-size:.92rem; color:var(--ink); background:transparent; }
#tweaks input[type=text]:focus{ outline:none; box-shadow:inset 0 0 0 1.5px var(--purple); }

/* ====================================================================
   MOBILE-FIRST POLISH (<=760px)  — centered, balanced, photo-forward
   ==================================================================== */
@media (max-width:760px){
  /* section intros centered to match the subpage .phero pattern */
  .port__head{ text-align:center; margin-inline:auto; }
  .impact__head{ text-align:center; margin-inline:auto; }
  .impact__head .lead{ margin-inline:auto; }

  /* HERO: centered text, and bring the key photo back (it was hidden) */
  .hero{ padding-top:104px; }
  /* mobile order: text -> photo (with ₹208 tag) -> Donate button */
  .hero__grid{ display:flex; flex-direction:column; gap:26px; text-align:center; }
  .hero__text{ display:contents; }
  .hero__eb{ margin-bottom:0; }
  .hero__lead{ margin-top:-24px; margin-inline:auto; }
  .hero__side{ order:2; display:block; max-width:360px; margin:0 auto; position:relative; }
  .hero__side .photo{ max-width:none; margin:0; }
  .hero__cta{ order:3; justify-content:center; row-gap:16px; margin-top:0; }
  /* ₹208 tag on the photo, bottom-left, like desktop (does not cover the image) */
  .hero__side .hero__tag{ display:block; position:absolute; left:12px; right:auto; top:auto; bottom:16px;
    transform:none; margin:0; padding:12px 16px; box-shadow:0 12px 26px rgba(23,21,20,.32); }
  .hero__side .hero__tag b{ font-size:1.55rem; }
  .hero__side .hero__tag span{ font-size:.72rem; }

  /* equal vertical rhythm: uniform padding on every content section */
  .pad, .cta{ padding-block:34px !important; }
  .hero{ padding-bottom:34px; }

  /* teaser cards: centered content */
  .tcard{ text-align:center; align-items:center; }

  /* project cards: centered content (photo already stacks on top) */
  .pcard__info{ text-align:center; }
  .pcard__stats{ justify-content:center; gap:26px; }
  .pcard__tags{ justify-content:center; }
  /* programme flow stays on one line */
  .flow{ justify-content:center; flex-wrap:nowrap; gap:6px; }
  .flow__arrow{ width:26px; }
  .flow__step{ font-size:.8rem; }
  .flow__step b{ font-size:.95rem; }

  /* impact dot-meter on one line */
  .cmeter{ flex-wrap:nowrap; justify-content:space-between; gap:3px; }
  /* calculator note + disclaimer centered (donate button removed) */
  .calc .muted, .calc .disc{ text-align:center; }

  /* contact methods: icon on top, fully centered */
  .contact__aside{ text-align:center; }
  .contact__aside .cinfo a{ flex-direction:column; gap:7px; }

  /* CTA lead: keep it to 2 tidy lines on phones */
  .donate p, .cta p{ font-size:1rem; }
  /* homepage donate lead -> 3 lines */
  .donate p.dcta3{ font-size:.8rem; max-width:none; margin-inline:auto; }

  /* About page: centre everything */
  .about__intro{ text-align:center; }
  .process__intro{ text-align:center; }
  .process__intro p{ margin-inline:auto; }
  .process__intro div[style*="flex"]{ justify-content:center; }
  .pstep{ grid-template-columns:1fr; justify-items:center; text-align:center; gap:4px; }
  .pstep p{ margin-inline:auto; }

  /* Contact form: centre labels + button */
  .form{ text-align:center; }
  .form .dbtn{ margin-inline:auto; }

  /* footer: stacked + centered on mobile */
  .foot__cta{ flex-direction:column; align-items:center; text-align:center; }
  .foot__in{ flex-direction:column; align-items:center; text-align:center; }
  .foot__nav{ justify-content:center; }
  .foot__social{ justify-content:center; }
  .foot__bottom{ flex-direction:column; align-items:center; text-align:center; gap:10px; }
  .foot__bottom .lk{ justify-content:center; }
}

/* ---------- story / content pages ---------- */
/* unify body paragraphs (lead + follow-on) so the type reads consistent */
/* every prose paragraph identical (lead included) so the type never clashes */
.story .pad .wrap > p{ font-family:var(--serif); font-size:1.18rem; line-height:1.6; color:var(--ink-2); margin-top:1.05em; text-wrap:pretty; }
.story .pad .wrap > p:first-of-type{ margin-top:0; }
.story .pad .wrap > p.muted{ font-size:.92rem; line-height:1.5; color:var(--mute); }
.pad .wrap > p a, .blocks a{ color:var(--purple-ink); text-decoration:underline; text-underline-offset:2px; }

/* labelled blocks (replace run-in prose lists) */
.blocks{ display:grid; gap:12px; margin-top:18px; }
.block{ display:grid; grid-template-columns:auto 1fr; gap:3px 18px; background:var(--card); border:1px solid var(--line); padding:clamp(16px,2.1vw,22px) clamp(18px,2.4vw,26px); text-align:left; }
.block__n{ grid-row:1 / span 2; align-self:start; font-family:var(--display); font-weight:500; font-size:1.16rem; line-height:1.42; color:var(--purple-ink); font-variant-numeric:tabular-nums; }
.block__t{ font-family:var(--sans); font-weight:600; font-size:1.02rem; line-height:1.3; color:var(--ink); letter-spacing:-.004em; }
.block__b{ font-family:var(--serif); font-size:1.08rem; line-height:1.56; color:var(--ink-2); text-wrap:pretty; margin:0; }
.block__b strong{ color:var(--ink); font-weight:600; }
.block--price{ align-items:center; gap:18px; }
.block--price .block__n{ grid-row:auto; align-self:center; min-width:7ch; white-space:nowrap; font-size:clamp(1.5rem,3.6vw,1.95rem); letter-spacing:-.01em; line-height:1; }
.block--price .block__b{ align-self:center; }
