:root{
  --paper:#fbfaf7; --paper-deep:#f1f0eb; --ink:#17211b; --muted:#626b63;
  --rule:#e3e0d8; --primary:#285f43; --primary-dark:#173c2b; --accent:#b9d3c0;
  --font-display:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; --font-sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
a{color:inherit;text-decoration:none}.wrap{max-width:1120px;margin:0 auto;padding:0 40px}.eyebrow{font-size:11px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:#7c857d}.display{font-family:var(--font-display);font-weight:500;letter-spacing:-.07em;line-height:.96}.serif{font-family:var(--font-display);font-weight:520;letter-spacing:-.055em;line-height:1.05}.italic{font-style:normal;color:var(--primary);font-weight:500}.muted{color:var(--muted)}.hairline{height:1px;background:var(--rule)}
header{position:sticky;top:0;z-index:20;background:rgba(251,250,247,.82);backdrop-filter:saturate(140%) blur(12px)}.nav{height:72px;display:flex;align-items:center;justify-content:space-between}.brand{font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.04em}.brand span{color:var(--primary);margin-left:5px}.links{display:flex;gap:6px;font-size:13px}.links a{border-radius:999px;padding:7px 13px;color:var(--muted)}.links a:hover,.links a.active{background:#efeee8;color:var(--ink)}
.hero{position:relative;overflow:hidden}.hero:before{content:"";position:absolute;right:-220px;top:-220px;width:580px;height:580px;border-radius:50%;background:var(--accent);opacity:.12;filter:blur(70px)}.hero:after{content:"";position:absolute;left:-220px;bottom:-220px;width:520px;height:520px;border-radius:50%;background:var(--primary);opacity:.08;filter:blur(70px)}.hero-inner{position:relative;padding:105px 0 90px}.hero h1{font-size:clamp(54px,8vw,92px);max-width:960px}.lead-grid{display:grid;grid-template-columns:7fr 4fr;gap:80px;margin-top:46px;align-items:end}.lead{font-size:21px;line-height:1.6;color:var(--muted);max-width:710px}.button-row{display:flex;flex-direction:column;gap:13px}.btn{display:inline-flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid rgba(36,29,24,.16);border-radius:999px;padding:14px 22px;font-size:14px;font-weight:600;transition:.18s}.btn:hover{transform:translateY(-2px);border-color:rgba(36,29,24,.38)}.btn.dark{background:var(--ink);color:#fff;border-color:var(--ink)}.btn.red{background:var(--primary);color:#fff;border-color:var(--primary)}.logos{display:flex;flex-wrap:wrap;gap:18px 36px;padding:24px 0;color:var(--muted);font-size:14px}.logos .eyebrow{margin-right:10px}.section{border-top:1px solid var(--rule);padding:105px 0}.deep{background:var(--paper-deep)}.dark{background:var(--ink);color:var(--paper)}.split{display:grid;grid-template-columns:4fr 7fr;gap:90px}.split h2,.section h2{font-size:clamp(38px,5vw,56px);margin:14px 0 0}.bodycopy{font-size:19px;color:rgba(23,33,27,.78);line-height:1.68}.bodycopy p{margin:0 0 22px}.text-link{color:var(--primary);font-weight:600;font-size:14px}.cards{display:grid;grid-template-columns:repeat(2,1fr);background:var(--rule);gap:1px;border-radius:18px;overflow:hidden}.card{background:var(--paper);padding:30px}.card:hover{background:var(--paper-deep)}.card h3{font-family:var(--font-display);font-size:22px;font-weight:650;margin:0 0 12px;letter-spacing:-.04em}.card p{margin:0;color:var(--muted);font-size:14px;line-height:1.7}.work-list{margin-top:58px;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}.work-row{display:grid;grid-template-columns:.5fr 2.5fr 4fr 2fr 1fr;gap:22px;align-items:baseline;padding:30px 0;border-top:1px solid rgba(255,255,255,.12)}.work-row:first-child{border-top:0}.work-row:hover{background:rgba(255,255,255,.035)}.work-row h3{font-family:var(--font-display);font-size:30px;font-weight:650;letter-spacing:-.06em;margin:0}.work-row p{margin:0}.work-row .num,.work-row .meta,.work-row .year{color:rgba(247,243,236,.56);font-size:13px}.work-row .desc{color:rgba(247,243,236,.82)}.principles{display:grid;gap:0}.principle{display:grid;grid-template-columns:55px 1fr;gap:18px;border-top:1px solid var(--rule);padding:30px 0}.principle:first-child{border-top:0;padding-top:0}.principle .n{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--primary)}.principle h3{font-family:var(--font-display);font-size:28px;font-weight:650;letter-spacing:-.055em;margin:0}.principle p{max-width:690px;color:var(--muted);margin:12px 0 0}.cta-band{display:grid;grid-template-columns:8fr 4fr;gap:40px;align-items:end}.cta-band h2{font-size:clamp(42px,6vw,70px)}footer{border-top:1px solid var(--rule)}.footer-grid{display:grid;grid-template-columns:6fr 3fr 3fr;gap:60px;padding:62px 0}.footer-grid h2{font-size:38px;margin:0}.footer-grid ul{list-style:none;padding:0;margin:0}.footer-grid li{margin:8px 0}.copyright{border-top:1px solid var(--rule);font-size:12px;color:var(--muted)}.copyright .wrap{display:flex;justify-content:space-between;padding-top:22px;padding-bottom:22px}.mark{font-family:var(--font-display);font-style:normal;font-weight:600}
.page-hero{padding:88px 0 80px}.page-hero h1{font-size:clamp(48px,7vw,76px);max-width:860px}.two-col{display:grid;grid-template-columns:4fr 5fr;gap:100px}.timeline{border-top:1px solid var(--rule)}.timeline-row{display:grid;grid-template-columns:2fr 7fr;gap:80px;border-bottom:1px solid var(--rule);padding:34px 0}.timeline-row .date{color:var(--primary);font-size:16px}.timeline-row h3{font-family:var(--font-display);font-size:28px;font-weight:650;letter-spacing:-.055em;margin:0 0 8px}.texture{display:grid;grid-template-columns:4fr 7fr;gap:80px;align-items:start}.texture-grid{display:grid;grid-template-columns:repeat(2,1fr);overflow:hidden;border-radius:14px;border:1px solid var(--rule);background:var(--rule);gap:1px}.texture-grid div{background:rgba(251,250,247,.72);padding:23px;font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.035em}.work-page-row{display:grid;grid-template-columns:270px 1fr;gap:32px;margin-bottom:52px}.tile{height:270px;border-radius:9px;background:linear-gradient(135deg,var(--c1),var(--c2));position:relative;color:#fff;overflow:hidden}.tile:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.13),transparent 45%)}.tile .num{position:absolute;left:22px;bottom:22px;font-family:var(--font-display);font-size:26px}.tile .pill{position:absolute;right:13px;bottom:18px;border-radius:999px;background:rgba(0,0,0,.25);font-size:10px;padding:4px 9px}.project h2{font-size:36px;font-weight:650;letter-spacing:-.06em;margin:0}.project .kicker{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:#7c857d;font-weight:700;margin:5px 0 26px}.spec{display:grid;grid-template-columns:94px 1fr;gap:15px;margin:15px 0}.spec b{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--primary)}.contact-grid{display:grid;grid-template-columns:4fr 5fr;gap:120px}.contact-card{border-top:1px solid var(--rule);padding:24px 0}.contact-card h3{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:#7c857d;margin:0 0 8px;font-weight:700}.contact-card p,.contact-card a{font-family:var(--font-display);font-size:28px;font-weight:600;letter-spacing:-.055em;line-height:1.15}.fit-list{list-style:none;margin:0;padding:0}.fit-list li{position:relative;padding:0 0 24px 28px;font-size:19px;color:rgba(23,33,27,.8)}.fit-list li:before{content:"•";position:absolute;left:0;color:var(--primary)}.quote{text-align:center;font-family:var(--font-display);font-size:34px;font-weight:560;max-width:760px;margin:0 auto;letter-spacing:-.06em;line-height:1.18}.quote small{display:block;margin-top:22px;font-family:var(--font-sans);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#7c857d;font-weight:700}

/* V2 visual refinement: cleaner, whiter, greener, sans-serif throughout */
h1,h2,h3,.display,.serif{font-family:var(--font-display)}
.hero h1,.page-hero h1{letter-spacing:-.075em;}
.section h2,.split h2,.cta-band h2,.footer-grid h2{font-weight:560;letter-spacing:-.065em;}
.deep{background:var(--paper-deep)}
.dark{background:#16221b;color:#fbfaf7}
.work-row .num,.work-row .meta,.work-row .year{color:rgba(251,250,247,.58)}
.work-row .desc{color:rgba(251,250,247,.84)}
.tile{box-shadow: inset 0 0 0 1px rgba(255,255,255,.18)}

@media(max-width:800px){.wrap{padding:0 22px}.nav{height:64px}.links{font-size:12px}.hero-inner{padding:70px 0}.lead-grid,.split,.cta-band,.footer-grid,.two-col,.texture,.contact-grid{grid-template-columns:1fr;gap:36px}.button-row{max-width:360px}.cards{grid-template-columns:1fr}.work-row{grid-template-columns:42px 1fr}.work-row .desc,.work-row .meta,.work-row .year{grid-column:2}.work-page-row{grid-template-columns:1fr}.tile{height:220px}.timeline-row{grid-template-columns:1fr;gap:8px}.texture-grid{grid-template-columns:1fr}.footer-grid{padding:44px 0}.copyright .wrap{flex-direction:column;gap:8px}.contact-card p,.contact-card a{font-size:25px}}

/* V3 visual refinement: more creative/design signal on landing */
:root{
  --paper:#fffefa;
  --paper-deep:#f4f3ec;
  --primary:#1d6b48;
  --primary-dark:#103f2b;
  --accent:#dcebdd;
  --ink:#131a16;
}
header{background:rgba(255,254,250,.84)}
.hero-visual:before{right:-260px;top:-260px;width:680px;height:680px;opacity:.16;filter:blur(80px)}
.hero-visual:after{left:-300px;bottom:-300px;width:620px;height:620px;opacity:.09;filter:blur(80px)}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(0,1.02fr) minmax(360px,.78fr);gap:66px;align-items:center;padding:88px 40px 84px}
.hero-copy .display{font-size:clamp(48px,6.7vw,84px);max-width:820px;margin:18px 0 0}
.hero-copy .lead{margin-top:34px;max-width:680px;font-size:20px}
.hero-buttons{margin-top:34px;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;max-width:none}.hero-buttons .btn{min-width:205px}
.hero-board{position:relative;height:560px;min-height:500px;border-radius:34px;background:linear-gradient(145deg,rgba(244,243,236,.95),rgba(255,254,250,.72));box-shadow:0 34px 90px rgba(19,26,22,.08), inset 0 0 0 1px rgba(19,26,22,.08);overflow:hidden;isolation:isolate}
.hero-board:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 26% 18%,rgba(29,107,72,.19),transparent 30%),radial-gradient(circle at 76% 74%,rgba(29,107,72,.13),transparent 34%),linear-gradient(rgba(19,26,22,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(19,26,22,.04) 1px,transparent 1px);background-size:auto,auto,34px 34px,34px 34px;z-index:-2}
.hero-board:after{content:"";position:absolute;inset:18px;border:1px solid rgba(19,26,22,.08);border-radius:24px;pointer-events:none}
.board-lines{position:absolute;inset:0;width:100%;height:100%;z-index:-1}.board-lines path{fill:none;stroke:rgba(29,107,72,.28);stroke-width:1.5;stroke-dasharray:4 7;stroke-linecap:round}
.board-card{position:absolute;border-radius:22px;box-shadow:0 20px 50px rgba(19,26,22,.12), inset 0 0 0 1px rgba(255,255,255,.32);overflow:hidden}.portrait-card{left:38px;top:42px;width:230px;height:276px;background:#13351f;color:#fff;padding:24px;display:flex;flex-direction:column;justify-content:space-between}.portrait-mark{width:80px;height:80px;border-radius:28px;background:rgba(255,255,255,.13);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;letter-spacing:-.08em}.portrait-card p{margin:0;font-size:20px;line-height:1.16;font-weight:650;letter-spacing:-.05em}.portrait-card span{color:#abd2b4}.image-card{display:flex;align-items:flex-end;padding:18px;color:#fff;background-size:cover;background-position:center}.image-card span{font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;background:rgba(19,26,22,.54);backdrop-filter:blur(10px);border-radius:999px;padding:7px 10px}.image-one{right:38px;top:74px;width:190px;height:150px;background-image:linear-gradient(135deg,rgba(6,78,59,.8),rgba(15,118,110,.22)),linear-gradient(135deg,#0f766e,#d9f99d)}.image-two{left:96px;bottom:62px;width:205px;height:160px;background-image:radial-gradient(circle at 32% 24%,rgba(255,255,255,.35),transparent 28%),linear-gradient(135deg,#3b82f6,#14b8a6 48%,#14532d)}.image-three{right:50px;bottom:104px;width:170px;height:220px;background-image:radial-gradient(circle at 58% 22%,rgba(255,255,255,.3),transparent 26%),linear-gradient(150deg,#52525b,#1d6b48 58%,#a7f3d0)}.board-note{position:absolute;left:292px;top:254px;width:150px;border-radius:18px;background:rgba(255,254,250,.72);backdrop-filter:blur(14px);border:1px solid rgba(19,26,22,.09);padding:17px;font-size:13px;line-height:1.35;color:var(--muted);box-shadow:0 14px 34px rgba(19,26,22,.08)}.board-note b{color:var(--ink);font-size:24px;letter-spacing:-.06em}
.cards{border-radius:24px}.card{position:relative}.card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);opacity:0;transition:.18s}.card:hover:before{opacity:1}.dark{background:#10271b}.work-row:hover{background:rgba(164,214,178,.07)}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;padding-top:70px;gap:46px}.hero-board{height:470px;min-height:0;max-width:560px}.hero-copy .display{font-size:clamp(45px,12vw,72px)}}
@media(max-width:620px){.hero-grid{padding-left:22px;padding-right:22px}.hero-buttons{flex-direction:column}.hero-buttons .btn{width:100%}.hero-board{height:420px;border-radius:24px}.portrait-card{left:22px;top:26px;width:190px;height:238px}.image-one{right:24px;top:58px;width:145px;height:126px}.image-two{left:46px;bottom:36px;width:170px;height:132px}.image-three{right:28px;bottom:64px;width:132px;height:172px}.board-note{left:auto;right:24px;top:206px;width:132px}.portrait-card p{font-size:18px}}


/* V4 visual collage: real project imagery in hero */
.hero-board{height:590px;min-height:540px}
.board-card{background:#fff}
.board-card img{display:block;width:100%;height:100%}
.portrait-card{left:34px;top:38px;width:228px;height:294px;background:#0f2418;color:#fff;padding:0;display:flex;flex-direction:column;justify-content:flex-start;transform:rotate(1.5deg)}
.portrait-card .photo-wrap{height:72%;overflow:hidden}
.portrait-card .photo-wrap img{object-fit:cover}
.portrait-card .card-caption{padding:16px 18px 18px;background:linear-gradient(180deg,rgba(15,36,24,.86),#0f2418)}
.portrait-card p{margin:0;font-size:19px;line-height:1.14;font-weight:650;letter-spacing:-.05em}
.portrait-card span{color:#b9d8c1}
.thread-card{right:34px;top:56px;width:210px;height:164px;background:#050806;padding:18px 18px 42px;display:flex;align-items:center;justify-content:center;transform:rotate(-1.8deg)}
.thread-card img{object-fit:contain}
.mastermind-card{left:102px;bottom:58px;width:232px;height:170px;background:#e8e7e1;padding:0;transform:rotate(-1deg)}
.mastermind-card img{object-fit:cover}
.matrix-card{right:42px;bottom:94px;width:184px;height:238px;background:#0b1320;transform:rotate(2deg)}
.matrix-card img{object-fit:cover}
.image-card{position:absolute;overflow:hidden}
.image-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(0,0,0,.52) 100%);z-index:1;pointer-events:none}
.image-card span{position:absolute;left:14px;bottom:14px;z-index:2;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:rgba(19,26,22,.56);backdrop-filter:blur(10px);border-radius:999px;padding:7px 10px;color:#fff}
.board-note{left:274px;top:250px;width:172px;padding:16px 16px 18px;background:rgba(255,255,255,.78)}
.board-note b{display:block;color:var(--ink);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.hero-board:before{background:radial-gradient(circle at 26% 18%,rgba(29,107,72,.17),transparent 30%),radial-gradient(circle at 76% 74%,rgba(29,107,72,.11),transparent 34%),linear-gradient(rgba(19,26,22,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(19,26,22,.04) 1px,transparent 1px);background-size:auto,auto,34px 34px,34px 34px}
@media(max-width:980px){.hero-board{height:500px}.portrait-card{left:24px;top:24px;width:204px;height:260px}.thread-card{right:24px;top:48px;width:180px;height:144px}.mastermind-card{left:74px;bottom:42px;width:208px;height:152px}.matrix-card{right:28px;bottom:74px;width:162px;height:206px}.board-note{left:auto;right:212px;top:215px;width:148px}}
@media(max-width:620px){.hero-board{height:430px}.portrait-card{left:18px;top:22px;width:172px;height:228px}.portrait-card p{font-size:17px}.thread-card{right:18px;top:40px;width:136px;height:112px;padding:14px 14px 36px}.mastermind-card{left:34px;bottom:34px;width:180px;height:128px}.matrix-card{right:22px;bottom:56px;width:126px;height:160px}.board-note{right:18px;top:176px;width:126px;padding:12px}.image-card span{left:10px;bottom:10px;font-size:10px;padding:6px 8px}}


/* V5 logo strip refinement */
.logo-strip{padding:26px 0 6px}
.logo-strip-head{display:flex;justify-content:space-between;align-items:end;gap:30px;margin-bottom:26px}
.logo-strip-head p{margin:0;max-width:620px;color:var(--muted);font-size:14px}
.logo-grid{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:14px;align-items:start}
.logo-item{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center;padding:10px 4px 0}
.logo-icon{width:100%;aspect-ratio:1.15/1;display:flex;align-items:center;justify-content:center;border-radius:18px;border:1px solid rgba(19,26,22,.09);background:linear-gradient(180deg,#fff,#f6f4ee);box-shadow:0 8px 24px rgba(19,26,22,.06), inset 0 1px 0 rgba(255,255,255,.8);padding:12px;overflow:hidden}
.logo-dark .logo-icon{background:linear-gradient(180deg,#111714,#0a0d0b);border-color:rgba(255,255,255,.06);box-shadow:0 10px 28px rgba(19,26,22,.12)}
.logo-icon img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.logo-item span{font-size:13px;line-height:1.3;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.logo-dark span{color:var(--muted)}
.logo-dark span{color:var(--ink)}
@media(max-width:1180px){.logo-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
@media(max-width:800px){.logo-strip{padding-top:22px}.logo-strip-head{flex-direction:column;align-items:flex-start;margin-bottom:18px}.logo-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.logo-item span{font-size:12px}}
@media(max-width:460px){.logo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.logo-icon{border-radius:16px;padding:10px}}


/* V6 minimalist premium logo strip */
.logo-strip.minimalist{padding:26px 0 2px}
.logo-strip.minimalist .logo-strip-head{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;margin-bottom:20px}
.logo-strip.minimalist .logo-strip-head p{margin:0;max-width:560px;color:var(--muted);font-size:13px;line-height:1.45}
.minimal-grid{display:flex;flex-wrap:wrap;align-items:flex-start;gap:20px 24px;padding:6px 0 4px}
.minimal-grid .logo-item{width:calc((100% - 8*24px)/9);min-width:88px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;padding:6px 0 0;text-align:center}
.minimal-grid .logo-item img{height:42px;max-width:100%;width:auto;display:block;object-fit:contain;opacity:.98;filter:saturate(.95) contrast(1.02)}
.minimal-grid .logo-item span{font-size:12px;line-height:1.28;color:#657067;font-weight:600;letter-spacing:-.01em}
.minimal-grid .logo-item:hover span{color:var(--ink)}
.minimal-grid .logo-item:hover img{transform:translateY(-1px);transition:transform .16s ease}
@media(max-width:1180px){.minimal-grid .logo-item{width:calc((100% - 4*24px)/5)}}
@media(max-width:800px){.logo-strip.minimalist .logo-strip-head{flex-direction:column;align-items:flex-start;gap:8px}.minimal-grid{gap:18px 18px}.minimal-grid .logo-item{width:calc((100% - 2*18px)/3)}.minimal-grid .logo-item img{height:38px}}
@media(max-width:460px){.minimal-grid .logo-item{width:calc((100% - 18px)/2)}.minimal-grid .logo-item img{height:34px}.minimal-grid .logo-item span{font-size:11.5px}}


/* V8 logo strip polish: correct logo mapping + no hover/link behavior */
.minimal-grid .logo-item{cursor:default}
.minimal-grid .logo-item img{transition:none !important}
.minimal-grid .logo-item span{transition:none !important}
.minimal-grid .logo-item:hover img{transform:none !important}
.minimal-grid .logo-item:hover span{color:#657067 !important}


/* V9 work section with real project visuals */
.work-page-row{display:grid;grid-template-columns:270px 1fr;gap:34px;margin-bottom:56px;align-items:start}
.media-card{height:270px;border-radius:14px;position:relative;overflow:hidden;background:#0e1110;box-shadow:0 10px 34px rgba(11,18,14,.12), inset 0 0 0 1px rgba(255,255,255,.06)}
.media-card img{width:100%;height:100%;object-fit:cover;display:block}
.media-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,10,9,.06),rgba(7,10,9,.12) 34%,rgba(7,10,9,.42) 100%);pointer-events:none}
.card-logo{position:absolute;left:18px;top:18px;z-index:2;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.24)}
.card-logo .wordmark{font-size:28px;line-height:0.98;font-weight:800;letter-spacing:-.055em}
.card-logo .submark{margin-top:4px;font-size:12px;line-height:1;letter-spacing:.18em;text-transform:uppercase;font-weight:700;opacity:.94}
.media-card .num{position:absolute;left:18px;bottom:18px;z-index:2;font-size:24px;font-weight:700;letter-spacing:-.04em;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.28)}
.media-card .pill{position:absolute;right:14px;bottom:16px;z-index:2;border-radius:999px;background:rgba(255,255,255,.14);backdrop-filter:blur(10px);font-size:10px;font-weight:700;letter-spacing:.02em;color:#fff;padding:6px 10px;border:1px solid rgba(255,255,255,.16)}
.project h2{font-size:35px;line-height:1.02;font-weight:700;letter-spacing:-.055em;margin:0}
.project .kicker{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:#7c857d;font-weight:700;margin:8px 0 24px}
.spec{display:grid;grid-template-columns:94px 1fr;gap:15px;margin:15px 0}
.spec b{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--primary)}
.spec p{margin:0;color:rgba(23,33,27,.84)}
@media(max-width:800px){.work-page-row{grid-template-columns:1fr;gap:18px;margin-bottom:38px}.media-card{height:240px}.card-logo .wordmark{font-size:25px}.card-logo .submark{font-size:11px}}


/* V11 work refinement: no blur, corrected image mapping, subtler art direction */
.media-card{border-radius:16px;box-shadow:0 10px 30px rgba(11,18,14,.10), inset 0 0 0 1px rgba(255,255,255,.06)}
.media-card:after{background:linear-gradient(180deg,rgba(7,10,9,.04),rgba(7,10,9,.08) 34%,rgba(7,10,9,.28) 100%)}
.card-logo .wordmark{font-size:28px;line-height:.98;font-weight:800;letter-spacing:-.055em}
.card-logo .submark{margin-top:4px;font-size:11px;line-height:1;letter-spacing:.18em;text-transform:uppercase;font-weight:700;opacity:.95}
.media-card .pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14)}


/* V12 about page resume button */
.timeline-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px;padding-left:calc((100% - 0px) * 2 / 9 + 80px)}
.timeline-actions .btn{min-width:156px}
@media(max-width:800px){.timeline-actions{padding-left:0;margin-top:28px}.timeline-actions .btn{width:100%;max-width:320px}}


/* V14 homepage selected work cleanup: add UC Berkeley, remove dates */
.work-row{grid-template-columns:.5fr 2.7fr 4.3fr 2.5fr}
.work-row .year{display:none}
@media(max-width:800px){.work-row{grid-template-columns:42px 1fr}.work-row .desc,.work-row .meta{grid-column:2}}


/* V22 color exploration: fresher, positive green without feeling neon */
:root{
  --primary:#1fbf72;
  --primary-dark:#0f8f56;
  --accent:#c7f3d8;
}
.italic{color:var(--primary-dark)}
.btn.red{background:var(--primary-dark);border-color:var(--primary-dark)}
.btn.red:hover{background:#0c7a49;border-color:#0c7a49}
.hero:after,.hero-visual:after{background:var(--primary);opacity:.055}
.hero-visual:before{background:var(--accent);opacity:.16}
.dark{background:#0d2318}
.text-link,.timeline-row .date,.principle .n,.spec b,.fit-list li:before,.brand span{color:var(--primary-dark)}
.logo-strip.minimalist .logo-strip-head p{color:#606b62}


/* V23 full green propagation: fresher green carried consistently across accents and CTAs */
:root{
  --primary:#1fbf72;
  --primary-dark:#0f8f56;
  --accent:#c7f3d8;
  --accent-soft:#ecfbf2;
}

header{background:rgba(255,254,250,.88)}
.italic{color:var(--primary-dark)}
.brand span,.text-link,.timeline-row .date,.principle .n,.spec b,.fit-list li:before{color:var(--primary-dark)}
.links a:hover,.links a.active{background:rgba(31,191,114,.12);color:var(--primary-dark)}

.hero:before,.hero-visual:before{background:var(--accent);opacity:.18}
.hero:after,.hero-visual:after{background:var(--primary);opacity:.07}
.hero-board:before{background:radial-gradient(circle at 26% 18%,rgba(31,191,114,.20),transparent 30%),radial-gradient(circle at 76% 74%,rgba(31,191,114,.12),transparent 34%),linear-gradient(rgba(19,26,22,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(19,26,22,.04) 1px,transparent 1px);background-size:auto,auto,34px 34px,34px 34px}
.board-lines path{stroke:rgba(31,191,114,.24)}
.portrait-card{background:#123a28}
.portrait-card .card-caption{background:linear-gradient(180deg,rgba(18,58,40,.88),#123a28)}
.portrait-card span{color:var(--accent)}
.board-note{border-color:rgba(15,143,86,.16)}

.btn{border-color:rgba(15,143,86,.24)}
.btn:hover{transform:translateY(-2px);border-color:rgba(15,143,86,.5)}
.btn.dark,.btn.red{background:var(--primary-dark);color:#fff;border-color:var(--primary-dark)}
.btn.dark:hover,.btn.red:hover{background:#0c7a49;border-color:#0c7a49}
.btn:not(.dark):not(.red){color:var(--primary-dark);background:transparent}
.btn:not(.dark):not(.red):hover{background:rgba(31,191,114,.06)}
.dark .btn:not(.dark):not(.red){color:var(--paper);border-color:rgba(255,255,255,.25);background:transparent}
.dark .btn:not(.dark):not(.red):hover{background:rgba(255,255,255,.06)}

.contact-card a:hover,.footer-grid a:hover{color:var(--primary-dark)}


/* V27 landing image refresh: preserve full collage and soften frame */
.hero-board.hero-board-collage{
  height:auto;
  min-height:0;
  aspect-ratio:1 / 1;
  padding:10px;
  border-radius:28px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(23,33,27,.08);
  box-shadow:0 20px 56px rgba(19,26,22,.08);
  overflow:hidden;
}
.hero-board.hero-board-collage:before{display:none}
.hero-board.hero-board-collage:after{display:none}
.hero-board.hero-board-collage img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  border-radius:20px;
  background:#000;
  box-shadow:none;
}
@media(max-width:980px){
  .hero-board.hero-board-collage{max-width:560px; width:100%; justify-self:start}
}
@media(max-width:620px){
  .hero-board.hero-board-collage{padding:8px;border-radius:22px}
  .hero-board.hero-board-collage img{border-radius:16px}
}


/* V28 homepage tuning: green emphasis, remove false affordance hovers */
.green-word{color:var(--primary-dark)}
.card:hover{background:var(--paper)}
.cards .card{cursor:default}
.cards .card:hover{transform:none;box-shadow:none}
.work-row:hover{background:transparent}


/* V30 resume buttons at bottom of selected work page */
.work-resume-actions{display:flex;gap:16px;flex-wrap:wrap;margin:12px 0 0 304px;padding-top:10px}
.work-resume-actions .btn{min-width:178px}
@media(max-width:800px){.work-resume-actions{margin-left:0;margin-top:24px}.work-resume-actions .btn{width:100%;max-width:320px}}
