/* Chanelle Henry Site v1.1
   Editorial, investigative, useful-weird system.
*/
:root{
  --paper:#f4efe6; --paper-2:#fffaf0; --paper-3:#e8dfd0; --ink:#141411; --ink-2:#28251e; --muted:#70695f; --line:#d7ccba;
  --dark:#11110f; --dark-2:#1d1b17; --cream:#fffaf0; --rust:#c56945; --blue:#d7e6f2; --blue-2:#89a9bf; --green:#4f8f6a; --green-soft:#e9f1e6;
  --shadow:0 26px 78px rgba(20,20,17,.11); --shadow-soft:0 12px 42px rgba(20,20,17,.075);
  --serif:'Cormorant Garamond', Georgia, serif; --sans:'Inter', Arial, sans-serif; --mono:'JetBrains Mono', monospace;
  --radius:30px; --max:1180px; --wide:1440px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-2;background:radial-gradient(circle at 9% 12%, rgba(197,105,69,.14), transparent 32rem),radial-gradient(circle at 90% 18%, rgba(215,230,242,.6), transparent 36rem),radial-gradient(circle at 80% 82%, rgba(79,143,106,.16), transparent 28rem),linear-gradient(180deg,var(--paper),#f8f1e7)}body:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.36;background-image:linear-gradient(rgba(20,20,17,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(20,20,17,.05) 1px,transparent 1px);background-size:62px 62px;mask-image:linear-gradient(to bottom,black 0,transparent 88%)}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{width:min(var(--max),calc(100% - 48px));margin-inline:auto}.container.wide{width:min(var(--wide),calc(100% - 56px))}.section{padding:clamp(5rem,9vw,8.5rem) 0}.section.compact{padding:clamp(3.5rem,7vw,6rem) 0}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(2rem,5vw,5rem)}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem}.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.2rem}.split-title{display:grid;grid-template-columns:minmax(280px,.75fr) minmax(0,1.25fr);gap:clamp(2rem,5vw,5rem);align-items:start}.dark{background:var(--dark);color:var(--cream)}.sage{background:linear-gradient(135deg,var(--green-soft),rgba(215,230,242,.7))}.blue{background:linear-gradient(135deg,rgba(215,230,242,.88),rgba(255,250,240,.8))}.rust-soft{background:linear-gradient(135deg,rgba(197,105,69,.12),rgba(255,250,240,.78))}.paper-card{background:rgba(255,250,240,.72);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);backdrop-filter:blur(14px)}
.display,.title-xl,.title-lg,.title-md{font-family:var(--serif);font-weight:400;letter-spacing:-.028em;color:var(--ink)}.display{font-size:clamp(4.5rem,12vw,10.8rem);line-height:.88}.title-xl{font-size:clamp(4rem,9vw,8.4rem);line-height:.9}.title-lg{font-size:clamp(3rem,6.5vw,6rem);line-height:.95}.title-md{font-size:clamp(2.05rem,4vw,3.65rem);line-height:1.02}.title-sm{font-family:var(--serif);font-size:clamp(1.7rem,2.7vw,2.5rem);line-height:1.08;font-weight:500}.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:800}.body-xl{font-size:clamp(1.2rem,2vw,1.65rem);line-height:1.55;color:var(--ink-2)}.body{font-size:1rem;line-height:1.75;color:var(--muted)}.small{font-size:.84rem;line-height:1.65;color:var(--muted)}strong{color:var(--ink);font-weight:800}.dark .title-lg,.dark .title-md,.dark .display,.dark .title-sm{color:var(--cream)}.dark .body,.dark .body-xl{color:rgba(255,250,240,.68)}.loose-headline{letter-spacing:-.015em;word-spacing:.02em}
.site-nav{position:fixed;top:1.1rem;left:50%;transform:translateX(-50%);z-index:1000;width:min(1120px,calc(100% - 28px));display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.68rem .72rem .68rem 1rem;border:1px solid rgba(255,255,255,.62);border-radius:999px;background:rgba(255,250,240,.55);backdrop-filter:blur(26px) saturate(1.45);-webkit-backdrop-filter:blur(26px) saturate(1.45);box-shadow:0 18px 70px rgba(20,20,17,.12)}.site-nav.scrolled{background:rgba(255,250,240,.76);box-shadow:0 20px 78px rgba(20,20,17,.16)}.nav-brand{display:flex;align-items:center;gap:.55rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:800;white-space:nowrap}.nav-mark{width:34px;height:34px;border-radius:50%;background:url('assets/ch-mark.svg') center/cover no-repeat;box-shadow:0 0 0 8px rgba(255,250,240,.55)}.nav-links{display:flex;align-items:center;gap:.45rem;list-style:none;margin:0;padding:0}.nav-links a{display:inline-flex;align-items:center;min-height:2.35rem;padding:.55rem .75rem;border-radius:999px;font-size:.82rem;font-weight:800;color:rgba(20,20,17,.74)}.nav-links a:hover{background:rgba(255,255,255,.45);color:var(--ink)}.nav-cta{background:var(--ink)!important;color:var(--cream)!important;box-shadow:0 12px 26px rgba(20,20,17,.18)}.nav-toggle{display:none;border:0;background:transparent;font-family:var(--mono);font-weight:800}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:3.1rem;padding:.9rem 1.2rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,250,240,.68);font-weight:900;color:var(--ink);box-shadow:0 10px 20px rgba(20,20,17,.04);transition:transform .25s ease,box-shadow .25s ease,background .25s ease}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.btn.primary{background:var(--ink);color:var(--cream);border-color:var(--ink)}.btn.green{background:var(--green);color:#fff;border-color:var(--green)}.btn.blue{background:var(--blue);border-color:#b8cedb}.btn.text{background:transparent;border-color:transparent;box-shadow:none;color:var(--muted);padding-inline:.2rem}.btn.text:after{content:"→";margin-left:.45rem}.btn.small-btn{min-height:2.4rem;padding:.55rem .85rem;font-size:.84rem}.btn:focus,.form-field:focus{outline:3px solid rgba(79,143,106,.24);outline-offset:3px}
.card{border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,250,240,.74);box-shadow:var(--shadow-soft);padding:clamp(1.35rem,2vw,2rem);position:relative;overflow:hidden}.card:hover{transform:translateY(-4px);transition:.25s ease}.icon{width:42px;height:42px;display:grid;place-items:center;border-radius:18px;background:var(--blue);color:var(--ink);margin-bottom:1rem}.icon svg{width:24px;height:24px}.tag{display:inline-flex;border:1px solid var(--line);background:rgba(255,250,240,.7);border-radius:999px;padding:.32rem .55rem;font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:800}.tag.green{background:rgba(79,143,106,.13);color:#315e45}.tag.blue{background:rgba(215,230,242,.7);color:#455d70}.tag.rust{background:rgba(197,105,69,.12);color:#8b442e}.coming{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.coming .typed{display:inline-block;min-width:8.8ch;border-right:2px solid var(--green);white-space:nowrap;overflow:hidden;animation:typing 2.4s steps(11,end) infinite alternate}@keyframes typing{0%,20%{width:0}100%{width:8.8ch}}
.media-card{border:1px solid var(--line);border-radius:34px;background:rgba(255,250,240,.68);box-shadow:var(--shadow);overflow:hidden}.media-card img{width:100%;height:100%;object-fit:cover}.placeholder{min-height:220px;border:1px dashed rgba(20,20,17,.25);border-radius:26px;background:linear-gradient(135deg,rgba(255,250,240,.7),rgba(215,230,242,.36));display:grid;place-items:center;text-align:center;padding:2rem}.doodle{position:absolute;pointer-events:none;opacity:.7}.doodle path{stroke-dasharray:900;stroke-dashoffset:900;animation:draw 2.8s ease forwards}@keyframes draw{to{stroke-dashoffset:0}}.connector-arrow{position:absolute;pointer-events:none;opacity:.56}.connector-arrow path{stroke:var(--green);stroke-width:3;fill:none;stroke-linecap:round;stroke-dasharray:8 12;animation:dash 18s linear infinite}.connector-arrow marker path{fill:var(--green)}@keyframes dash{to{stroke-dashoffset:-200}}
.hero{min-height:100svh;padding:9rem 0 5rem;display:flex;align-items:center;position:relative;overflow:hidden}.hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr);gap:clamp(2rem,6vw,6rem);align-items:center}.hero-copy{max-width:650px;margin-top:1.6rem}.availability-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem}.mini-proof{border-top:1px solid var(--line);padding-top:1rem}.mini-proof b{display:block;margin-bottom:.35rem}.hero-actions-art{margin-top:2rem;display:grid;grid-template-columns:1fr .85fr;gap:1rem;align-items:stretch}.tiny-map{min-height:120px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(135deg,rgba(215,230,242,.58),rgba(233,241,230,.52));position:relative;overflow:hidden}.tiny-map:before{content:"";position:absolute;inset:20px;background:repeating-linear-gradient(90deg,rgba(20,20,17,.08) 0 1px,transparent 1px 34px),repeating-linear-gradient(0deg,rgba(20,20,17,.08) 0 1px,transparent 1px 34px)}.tiny-map:after{content:"fracture → pattern → system";position:absolute;left:1rem;bottom:1rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:800}.floating-note{padding:1rem;border-radius:24px;border:1px solid var(--line);background:rgba(255,250,240,.76);box-shadow:var(--shadow-soft)}
.offer-band{padding:clamp(5rem,10vw,8rem) 0;background:var(--dark);color:var(--cream);position:relative;overflow:hidden}.offer-band:after{content:"";position:absolute;right:10%;bottom:-18%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(79,143,106,.35),transparent 65%)}.offer-diagram{height:280px;border:1px solid rgba(255,255,255,.13);border-radius:28px;background:linear-gradient(135deg,rgba(215,230,242,.07),rgba(79,143,106,.08));position:relative;overflow:hidden}.offer-diagram:before{content:"";position:absolute;inset:12%;border:1px dashed rgba(255,255,255,.24);border-radius:50%;animation:spin 18s linear infinite}.offer-diagram:after{content:"mess → map → move";position:absolute;left:2rem;bottom:2rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,250,240,.52)}@keyframes spin{to{transform:rotate(360deg)}}.dot{position:absolute;width:16px;height:16px;border-radius:50%;background:var(--green);box-shadow:0 0 0 10px rgba(79,143,106,.14)}.dot.d1{left:28%;top:32%;background:var(--blue-2)}.dot.d2{right:22%;top:48%;background:var(--green)}.dot.d3{left:48%;bottom:24%;background:var(--rust)}
.work-list{display:flex;flex-direction:column;gap:1rem}.work-row{display:grid;grid-template-columns:.75fr 1.05fr .82fr;gap:1.5rem;padding:1.15rem;border:1px solid var(--line);border-radius:30px;background:rgba(255,250,240,.62);align-items:center;position:relative;overflow:hidden}.work-row:hover{background:rgba(255,250,240,.9);transform:translateY(-4px);box-shadow:var(--shadow-soft);transition:.25s ease}.work-title{font-family:var(--serif);font-size:clamp(1.75rem,3.4vw,3rem);line-height:.98;letter-spacing:-.015em}.work-thumb{min-height:170px;border-radius:24px;border:1px solid var(--line);overflow:hidden;position:relative;background:var(--paper-3)}.work-thumb img{width:100%;height:100%;object-fit:cover}.work-thumb .coming{position:absolute;left:1rem;bottom:1rem;background:rgba(255,250,240,.78);border:1px solid rgba(255,255,255,.7);padding:.55rem .75rem;border-radius:999px;backdrop-filter:blur(10px)}.work-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.7rem}.work-row:before{content:"";position:absolute;right:-8%;top:-20%;width:200px;height:200px;border-radius:50%;background:rgba(215,230,242,.3);opacity:0;transition:.25s}.work-row:hover:before{opacity:1}
.note-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.note-card{border-top:1px solid rgba(255,255,255,.16);padding:1.5rem 0;position:relative}.note-card h3{font-family:var(--serif);font-size:1.9rem;line-height:1;margin:.3rem 0 .7rem}.note-card p{color:rgba(255,250,240,.66)}.external-icon{display:inline-flex;margin-left:.3rem;opacity:.7}.view-more{margin-top:2rem}.experiment-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.experiment-card{min-height:220px;display:flex;flex-direction:column;justify-content:space-between}.experiment-card h3{font-family:var(--serif);font-size:1.65rem;line-height:1;margin:.7rem 0}.experiment-card:hover{transform:translateY(-4px);transition:.25s ease}.case-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.case-card{min-height:310px;display:flex;flex-direction:column;justify-content:space-between}.case-card .media-mini{height:120px;border-radius:22px;border:1px solid var(--line);background:linear-gradient(135deg,var(--blue),var(--green-soft));position:relative;overflow:hidden;margin-bottom:1rem}.media-mini:before{content:"";position:absolute;inset:18px;border:1px dashed rgba(20,20,17,.28);border-radius:18px}.media-mini:after{content:"coming soon";position:absolute;right:1rem;bottom:1rem;font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);animation:blink 1.4s steps(2,end) infinite}@keyframes blink{50%{opacity:.35}}
.sprint-hero{padding:9rem 0 5rem}.sprint-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.78fr);gap:4rem;align-items:center}.sprint-hero-illustration{margin-top:2rem;min-height:150px;border-radius:30px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(215,230,242,.7),rgba(233,241,230,.74));position:relative;overflow:hidden}.sprint-hero-illustration:before{content:"";position:absolute;inset:20px;background:radial-gradient(circle at 20% 50%,var(--rust) 0 8px,transparent 9px),radial-gradient(circle at 50% 35%,var(--green) 0 8px,transparent 9px),radial-gradient(circle at 76% 64%,var(--blue-2) 0 8px,transparent 9px)}.sprint-hero-illustration:after{content:"messy idea → useful direction";position:absolute;left:1.2rem;bottom:1.1rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:800}.sprint-panel{background:rgba(255,250,240,.78);border:1px solid var(--line);border-radius:34px;box-shadow:var(--shadow);padding:2rem}.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;position:relative}.process-card{position:relative;min-height:225px}.process-card .num{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--ink);color:var(--cream);font-weight:800;margin-bottom:.9rem}.package-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.package-card{min-height:500px;display:flex;flex-direction:column;background:var(--dark);color:var(--cream);border-color:rgba(255,255,255,.16)}.package-card.featured{background:linear-gradient(160deg,var(--dark),#162018);border-color:rgba(79,143,106,.48)}.package-card ul,.plain-list{padding-left:1.1rem;color:var(--muted)}.package-card li,.plain-list li{margin:.55rem 0}.package-card .btn{margin-top:auto}.package-card .body,.package-card .plain-list{color:rgba(255,250,240,.58)}.package-card .btn.green{color:#fff}.deliverable-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}.deliverable{border:1px solid var(--line);border-radius:18px;padding:1rem;background:rgba(255,250,240,.65);font-weight:800;position:relative}.deliverable span{display:block;margin-top:.35rem;font-weight:500;color:var(--muted);font-size:.82rem;line-height:1.45}.deliverable:hover{background:var(--blue);transform:translateY(-2px);transition:.25s}.deliverable:before{content:"";display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--green);margin-right:.45rem}.not-section .card{background:linear-gradient(135deg,var(--dark),#172018);color:var(--cream)}.not-section .body,.not-section li{color:rgba(255,250,240,.66)}
.contact-hero{padding:9rem 0 3rem}.contact-email-display{font-family:var(--serif);font-size:clamp(3rem,8vw,6.4rem);letter-spacing:-.03em;line-height:.95;word-break:break-word}.contact-email-display span{color:var(--muted);font-style:italic}.path-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.path-card{cursor:pointer;min-height:220px;text-align:left}.path-card:hover{background:var(--blue)}.contact-art{height:170px;border:1px solid var(--line);border-radius:28px;background:linear-gradient(135deg,rgba(215,230,242,.76),rgba(233,241,230,.72));position:relative;margin-top:1.4rem;overflow:hidden}.contact-art:before{content:"";position:absolute;inset:24px;border:1px dashed rgba(20,20,17,.28);border-radius:22px}.contact-art:after{content:"short email, messy email, brave first draft";position:absolute;left:1rem;bottom:1rem;font-family:var(--mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:800}.form-panel{margin-top:2rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-field{width:100%;border:1px solid var(--line);border-radius:18px;background:rgba(255,250,240,.72);padding:1rem;font:inherit;color:var(--ink)}textarea.form-field{min-height:160px;resize:vertical}.modal{position:fixed;inset:0;z-index:3000;display:none;place-items:center;padding:1.2rem;background:rgba(17,17,15,.45);backdrop-filter:blur(14px)}.modal.is-open{display:grid}.modal-card{width:min(780px,100%);max-height:90vh;overflow:auto;background:var(--paper-2);border:1px solid var(--line);border-radius:32px;padding:clamp(1.5rem,4vw,2.6rem);box-shadow:0 40px 120px rgba(0,0,0,.26)}.modal-close{float:right;border:0;background:var(--dark);color:var(--cream);border-radius:999px;padding:.55rem .8rem;font-weight:800;cursor:pointer}.helper{font-size:.82rem;color:var(--muted)}
.case-hero{padding:9rem 0 3rem}.case-layout{display:grid;grid-template-columns:.75fr 1.25fr;gap:4rem}.case-meta{position:sticky;top:7rem}.case-visual{min-height:330px;border:1px solid var(--line);border-radius:34px;background:linear-gradient(135deg,rgba(215,230,242,.7),rgba(255,250,240,.68));position:relative;box-shadow:var(--shadow-soft);overflow:hidden}.case-visual:before{content:"";position:absolute;inset:36px;border:1px dashed rgba(20,20,17,.26);border-radius:28px}.case-visual:after{content:"sanitized visual layer · replace when safe";position:absolute;left:2rem;bottom:2rem;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.lock-panel{position:fixed;inset:0;background:rgba(17,17,15,.78);backdrop-filter:blur(18px);z-index:2000;display:grid;place-items:center;padding:2rem}.lock-card{width:min(560px,100%);background:var(--paper-2);border:1px solid var(--line);border-radius:32px;padding:2rem;box-shadow:0 30px 100px rgba(0,0,0,.35)}.lock-card input{width:100%;border:1px solid var(--line);border-radius:16px;padding:1rem 1.1rem;background:var(--cream);font:inherit;margin:1rem 0}.lock-error{color:var(--rust);font-weight:800;min-height:1.3em}.protected-content.is-locked{display:none}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}.site-footer{padding:2rem 0;border-top:1px solid var(--line);font-size:.78rem;color:var(--muted)}.footer-grid{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
@media (max-width:1050px){.grid-3,.package-grid,.process-grid,.case-grid{grid-template-columns:1fr 1fr}.grid-4,.experiment-grid,.path-grid{grid-template-columns:1fr 1fr}.hero-grid,.sprint-hero-grid,.grid-2,.split-title,.case-layout{grid-template-columns:1fr}.work-row{grid-template-columns:1fr}.nav-links{display:none}.nav-toggle{display:block}.site-nav.is-open{border-radius:26px}.site-nav.is-open .nav-links{display:flex;position:absolute;left:0;right:0;top:calc(100% + .6rem);background:rgba(255,250,240,.86);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:24px;padding:1rem;flex-direction:column;box-shadow:var(--shadow)}.case-meta{position:relative;top:0}.process-card .connector-arrow{display:none}.form-grid{grid-template-columns:1fr}}
@media (max-width:680px){.container,.container.wide{width:min(100% - 32px,1180px)}.display{font-size:clamp(4rem,20vw,6rem)}.title-xl{font-size:clamp(3.1rem,16vw,4.7rem)}.title-lg{font-size:clamp(2.45rem,12vw,3.7rem)}.grid-3,.grid-4,.case-grid,.note-grid,.package-grid,.process-grid,.deliverable-grid,.experiment-grid,.path-grid,.availability-strip,.hero-actions-art{grid-template-columns:1fr}.site-nav{width:calc(100% - 24px);top:.75rem}.nav-brand span:last-child{display:none}.section{padding:4.5rem 0}.hero{min-height:auto;padding-top:8rem}.btn-row{align-items:stretch}.btn{width:100%}.card{border-radius:22px}.contact-email-display{font-size:clamp(2.5rem,14vw,4.1rem)}.footer-grid{display:block}.footer-grid div+div{margin-top:1rem}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}


/* =============================
   V1.2 polish pass
   Personal pages return to the quieter editorial direction.
   Sprint page keeps its own sales-page language.
   ============================= */

/* Better CH mark / favicon readability */
.nav-mark{
  background: var(--paper-2) !important;
  border: 2px solid var(--ink);
  color: var(--ink);
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-size: .86rem;
  font-weight: 700;
  letter-spacing: -.08em;
  line-height: 1;
  box-shadow: 0 0 0 8px rgba(255,250,240,.54), 0 10px 26px rgba(20,20,17,.10);
  position: relative;
  overflow: visible;
}
.nav-mark::after{
  content:"";
  position:absolute;
  width:7px;height:7px;border-radius:50%;
  right:-2px;bottom:3px;background:var(--green);
  box-shadow: 0 0 0 3px var(--paper-2);
}
.site-nav{
  background: rgba(255,250,240,.50);
  border-color: rgba(255,255,255,.74);
  backdrop-filter: blur(30px) saturate(1.45);
  -webkit-backdrop-filter: blur(30px) saturate(1.45);
}
.site-nav.scrolled{background:rgba(255,250,240,.72)}

/* Header typography: avoid orphan words, keep readable rhythm */
.display,.title-xl,.title-lg,.title-md,.work-title{ text-wrap: balance; }
.display{font-size:clamp(4rem,9.2vw,9.2rem);line-height:.94;letter-spacing:-.02em;}
.title-xl{font-size:clamp(3.7rem,8vw,7.8rem);line-height:.94;letter-spacing:-.018em;}
.title-lg{font-size:clamp(2.8rem,6vw,5.7rem);line-height:.98;letter-spacing:-.015em;}
.title-md{line-height:1.06;letter-spacing:-.012em;}
.body-xl{max-width:62ch;}
.body{max-width:72ch;}

/* Reduce accidental empty deserts on personal pages */
body.personal-site .hero{min-height:92svh;padding-top:8.5rem;padding-bottom:4.25rem;}
body.personal-site .section{padding:clamp(4.5rem,7.6vw,7rem) 0;}
body.personal-site .section.compact{padding:clamp(3.4rem,6vw,5.3rem) 0;}
body.personal-site .case-hero,
body.personal-site .contact-hero{padding:8rem 0 4.4rem;}
body.personal-site .split-title{align-items:start;}
body.personal-site .hero-grid{grid-template-columns:minmax(0,.95fr) minmax(320px,1.05fr);}
body.personal-site .hero-copy{margin-top:1.2rem;}
body.personal-site .availability-strip{margin-top:2.35rem;}
body.personal-site .hero-actions-art{margin-top:1.55rem;}
body.personal-site .placeholder{min-height:170px;}
body.personal-site .media-card{background:rgba(255,250,240,.62);}

/* Personal page color audit: stronger contrast, no low-visibility dark text */
body.personal-site .dark{background:#11110f;color:var(--cream);}
body.personal-site .dark .eyebrow{color:rgba(255,250,240,.62);}
body.personal-site .dark .body,
body.personal-site .dark .body-xl,
body.personal-site .dark p{color:rgba(255,250,240,.78);}
body.personal-site .dark strong{color:var(--cream);}
body.personal-site .card,
body.personal-site .paper-card,
body.personal-site .path-card,
body.personal-site .case-card{background:rgba(255,250,240,.78);}
body.personal-site .card .body,
body.personal-site .path-card .body,
body.personal-site .case-card .body{color:#5f574d;}
body.personal-site .tag{color:#5c554d;}
body.personal-site .tag.green{color:#27553d;}
body.personal-site .tag.blue{color:#39586e;}
body.personal-site .tag.rust{color:#7d3b26;}

/* Clear link affordance and hover effects */
a:not(.nav-brand):not(.btn):not(.nav-cta):not(.nav-links a){text-decoration-thickness:1px;text-underline-offset:.18em;}
.work-row,.note-card,.case-card,.path-card,.experiment-card,.related-item{transition:transform .28s ease, box-shadow .28s ease, background .28s ease, border-color .28s ease, color .28s ease;}
.work-row:hover,.case-card:hover,.path-card:hover,.experiment-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft);border-color:rgba(20,20,17,.25);}
.work-row::after{
  content:"Open →";
  position:absolute;right:1.1rem;top:1.05rem;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);opacity:0;transform:translateY(-4px);transition:.25s ease;
}
.work-row:hover::after{opacity:1;transform:translateY(0);}
.note-card{padding:1.55rem;border-radius:24px;border-top:1px solid rgba(255,255,255,.16);}
.note-card:hover{background:rgba(255,250,240,.08);transform:translateY(-4px);}
.note-card:hover h3{color:var(--cream);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.22em;}
.external-icon{font-size:.9em;opacity:.9;transform:translateY(-.08em);}
.btn{position:relative;overflow:hidden;}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent,rgba(255,255,255,.22),transparent);transform:translateX(-115%);transition:.5s ease;}
.btn:hover::before{transform:translateX(115%);}
.btn.text::before{display:none;}

/* Coming soon placeholders should look intentional, not empty */
.coming{font-weight:800;color:#5f574d;}
.coming .typed{min-width:10ch;color:#3f6f53;border-right-color:var(--green);}
.placeholder{
  background:
    radial-gradient(circle at 20% 18%, rgba(215,230,242,.42), transparent 40%),
    radial-gradient(circle at 86% 80%, rgba(79,143,106,.18), transparent 42%),
    rgba(255,250,240,.68);
}
.placeholder::after{
  content:"";
  width:54px;height:24px;border-bottom:2px dashed rgba(20,20,17,.24);border-radius:50%;
  position:absolute;right:1.6rem;top:1.35rem;transform:rotate(-9deg);
}

/* Work/case cards: more visually alive, still calm */
.work-thumb,.media-mini,.case-visual,.contact-art,.tiny-map{background:
  radial-gradient(circle at 22% 26%, rgba(215,230,242,.74), transparent 36%),
  radial-gradient(circle at 82% 82%, rgba(79,143,106,.22), transparent 42%),
  var(--paper-2);}
.work-thumb img,.media-card img{transition:transform .45s ease, filter .45s ease;}
.work-row:hover .work-thumb img,.media-card:hover img{transform:scale(1.025);filter:saturate(1.05);}

/* Contact page: make the path cards and email area less empty */
.contact-email-display{font-size:clamp(2.7rem,7vw,5.7rem);line-height:1;}
.contact-email-display span{font-style:italic;color:#6a6257;}
.path-card{position:relative;}
.path-card::after{content:"Open form";position:absolute;left:1.35rem;bottom:1.15rem;font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);opacity:0;transition:.25s ease;}
.path-card:hover::after{opacity:1;}
.path-card:hover{background:linear-gradient(135deg,rgba(215,230,242,.78),rgba(233,241,230,.72));}
.contact-art{min-height:150px;}

/* Project detail template: closer to original Kimi editorial rhythm */
.project-hero,.case-hero{position:relative;}
.case-layout{gap:clamp(2rem,4vw,4rem);}
.case-visual{min-height:300px;}
.plain-list li{margin-bottom:.58rem;color:#5f574d;}

/* Sprint page stays distinct, but fix contrast and hover clarity */
body.sprint-page .option-card,
body.sprint-page .process-card,
body.sprint-page .deliverable-item{color:#151515;}
body.sprint-page .option-card.featured{color:#fffaf0;}
body.sprint-page .option-card:not(.featured) p,
body.sprint-page .option-card:not(.featured) li{color:#5d554b;}
body.sprint-page .featured p,
body.sprint-page .featured li{color:rgba(255,250,240,.76)!important;}
body.sprint-page .dark-band p{color:rgba(255,250,240,.78)!important;}
body.sprint-page .cta-primary:hover,
body.sprint-page .cta-secondary:hover{transform:translateY(-2px);}

/* Mobile refinements */
@media (max-width: 1050px){
  body.personal-site .hero-grid{grid-template-columns:1fr;}
  body.personal-site .hero{padding-top:7.5rem;}
}
@media (max-width: 680px){
  .container,.container.wide{width:min(100% - 32px, var(--max));}
  .display{font-size:clamp(3.6rem,18vw,5.8rem);line-height:.96;}
  .title-xl{font-size:clamp(3rem,15vw,5rem);}
  .title-lg{font-size:clamp(2.6rem,12vw,4.2rem);}
  .site-nav{width:calc(100% - 20px);top:.7rem;}
  .nav-brand span:last-child{display:none;}
  .availability-strip,.grid-4,.experiment-grid,.path-grid{grid-template-columns:1fr;}
}
