:root{--bg:#F8F7F4;--ink:#1E2328;--ink2:#5A6068;--ink3:#9AA0A6;--accent:#C47B3C;--al:#F4E4D0;--a2:#3D5A80;--white:#FFFFFF;--border:rgba(30,35,40,0.1);--serif:'Instrument Serif',Georgia,serif;--sans:'DM Sans',sans-serif;--body:'DM Sans',sans-serif;--nav-bg:rgba(248,247,244,.94);--panel:#1A2028}
html[data-theme="dark"]{--bg:#14181C;--ink:#F0EDE8;--ink2:#8A9098;--ink3:#5A6068;--white:#1C2228;--border:rgba(240,237,232,0.1);--al:#2A2218;--nav-bg:rgba(20,24,28,.94);--panel:#0E1218}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.6;overflow-x:hidden}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:9998;opacity:.4}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.25rem 3rem;display:flex;justify-content:space-between;align-items:center;background:var(--nav-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:padding .3s,background .3s}
.nav-logo{font-family:var(--serif);font-size:1.25rem;color:var(--ink);text-decoration:none;letter-spacing:.01em}
.nav-actions{display:flex;align-items:center;gap:.5rem}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-family:var(--sans);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{background:var(--ink)!important;color:var(--bg)!important;padding:.5rem 1.25rem;border-radius:2rem;transition:background .2s,transform .1s!important}
.nav-cta:hover{background:var(--accent)!important;color:var(--white)!important;transform:translateY(-1px)}

/* HERO */
#hero{min-height:88vh;display:grid;grid-template-columns:1fr 1fr;padding-top:0}
.hero-left{padding:7rem 3.5rem 3.5rem 3rem;display:flex;flex-direction:column;justify-content:center}
.hero-eye{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.63rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.75rem}
.hero-eye::before{content:'';width:1.6rem;height:1px;background:var(--accent)}
h1.hh{font-family:var(--serif);font-size:clamp(2.5rem,4.3vw,4rem);font-weight:400;line-height:1.1;letter-spacing:-.025em;margin-bottom:1.4rem}
h1.hh em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:1rem;color:var(--ink2);line-height:1.78;max-width:44ch;margin-bottom:2.25rem;font-weight:300}
.hero-sub strong{color:var(--ink);font-weight:500}
.hero-btns{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:2.5rem}
.bp{background:var(--ink);color:#fff;padding:.78rem 1.7rem;border-radius:3rem;font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .15s;display:inline-flex;align-items:center;gap:.4rem}
.bp:hover{background:var(--accent);transform:translateY(-2px)}
.bs{background:transparent;color:var(--ink);padding:.78rem 1.7rem;border-radius:3rem;border:1.5px solid var(--border);font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;text-decoration:none;transition:border-color .2s,transform .15s;display:inline-flex;align-items:center;gap:.4rem}
.bs:hover{border-color:var(--ink);transform:translateY(-2px)}

/* QUICK JUMP BAR */
.jump-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.jump-label{font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-right:.25rem}
.jump-btn{background:var(--white);border:1px solid var(--border);border-radius:2rem;padding:.32rem .85rem;font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink2);text-decoration:none;transition:background .15s,border-color .15s,color .15s;display:inline-flex;align-items:center;gap:.3rem;cursor:pointer}
.jump-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.jump-btn .jdot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.jd1{background:#C47B3C}.jd2{background:#3D5A80}.jd3{background:#2A5A40}.jd4{background:#3D2B1F}.jd5{background:#485A70}.jd6{background:#2A2070}.jd7{background:#1A3A2A}

/* HERO RIGHT */
.hero-right{background:var(--panel);position:relative;overflow:hidden;display:flex;flex-direction:column;padding:0}
.hglow{position:absolute;inset:0;background:radial-gradient(ellipse at 40% 40%,rgba(196,123,60,.22) 0%,transparent 50%),radial-gradient(ellipse at 75% 70%,rgba(61,90,128,.25) 0%,transparent 45%)}
.hwm{display:none}
.hero-photo-wrap{position:relative;z-index:1;display:flex;justify-content:center;align-items:center;flex:1;padding-top:4rem}
.hero-photo{width:190px;height:190px;border-radius:50%;object-fit:cover;border:3px solid rgba(123,79,207,.55);box-shadow:0 0 0 8px rgba(123,79,207,.12),0 8px 32px rgba(0,0,0,.35)}
.mgrid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:1px;flex:1}
.mc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);padding:1.1rem 1rem;transition:background .25s;cursor:default;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.35rem}
.mc:hover{background:rgba(255,255,255,.09)}
.mn{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.6rem);font-style:italic;color:#fff;line-height:1}
.ma{color:var(--accent)}
.mk{font-family:var(--sans);font-size:.55rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:.15rem}
.ml{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:300;line-height:1.55;max-width:16ch}
.mc::before{content:'';display:block;width:1.8rem;height:2px;background:var(--accent);border-radius:2px;margin-bottom:.6rem;opacity:.7}

/* SECTIONS */
section{padding:6.5rem 3rem}
.sl{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:.55rem;margin-bottom:1.85rem}
.sl::after{content:'';flex:0 0 2.2rem;height:1px;background:var(--accent)}
.sh2{font-family:var(--serif);font-size:clamp(1.9rem,3.3vw,3rem);font-weight:400;line-height:1.15;letter-spacing:-.02em;color:var(--ink);margin-bottom:1.1rem}
.sh2 em{font-style:italic;color:var(--accent)}

/* ABOUT */
#about{background:var(--white);display:grid;grid-template-columns:1fr;gap:3rem}
.ab{font-size:1rem;color:var(--ink2);line-height:1.82;font-weight:300;margin-bottom:1.1rem}
.ab strong{color:var(--ink);font-weight:500}
.vals{display:flex;flex-direction:column;gap:.55rem;margin:1.4rem 0 1.8rem}
.val{display:flex;align-items:flex-start;gap:.55rem;font-size:.88rem;color:var(--ink2);font-weight:300}
.val::before{content:'→';color:var(--accent);flex-shrink:0}
.acard{background:var(--bg);border:1px solid var(--border);border-radius:1rem;padding:1.4rem;margin-bottom:.8rem}
.act{font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.01em;color:var(--ink3);margin-bottom:.9rem}
.er{display:flex;gap:.8rem;padding:.6rem 0;border-bottom:1px solid var(--border);align-items:flex-start}
.er:last-child{border-bottom:none;padding-bottom:0}
.ed{width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:.42rem;flex-shrink:0}
.ero{font-family:var(--sans);font-size:.8rem;font-weight:600;color:var(--ink)}
.eco{font-size:.76rem;color:var(--ink2);font-weight:300}
.eyr{font-size:.68rem;color:var(--ink3);margin-top:.1rem}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.fc{background:var(--white);border:1px solid var(--border);border-radius:.6rem;padding:.6rem .85rem;font-size:.76rem;color:var(--ink2);font-weight:300;line-height:1.4}
.fc strong{color:var(--accent);font-weight:500}

/* ANALYTICS CALLOUT BAR */
.analytics-bar{background:linear-gradient(135deg,var(--a2) 0%,#243650 100%);border-radius:1rem;padding:1.75rem 2rem;margin-top:2.5rem;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center}
.ab-title{font-family:var(--serif);font-size:1.2rem;font-style:italic;color:#fff;margin-bottom:.4rem}
.ab-sub{font-size:.82rem;color:rgba(255,255,255,.6);font-weight:300;line-height:1.5}
.ab-chips{display:flex;gap:.4rem;flex-wrap:wrap}
.ab-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:2rem;padding:.3rem .75rem;font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.01em;color:rgba(255,255,255,.85)}

/* WORK */
#work{background:var(--bg)}
.wi{max-width:52ch;font-size:.98rem;color:var(--ink2);font-weight:300;line-height:1.78;margin-bottom:3.25rem}
.cgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.15rem}
.cc{border-radius:1rem;overflow:hidden;border:1px solid var(--border);background:var(--white);cursor:pointer;transition:transform .25s,box-shadow .25s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.cc:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(30,35,40,.1)}
.cc.lg{grid-column:span 7}.cc.sm{grid-column:span 5}.cc.hf{grid-column:span 6}.cc.th{grid-column:span 4}
.cct{height:205px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:1.3rem}
.cct-bg{position:absolute;inset:0}
.cpat{position:absolute;inset:0;opacity:.11;background-image:radial-gradient(circle,rgba(255,255,255,.7) 1px,transparent 1px);background-size:22px 22px}
.bg1{background:linear-gradient(135deg,#A85E20 0%,#C47B3C 100%)}
.bg2{background:linear-gradient(135deg,#243650 0%,#3D5A80 100%)}
.bg3{background:linear-gradient(135deg,#2A4A3A 0%,#4A7060 100%)}
.bg4{background:linear-gradient(135deg,#3D2B1F 0%,#785040 100%)}
.bg5{background:linear-gradient(135deg,#2C3E50 0%,#485A70 100%)}
.bg6{background:linear-gradient(135deg,#1A1A2E 0%,#4A2C6E 100%)}
.bg7{background:linear-gradient(135deg,#1A3A2A 0%,#2A6A4A 100%)}
.cnum{position:relative;font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.52)}
.cimp{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);border-radius:.4rem;padding:.35rem .6rem;font-family:var(--serif);font-size:1.25rem;font-style:italic;color:#fff;line-height:1}
.ccb{padding:1.35rem;flex:1;display:flex;flex-direction:column}
.ctag{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.01em;color:var(--accent);margin-bottom:.45rem}
.ctit{font-family:var(--serif);font-size:1.15rem;font-weight:400;line-height:1.25;color:var(--ink);margin-bottom:.6rem;letter-spacing:-.01em}
.cdesc{font-size:.82rem;color:var(--ink2);font-weight:300;line-height:1.6;flex:1}
.cfoot{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border)}
.pills{display:flex;gap:.32rem;flex-wrap:wrap}
.pill{font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.01em;padding:.18rem .55rem;border-radius:2rem;background:var(--bg);border:1px solid var(--border);color:var(--ink2)}
.carr{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:.82rem;transition:background .2s,border-color .2s,transform .2s;flex-shrink:0}
.cc:hover .carr{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg)}

/* MODAL */
.mo{position:fixed;inset:0;background:rgba(30,35,40,.74);backdrop-filter:blur(10px);z-index:2000;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;opacity:0;pointer-events:none;transition:opacity .3s;overflow-y:auto}
.mo.open{opacity:1;pointer-events:all}
.mbox{background:var(--bg);border-radius:1.5rem;max-width:860px;width:100%;overflow:hidden;transform:translateY(26px);transition:transform .35s cubic-bezier(.16,1,.3,1);margin:auto}
.mo.open .mbox{transform:translateY(0)}
.mhero{height:265px;position:relative;display:flex;align-items:flex-end;padding:2.25rem}
.mhc{position:relative;z-index:1}
.mhtag{font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:.38rem}
.mhtit{font-family:var(--serif);font-size:1.8rem;font-weight:400;color:#fff;line-height:1.2;letter-spacing:-.02em;max-width:24ch}
.mcls{position:absolute;top:1.3rem;right:1.3rem;z-index:2;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.14);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;transition:background .2s}
.mcls:hover{background:rgba(255,255,255,.28)}
.mbody{padding:2.25rem}
.mmets{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-bottom:2.25rem}
.mmet{background:var(--white);border:1px solid var(--border);border-radius:.7rem;padding:1.05rem;text-align:center}
.mmn{font-family:var(--serif);font-size:1.6rem;font-style:italic;color:var(--accent);line-height:1;margin-bottom:.22rem}
.mml{font-size:.68rem;color:var(--ink2);font-weight:300}
.mtabs{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:1.6rem;border-bottom:1px solid var(--border);padding-bottom:.9rem}
.mtab{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .95rem;border-radius:2rem;border:1.5px solid var(--border);background:transparent;color:var(--ink2);cursor:pointer;transition:.2s}
.mtab.act{background:var(--ink);color:#fff;border-color:var(--ink)}
.mpanel{display:none}
.mpanel.act{display:block}
.msec{margin-bottom:1.65rem}
.mst{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.01em;color:var(--accent);margin-bottom:.6rem}
.msb{font-size:.88rem;color:var(--ink2);font-weight:300;line-height:1.82}
.msb strong{color:var(--ink);font-weight:500}
.msteps{display:flex;flex-direction:column;gap:.42rem;margin-top:.45rem}
.mstep{display:flex;gap:.8rem;align-items:flex-start;padding:.65rem .95rem;background:var(--white);border:1px solid var(--border);border-radius:.65rem}
.msnum{font-family:var(--sans);font-size:.58rem;font-weight:700;color:var(--accent);background:var(--al);width:21px;height:21px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.08rem}
.mstxt{font-size:.83rem;color:var(--ink2);font-weight:300;line-height:1.55}
.mstxt strong{color:var(--ink);font-weight:500}
.mquote{background:linear-gradient(135deg,var(--al),rgba(61,90,128,.07));border:1px solid rgba(196,123,60,.18);border-radius:.7rem;padding:1.15rem 1.3rem;font-size:.86rem;color:var(--ink2);font-weight:300;line-height:1.78;font-style:italic;margin-top:.45rem}
.agrid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin-top:.65rem}
.acard{background:var(--white);border:1px solid var(--border);border-radius:.7rem;padding:1rem}
.alabel{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.01em;color:var(--a2);margin-bottom:.45rem}
.atit{font-size:.82rem;font-weight:500;color:var(--ink);margin-bottom:.3rem}
.adesc{font-size:.76rem;color:var(--ink2);font-weight:300;line-height:1.5}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:.65rem}
.persona{background:var(--white);border:1px solid var(--border);border-radius:.7rem;padding:.95rem}
.pav{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:.72rem;font-weight:700;margin-bottom:.55rem;color:#fff}
.pa1{background:var(--accent)}.pa2{background:var(--a2)}.pa3{background:#2A5A40}
.pname{font-family:var(--sans);font-size:.72rem;font-weight:700;color:var(--ink);margin-bottom:.18rem}
.prole{font-size:.7rem;color:var(--ink2);font-weight:300;margin-bottom:.35rem}
.pneed{font-size:.7rem;color:var(--ink2);font-weight:300;line-height:1.5;border-top:1px solid var(--border);padding-top:.38rem;margin-top:.38rem}
.jtable{width:100%;border-collapse:collapse;margin-top:.65rem;font-size:.8rem}
.jtable th{font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);padding:.55rem .7rem;border-bottom:1.5px solid var(--border);text-align:left}
.jtable td{padding:.55rem .7rem;border-bottom:1px solid var(--border);color:var(--ink2);font-weight:300;vertical-align:top}
.jtable tr:last-child td{border-bottom:none}
.jtable td:first-child{color:var(--ink);font-weight:500}
.fviz{display:flex;flex-direction:column;gap:3px;margin-top:.65rem}
.frow{display:flex;align-items:center;gap:.7rem}
.fbw{flex:1;background:var(--bg);border-radius:3px;height:30px;overflow:hidden;border:1px solid var(--border)}
.fbar{height:100%;display:flex;align-items:center;padding-left:.7rem;font-size:.72rem;font-weight:500;color:#fff;border-radius:3px;white-space:nowrap}
.flabel{font-size:.72rem;color:var(--ink2);font-weight:300;min-width:145px;text-align:right}
.fpct{font-size:.72rem;font-weight:600;color:var(--ink);min-width:36px;text-align:right}


/* ABOUT INNER LAYOUT */
.about-inner{display:grid;grid-template-columns:1.15fr 1fr;gap:5rem;align-items:start}
.about-intro{display:flex;flex-direction:column;gap:0}
.about-intro-text{flex:1}
/* AGILE VISUAL PANELS */
.case-visual{width:100%;border-radius:.75rem;overflow:hidden;margin-top:.65rem;border:1px solid var(--border)}
.sprint-board{background:#1A2535;padding:1.25rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.sb-col-head{font-family:var(--sans);font-size:.66rem;font-weight:700;letter-spacing:.01em;color:rgba(255,255,255,.55);margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.sb-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:.4rem;padding:.55rem .65rem;margin-bottom:.4rem}
.sb-card-label{font-size:.68rem;color:rgba(255,255,255,.7);font-weight:300;line-height:1.35}
.sb-card-tag{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.01em;margin-top:.25rem;opacity:.7}
.tag-data{color:#5DBBFF}.tag-retail{color:#5DFF9E}.tag-sec{color:#FFB24A}.tag-block{color:#FF7A7A}
.dep-arrow{font-size:.7rem;color:rgba(255,255,255,.3);text-align:center;padding:.25rem 0}
.spillover-viz{background:var(--white);padding:1.25rem;border-top:1px solid var(--border)}
.spill-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.55rem}
.spill-label{font-size:.72rem;color:var(--ink2);font-weight:400;min-width:80px}
.spill-bar-wrap{flex:1;background:var(--bg);border-radius:3px;height:22px;overflow:hidden}
.spill-bar{height:100%;border-radius:3px;display:flex;align-items:center;padding-left:.6rem;font-size:.65rem;font-weight:600;color:#fff;white-space:nowrap}
.spill-pct{font-size:.7rem;font-weight:600;min-width:36px;text-align:right}

/* DEPENDENCY DIAGRAM */
.dep-diagram{background:#F8F6F1;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}
.dep-row{display:flex;align-items:center;gap:.5rem}
.dep-team{background:var(--white);border:1px solid var(--border);border-radius:.4rem;padding:.4rem .7rem;font-family:var(--sans);font-size:.62rem;font-weight:600;color:var(--ink);min-width:80px;text-align:center}
.dep-link{flex:1;height:1px;background:var(--border);position:relative;display:flex;align-items:center;justify-content:center}
.dep-link::after{content:'BLOCKS';font-family:var(--sans);font-size:.5rem;font-weight:700;letter-spacing:.08em;color:var(--accent);background:var(--bg);padding:0 .3rem}
.dep-badge{font-family:var(--sans);font-size:.65rem;font-weight:700;letter-spacing:.01em;padding:.18rem .5rem;border-radius:2rem}
.db-before{background:#FFE4E4;color:#CC0000}.db-after{background:#E4FFE8;color:#006600}

.velocity-chart{background:var(--white);padding:1.1rem}
.vc-title{font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.01em;color:var(--ink3);margin-bottom:.85rem}
.vc-bars{display:flex;gap:.35rem;align-items:flex-end;height:80px}
.vc-bar-wrap{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex:1}
.vc-bar{width:100%;border-radius:3px 3px 0 0;transition:height .4s}
.vc-blabel{font-size:.58rem;color:var(--ink3);font-weight:300}
.vc-legend{display:flex;gap:1rem;margin-top:.5rem;font-size:.62rem;color:var(--ink3)}
.vc-leg-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.3rem}
#skills{background:var(--panel);color:#fff}
#skills .sl{color:var(--accent)}
#skills .sl::after{background:var(--accent)}
#skills .sh2{color:#fff}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.15rem;margin-top:2.5rem}
.sg{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:1rem;padding:1.3rem}
.sgt{font-family:var(--sans);font-size:.75rem;font-weight:700;letter-spacing:.01em;color:var(--accent);margin-bottom:1rem}
.skl{display:flex;flex-direction:column;gap:.48rem}
.sk{display:flex;align-items:center;gap:.48rem;font-size:.8rem;color:rgba(255,255,255,.66);font-weight:300}
.skd{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}
.trow{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:2.25rem}
.tc{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:2rem;padding:.38rem .9rem;font-family:var(--sans);font-size:.73rem;font-weight:500;letter-spacing:.01em;color:rgba(255,255,255,.72);transition:.2s;cursor:default}
.tc:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.clbar{margin-top:1.6rem;padding:1rem 1.3rem;background:rgba(196,123,60,.14);border:1px solid rgba(196,123,60,.28);border-radius:.7rem;display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.cltag{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.01em;color:var(--accent);white-space:nowrap}
.clchips{display:flex;gap:.38rem;flex-wrap:wrap}
.clc{background:rgba(196,123,60,.18);border:1px solid rgba(196,123,60,.28);color:#E8C4A0;font-family:var(--sans);font-size:.58rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;padding:.22rem .65rem;border-radius:2rem}
.certs{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:2.25rem}
.cert{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:.8rem;padding:1rem;display:flex;align-items:flex-start;gap:.7rem}
.cico{width:30px;height:30px;border-radius:.45rem;background:rgba(196,123,60,.22);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.85rem}
.cname{font-family:var(--sans);font-size:.7rem;font-weight:600;color:rgba(255,255,255,.82);line-height:1.3;margin-bottom:.18rem}
.cby{font-size:.65rem;color:rgba(255,255,255,.38);font-weight:300}

/* THINKING */
#thinking{background:var(--white)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem;margin-top:.5rem}
.tcard{background:var(--bg);border:1px solid var(--border);border-radius:1rem;padding:1.65rem;transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.tcard:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(30,35,40,.08)}
.tcn{font-family:var(--serif);font-size:2.8rem;font-style:italic;color:var(--border);line-height:1;margin-bottom:.8rem;letter-spacing:-.03em}
.tctag{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.01em;color:var(--accent);margin-bottom:.45rem}
.tctit{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);line-height:1.3;margin-bottom:.65rem;letter-spacing:-.01em}
.tcb{font-size:.82rem;color:var(--ink2);font-weight:300;line-height:1.65;flex:1}
.tcr{margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border);font-family:var(--sans);font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}

/* CONTACT */
#contact{background:var(--panel);color:#fff;text-align:center;padding:8rem 3rem;position:relative;overflow:hidden}
.cglow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 110%,rgba(196,123,60,.22) 0%,transparent 55%)}
.abadge{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:2rem;padding:.42rem .9rem;font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.52);margin-bottom:2rem;position:relative}
.adot{width:7px;height:7px;border-radius:50%;background:#4ADE80;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}70%{box-shadow:0 0 0 8px rgba(74,222,128,0)}100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}}
.ch2{font-family:var(--serif);font-size:clamp(2.3rem,5vw,4.8rem);font-weight:400;font-style:italic;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.3rem;position:relative}
.csub{font-size:.93rem;color:rgba(255,255,255,.52);font-weight:300;max-width:44ch;margin:0 auto 2.5rem;line-height:1.72;position:relative}
.cbtns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;position:relative}
.cb{display:inline-flex;align-items:center;gap:.5rem;padding:.82rem 1.8rem;border-radius:3rem;font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:.2s}
.cb-a{background:var(--accent);color:#fff;border:1.5px solid var(--accent)}.cb-a:hover{background:transparent;color:var(--accent)}
.cb-g{background:transparent;color:rgba(255,255,255,.75);border:1.5px solid rgba(255,255,255,.18)}.cb-g:hover{border-color:rgba(255,255,255,.6);color:#fff}
footer{background:#0E1218;padding:1.3rem 3rem;display:flex;justify-content:space-between;align-items:center}
footer p{font-size:.73rem;color:rgba(255,255,255,.26);font-weight:300}
footer a{font-size:.73rem;color:rgba(255,255,255,.26);text-decoration:none;transition:color .2s}
footer a:hover{color:var(--accent)}

/* QUICK ACCESS RIBBON */
.qa-ribbon{position:relative;background:var(--panel);border-bottom:1px solid rgba(255,255,255,.1);padding:0 3rem;display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none}
.qa-ribbon::-webkit-scrollbar{display:none}
.qa-ribbon.show{}
.qa-ribbon-label{font-family:var(--sans);font-size:.55rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);padding:.65rem 1rem .65rem 0;white-space:nowrap;border-right:1px solid rgba(255,255,255,.1);margin-right:.5rem;flex-shrink:0}
.qa-btn{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55);padding:.65rem .9rem;white-space:nowrap;cursor:pointer;border:none;background:none;transition:color .15s,background .15s;border-right:1px solid rgba(255,255,255,.06);flex-shrink:0}
.qa-btn:hover{color:#fff;background:rgba(255,255,255,.06)}
.qa-btn.qa-active{color:var(--accent);background:rgba(196,123,60,.12)}
.qa-dot{width:5px;height:5px;border-radius:50%;display:inline-block;margin-right:.35rem;vertical-align:middle}

/* INTERACTIVE HERO NUMBERS COUNTER */
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.mc{animation:countUp .6s ease both}
.mc:nth-child(1){animation-delay:.1s}
.mc:nth-child(2){animation-delay:.25s}
.mc:nth-child(3){animation-delay:.4s}
.mc:nth-child(4){animation-delay:.55s}

/* HOVER LIFT ON CASE CARDS */
.cc{position:relative}
.cc::before{content:'';position:absolute;inset:0;border-radius:1rem;background:linear-gradient(135deg,rgba(196,123,60,.04),transparent);opacity:0;transition:opacity .3s;pointer-events:none;z-index:0}
.cc:hover::before{opacity:1}

/* JUMP BAR PILL HOVER */
.jump-btn{transition:background .15s,border-color .15s,color .15s,transform .1s}
.jump-btn:hover{transform:translateY(-1px)}

/* ACTIVE NAV INDICATOR */
.nav-links a.nav-current{color:var(--accent)!important}

/* SKILLS TOOL CHIP ANIMATION */
.tc{transition:background .2s,color .2s,border-color .2s,transform .1s}
.tc:hover{transform:translateY(-2px)}

/* THOUGHT CARD READ MORE ARROW */
.tcr{transition:color .2s}
.tcard:hover .tcr{color:var(--ink);letter-spacing:.12em}

/* SCROLL PROGRESS BAR */
.scroll-progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:2000;transition:width .1s linear;width:0%}

/* SCROLL ANIM */
.fu{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fu.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* HAMBURGER + MOBILE MENU */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;width:36px;height:36px}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;top:62px;right:1.25rem;width:200px;background:var(--nav-bg);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:.75rem;z-index:1100;display:flex;flex-direction:column;padding:.5rem;box-shadow:0 8px 32px rgba(0,0,0,.15);opacity:0;pointer-events:none;transform:translateY(-6px) scale(.97);transform-origin:top right;transition:opacity .2s,transform .2s}
nav{position:relative}
.mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.mobile-menu a{font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink2);text-decoration:none;padding:.65rem .85rem;border-radius:.45rem;transition:background .15s,color .15s}
.mobile-menu a:hover{color:var(--accent);background:rgba(196,123,60,.07)}
.mobile-menu-cta{background:var(--ink)!important;color:var(--bg)!important;border-radius:.45rem!important;text-align:center;margin-top:.25rem}
.mobile-menu-cta:hover{background:var(--accent)!important;color:#fff!important}
.mobile-menu-overlay{position:fixed;inset:0;z-index:1099;opacity:0;pointer-events:none}
.mobile-menu-overlay.open{pointer-events:auto}

/* RESPONSIVE */
@media(max-width:960px){
  nav{padding:1rem 1.5rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  #hero{grid-template-columns:1fr}
  .hero-left{padding:6rem 1.5rem 3rem}
  .hero-right{min-height:420px}
  .mc{padding:1.5rem 1rem}
  section{padding:4rem 1.5rem}
  #about{grid-template-columns:1fr;gap:2.25rem}
  .about-inner{grid-template-columns:1fr;gap:2.5rem}
  .sgrid{grid-template-columns:repeat(2,1fr)}
  .tgrid{grid-template-columns:1fr}
  .certs{grid-template-columns:repeat(2,1fr)}
  .cc.lg,.cc.sm,.cc.hf,.cc.th{grid-column:span 12}
  .mbox{border-radius:1rem 1rem 0 0;margin:0}
  .mmets{grid-template-columns:1fr 1fr}
  .agrid,.pgrid{grid-template-columns:1fr}
  .analytics-bar{grid-template-columns:1fr}
}

/* DARK MODE THEME TOGGLE */
.theme-toggle{background:none;border:1.5px solid var(--border);border-radius:2rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink2);transition:border-color .2s,color .2s,background .2s;flex-shrink:0}
.theme-toggle:hover{border-color:var(--ink);color:var(--ink)}
.theme-toggle svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.icon-moon{display:none}
html[data-theme="dark"] .icon-sun{display:none}
html[data-theme="dark"] .icon-moon{display:block}

/* DARK MODE OVERRIDES */
html[data-theme="dark"] body{transition:background .3s,color .3s}
html[data-theme="dark"] .bp{color:var(--bg)}
html[data-theme="dark"] .bp:hover{color:#fff}
html[data-theme="dark"] .mtab.act{background:var(--panel);border-color:var(--panel)}
html[data-theme="dark"] .jump-btn:hover{background:var(--panel);border-color:var(--panel)}
html[data-theme="dark"] .dep-link::after{background:var(--bg)}
html[data-theme="dark"] .sprint-board{background:#111520}
html[data-theme="dark"] .dep-diagram{background:var(--white)}
html[data-theme="dark"] footer{background:#090C10}
