:root{color-scheme:light;--paper: #f4f8ff;--paper-2: #eef8f6;--ink: #0d1b2f;--muted: #52657a;--panel: rgba(255, 255, 255, .82);--panel-solid: #ffffff;--line: rgba(13, 27, 47, .11);--blue: #1857d4;--cyan: #00a6c8;--green: #0e9f6e;--coral: #f45f4f;--violet: #5d4ee8;--gold: #c9962b;--navy: #10284c;--aqua: #10c7b4;--shadow: 0 14px 34px rgba(16, 40, 76, .1);--shadow-strong: 0 20px 52px rgba(16, 40, 76, .16);--radius: 14px;--max: 1200px;--font-display: "Fraunces", Georgia, ui-serif, serif;--font-body: "Manrope", Inter, ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;font-family:var(--font-body)}*{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--paper)}body{margin:0;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 16% 8%,rgba(24,87,212,.15),transparent 28rem),radial-gradient(circle at 86% 12%,rgba(16,199,180,.15),transparent 28rem),radial-gradient(circle at 72% 88%,rgba(201,150,43,.12),transparent 30rem),linear-gradient(135deg,#f7fbff,#eef8ff 38%,#f4fbf7 72%,#fffaf0);letter-spacing:0;overflow-x:hidden;isolation:isolate}body:before{content:none}body:after{content:none}.site-header,main,.site-footer,.skip-link{position:relative}main,.site-footer{z-index:1}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button,input,textarea{font:inherit}:focus-visible{outline:3px solid rgba(31,111,235,.28);outline-offset:4px}::selection{color:#fff;background:var(--blue)}.skip-link{position:fixed;top:1rem;left:1rem;z-index:100;transform:translateY(-150%);padding:.8rem 1rem;background:var(--blue);color:#fff;border-radius:var(--radius);font-weight:900}.skip-link:focus{transform:translateY(0)}.site-header{position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line);background:#f8fbfff5}.nav-shell{width:min(var(--max),calc(100% - 2rem));min-height:76px;margin:0 auto;display:flex;align-items:center;justify-content:flex-end;gap:1rem}.brand{display:inline-flex;align-items:center;gap:.85rem}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:16px;color:#fff;background:linear-gradient(135deg,var(--navy),var(--blue) 45%,var(--aqua));box-shadow:0 16px 36px #1857d43d;font-weight:950}.brand-mark span{color:#fff4a4}.brand strong,.brand small{display:block}.brand small{color:var(--muted);margin-top:.1rem;font-size:.8rem}.nav-links{display:flex;align-items:center;gap:.35rem}.nav-links a{color:var(--muted);padding:.72rem .95rem;border-radius:999px;font-family:var(--font-body);font-weight:500;font-size:.92rem;letter-spacing:-.01em;position:relative;transition:color .22s ease,background .22s ease,transform .22s ease}.nav-links a:hover{color:var(--ink);background:#1f6feb12;transform:translateY(-1px)}.nav-links a[aria-current=page],.nav-links a.is-active{color:var(--blue);font-weight:700;background:#1f6feb14}.menu-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-solid);color:var(--ink)}.menu-toggle span{display:block;width:18px;height:2px;margin:5px auto;background:currentColor}main>section{width:min(var(--max),calc(100% - 2rem));margin:0 auto;padding:6.5rem 0}.section-accent{position:relative;isolation:isolate;padding-inline:clamp(1rem,2vw,1.6rem);border:1px solid rgba(19,32,47,.07);border-radius:28px;background:radial-gradient(circle at 92% 8%,color-mix(in srgb,var(--accent, var(--blue)) 20%,transparent),transparent 19rem),radial-gradient(circle at 8% 88%,color-mix(in srgb,var(--accent-2, var(--cyan)) 15%,transparent),transparent 18rem),linear-gradient(135deg,#ffffffd6,color-mix(in srgb,var(--accent, var(--blue)) 8%,rgba(255,255,255,.82)));box-shadow:0 22px 70px #10284c12}.section-accent+.section-accent{margin-top:2rem}.section-accent:before{content:"";position:absolute;inset:1rem auto 1rem 0;width:5px;border-radius:999px;background:linear-gradient(var(--accent, var(--blue)),var(--accent-2, var(--cyan)))}.section-accent .eyebrow,.section-accent .capability-grid article>span,.section-accent .principles-grid article>span{color:var(--accent, var(--blue))}.section-accent .section-visual,.section-accent .project-card,.section-accent .capability-grid article,.section-accent .principles-grid article,.section-accent .faq-grid article,.section-accent .skill-category,.section-accent .social-card,.section-accent .preview-card,.section-accent .visual-item{border-color:color-mix(in srgb,var(--accent, var(--blue)) 24%,transparent)}.section-accent .section-visual{background:linear-gradient(135deg,color-mix(in srgb,var(--accent, var(--blue)) 16%,transparent),transparent 48%),color-mix(in srgb,var(--accent-2, var(--cyan)) 8%,rgba(255,255,255,.8))}.section-accent .section-visual figcaption{border-color:color-mix(in srgb,var(--accent, var(--blue)) 22%,transparent);color:var(--accent, var(--blue))}.section-accent-blue{--accent: var(--blue);--accent-2: var(--aqua)}.section-accent-green{--accent: var(--green);--accent-2: var(--cyan)}.section-accent-coral{--accent: var(--coral);--accent-2: var(--gold)}.section-accent-violet{--accent: var(--violet);--accent-2: var(--blue)}.section-accent-gold{--accent: var(--gold);--accent-2: var(--green)}.hero{min-height:calc(100vh - 76px);display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);align-items:center;gap:clamp(2rem,6vw,6rem)}.eyebrow{margin:0 0 1rem;color:var(--blue);text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;font-weight:600;font-family:var(--font-mono)}h1,h2,h3,p{margin-top:0}h1{max-width:940px;margin-bottom:1.35rem;font-size:clamp(2.55rem,5.9vw,5.8rem);line-height:.98;letter-spacing:0;font-family:var(--font-display);font-weight:750}h2{margin-bottom:1rem;font-size:clamp(1.7rem,3.1vw,3.25rem);line-height:1.06;letter-spacing:0;font-family:var(--font-display);font-weight:650}h3{font-size:1.12rem;letter-spacing:-.015em;font-family:var(--font-body);font-weight:700}p{color:var(--muted);line-height:1.72}.hero[data-reveal]{opacity:1;transform:none;transition:none}.hero h1,.page-hero h1{background:linear-gradient(135deg,var(--navy) 2%,var(--blue) 34%,var(--aqua) 64%,var(--gold) 96%);-webkit-background-clip:text;background-clip:text;color:var(--ink)}@supports ((-webkit-background-clip: text) or (background-clip: text)){.hero h1,.page-hero h1{color:transparent}}.hero-content>.hero-lead{animation:entrance 1s cubic-bezier(.16,1,.3,1) .42s both}.hero-content>.hero-actions{animation:entrance 1s cubic-bezier(.16,1,.3,1) .6s both}.hero-content>.logo-strip{animation:entrance 1s cubic-bezier(.16,1,.3,1) .78s both}.hero-showcase{animation:entrance-right 1.15s cubic-bezier(.16,1,.3,1) .18s both}.page-hero h1{animation:entrance .95s cubic-bezier(.16,1,.3,1) .06s both}.page-hero p:not(.eyebrow){animation:entrance .9s cubic-bezier(.16,1,.3,1) .26s both}.hero-lead{max-width:720px;font-size:clamp(1rem,1.35vw,1.16rem)}.hero-actions,.project-actions,.center-action{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}.center-action{justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:50px;padding:.86rem 1.4rem;border-radius:999px;border:1px solid var(--line);font-weight:700;font-family:var(--font-body);letter-spacing:-.01em;transition:transform .28s cubic-bezier(.16,1,.3,1),background .28s ease,border-color .28s ease,box-shadow .28s ease}.btn:hover{transform:translateY(-3px)}.btn-primary{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 42%,var(--aqua) 100%);background-size:200% 100%;background-position:0% 0%;box-shadow:0 18px 44px #1857d447;transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s ease,background-position .5s ease}.btn-primary:hover{box-shadow:0 28px 72px #10284c47;background-position:100% 0%}.btn-ghost{color:var(--ink);background:#ffffffbd}.btn-ghost:hover{background:#fff;border-color:#1f6feb4d;box-shadow:0 8px 28px #1f6feb1a}.btn-disabled{color:#5f6f81;background:#eef2f6;cursor:not-allowed}.btn-compact{min-width:74px;padding-inline:1.05rem}.btn-icon{width:50px;min-width:50px;padding:0}.btn-icon svg{width:22px;height:22px;fill:currentColor}.logo-strip{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:2rem}.logo-strip span{width:52px;height:52px;position:relative;display:grid;place-items:center;overflow:hidden;border:1px solid rgba(31,111,235,.14);border-radius:16px;background:linear-gradient(145deg,#fffffffa,#f6faffe6),#fff;box-shadow:0 14px 34px #1f4b741f;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.logo-strip span:hover{transform:translateY(-4px);border-color:#1f6feb57;box-shadow:0 22px 54px #1f4b742e}.logo-strip img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 8px 12px rgba(19,32,47,.1))}.logo-strip span:before,.skill-logo-grid article:before,.social-card:before{content:attr(data-logo);display:none;place-items:center;color:#fff;background:linear-gradient(135deg,var(--blue),var(--cyan));box-shadow:0 12px 28px #1f6feb38;font-family:var(--font-mono);font-weight:800;letter-spacing:.02em}.logo-strip .logo-missing img,.skill-logo-grid .logo-missing img,.social-card.logo-missing img{display:none}.logo-strip .logo-missing:before,.skill-logo-grid .logo-missing:before,.social-card.logo-missing:before{display:grid}.logo-strip .logo-missing:before{width:30px;height:30px;border-radius:10px;font-size:.72rem}.hero-showcase{position:relative;min-height:400px}.showcase-main{position:relative;overflow:hidden;padding:.85rem;border:1px solid var(--line);border-radius:28px;background:linear-gradient(135deg,rgba(24,87,212,.14),transparent 42%),#ffffffd1;box-shadow:var(--shadow-strong);transform:rotate(1.2deg)}.showcase-main:after,.project-media:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.56),transparent 42%);transform:translate(-120%);opacity:0;transition:opacity .2s ease,transform .65s ease}.showcase-main:hover:after,.project-card:hover .project-media:after{opacity:1;transform:translate(120%)}.showcase-main>img{width:100%;aspect-ratio:4 / 3;max-height:380px;border-radius:22px;object-fit:cover;filter:saturate(1.06) contrast(1.02)}.showcase-caption{position:absolute;left:1.6rem;right:1.6rem;bottom:1.6rem;padding:1rem;border:1px solid rgba(255,255,255,.7);border-radius:18px;background:#ffffffd6;box-shadow:var(--shadow)}.showcase-caption span,.showcase-caption strong,.floating-card span,.floating-card strong{display:block}.showcase-caption span,.floating-card span{color:var(--blue);font-size:.68rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.floating-card{position:absolute;min-width:190px;padding:1rem;border:1px solid var(--line);border-radius:20px;background:#ffffffdb;box-shadow:var(--shadow)}.card-a{top:5rem;left:-2rem}.card-b{right:-1.5rem;bottom:8rem;animation-delay:-2.8s}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding-top:0}.metrics-grid>div,.contact-card,.capability-grid article,.principles-grid article,.faq-grid article,.project-card,.portrait-card{border:1px solid var(--line);border-radius:24px;background:var(--panel);box-shadow:var(--shadow)}.metrics-grid>div{position:relative;overflow:hidden;padding:1.45rem}.metrics-grid>div:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:linear-gradient(var(--blue),var(--aqua),var(--green))}.metrics-grid strong{display:block;font-size:clamp(2.15rem,5vw,4rem);color:var(--navy);line-height:1}.metrics-grid span{color:var(--muted)}.split-section,.about-grid,.contact-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:2rem}.section-heading{max-width:820px;margin-bottom:2rem}.capability-grid,.principles-grid,.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.capability-grid article,.principles-grid article,.faq-grid article{position:relative;overflow:hidden;padding:1.4rem;transition:transform .22s ease,border-color .22s ease,background .22s ease}.capability-grid article:hover,.principles-grid article:hover,.faq-grid article:hover{transform:translateY(-5px);border-color:#1857d447;background:#fff;box-shadow:var(--shadow-strong)}.capability-grid span,.principles-grid span{display:inline-block;margin-bottom:2rem;color:var(--coral);font-family:var(--font-mono);font-weight:600;font-size:.78rem;letter-spacing:.06em}.featured-grid,.projects-list{display:grid;gap:1rem}.featured-grid{grid-template-columns:repeat(3,1fr)}.projects-list{grid-template-columns:repeat(2,1fr)}.project-card{overflow:hidden;transform:translateY(0);opacity:1;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.project-card.is-visible{opacity:1;transform:translateY(0)}.project-card:hover{border-color:#1857d447;box-shadow:var(--shadow-strong);transform:translateY(-6px)}.project-card[hidden]{display:none}.project-card.private .project-media{cursor:not-allowed}.project-card.private .project-media img{filter:saturate(.8) brightness(.94)}.project-media{position:relative;display:block;overflow:hidden;min-height:280px;background:#eaf2f8}.project-media img{width:100%;height:300px;object-fit:cover;transition:transform .22s ease}.project-card:hover .project-media img{transform:scale(1.025)}.media-tag{position:absolute;left:1rem;bottom:1rem;z-index:1;padding:.48rem .7rem;border-radius:999px;color:#fff;background:linear-gradient(135deg,var(--navy),var(--blue),var(--aqua));font-size:.72rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.02em}.lock-badge{font-family:var(--font-mono);position:absolute;top:1rem;right:1rem;z-index:2;padding:.48rem .7rem;border-radius:999px;color:#fff;background:linear-gradient(135deg,#26364a,#5b6675);font-size:.78rem;font-weight:950;box-shadow:0 16px 36px #13202f38}.project-body{padding:1.35rem;background:#ffffffad}.project-body p{font-size:.95rem}.project-meta,.stack-list{display:flex;flex-wrap:wrap;gap:.5rem}.project-meta{margin-bottom:1rem}.project-meta span{color:var(--muted);font-size:.82rem;font-weight:850}.status-dot:before{content:"";display:inline-block;width:.48rem;height:.48rem;margin-right:.45rem;border-radius:50%;background:var(--green);box-shadow:0 0 18px #13a86b73}.project-card h3{margin-bottom:.75rem;font-size:1.08rem;line-height:1.22;letter-spacing:-.02em;font-family:var(--font-display);font-weight:600}.impact{color:#304154}.stack-list span,.filter-shell button{border:1px solid rgba(24,87,212,.16);border-radius:999px;padding:.48rem .72rem;color:#173a67;background:linear-gradient(135deg,#1857d412,#10c7b40d);font-size:.78rem;font-weight:600;font-family:var(--font-mono);letter-spacing:0}.skills-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.skill-logo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:.75rem}.skill-logo-grid article{min-height:116px;position:relative;overflow:hidden;padding:.9rem;display:flex;flex-direction:column;justify-content:space-between;border:1px solid rgba(19,32,47,.09);border-radius:18px;background:linear-gradient(180deg,#fffffff0,#f8fbffd1),#ffffffc7;box-shadow:0 16px 38px #1f4b741a;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.skill-logo-grid article:after{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--blue),var(--cyan),var(--green));opacity:0;transition:opacity .22s ease}.skill-logo-grid article:hover{transform:translateY(-5px);border-color:#1f6feb42;background:#fff;box-shadow:0 26px 70px #1f4b7429}.skill-logo-grid article:hover:after{opacity:1}.skill-logo-grid img{width:42px;height:42px;object-fit:contain;padding:.22rem;border-radius:14px;background:#ffffffd1;box-shadow:0 10px 24px #13202f14}.skill-logo-grid article.logo-missing:before{width:42px;height:42px;border-radius:14px;font-size:.78rem;align-self:center;flex-shrink:0}.skill-logo-grid strong,.skill-logo-grid span{display:block}.skill-logo-grid strong{margin-top:1rem;font-size:.92rem;line-height:1.25}.skill-logo-grid span{color:var(--muted);font-size:.88rem}.skill-categories{display:grid;gap:1.35rem}.skill-category{width:100%;padding:0}.skill-category h3{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.95rem;color:#213a55;font-family:var(--font-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.skill-category h3:before{content:"";width:18px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--green))}.skill-initials{width:38px;height:38px;display:grid;place-items:center;border-radius:12px;color:#fff!important;background:linear-gradient(135deg,var(--blue),var(--green));font-size:.76rem!important;font-weight:950}.timeline{display:grid;gap:0;max-width:780px}.timeline-item{display:grid;grid-template-columns:28px 1fr;gap:1.5rem;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{display:flex;flex-direction:column;align-items:center;padding-top:.3rem}.timeline-dot{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--aqua));box-shadow:0 0 0 4px #1857d424;flex-shrink:0;z-index:1}.timeline-item.is-current .timeline-dot{width:16px;height:16px;box-shadow:0 0 0 5px #13a86b2e;background:linear-gradient(135deg,var(--green),var(--cyan))}.timeline-line{width:2px;flex:1;margin-top:.55rem;background:linear-gradient(to bottom,rgba(24,87,212,.24),transparent)}.timeline-content{padding:1.6rem;border:1px solid var(--line);border-radius:20px;background:var(--panel);box-shadow:var(--shadow);transition:border-color .22s ease,box-shadow .22s ease,transform .22s ease}.timeline-content:hover{border-color:#1857d43d;box-shadow:var(--shadow-strong);transform:translate(4px)}.timeline-item.is-current .timeline-content{border-color:#13a86b38;background:linear-gradient(135deg,rgba(19,168,107,.04),var(--panel))}.timeline-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.65rem;flex-wrap:wrap}.timeline-date{color:var(--blue);font-size:.72rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.timeline-badge{padding:.22rem .7rem;border-radius:999px;font-size:.68rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em}.timeline-badge.current{background:#13a86b1f;color:var(--green);border:1px solid rgba(19,168,107,.22)}.timeline-role{font-size:1.1rem;font-weight:900;color:var(--ink);margin:0 0 .3rem;line-height:1.3}.timeline-org{color:var(--muted);font-size:.9rem;font-weight:700;margin:0 0 .9rem}.timeline-desc{font-size:.95rem;color:var(--muted);line-height:1.65;margin:0 0 1rem}.timeline-stack{display:flex;flex-wrap:wrap;gap:.4rem}.timeline-stack span{padding:.3rem .72rem;border-radius:999px;background:linear-gradient(135deg,#1857d414,#10c7b40f);border:1px solid rgba(24,87,212,.15);color:#173a67;font-family:var(--font-mono);font-size:.72rem;font-weight:850}.cta-section{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:3rem;margin-bottom:5rem;border:1px solid rgba(24,87,212,.18);border-radius:28px;background:radial-gradient(circle at 88% 18%,rgba(16,199,180,.16),transparent 18rem),radial-gradient(circle at 8% 86%,rgba(201,150,43,.12),transparent 16rem),linear-gradient(135deg,#ffffffeb,#ebf6ffd6);box-shadow:var(--shadow-strong)}.page-hero{padding-bottom:3rem}.page-hero-media{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,.45fr);align-items:center;gap:clamp(2rem,5vw,4rem)}.page-hero h1{font-size:clamp(2.25rem,5.4vw,4.9rem)}.page-hero p:not(.eyebrow){max-width:820px;font-size:1.16rem}.section-visual{position:relative;overflow:hidden;margin:0;padding:.85rem;border:1px solid var(--line);border-radius:28px;background:linear-gradient(135deg,rgba(24,87,212,.12),transparent 42%),#ffffffd1;box-shadow:var(--shadow-strong)}.section-visual>img{width:100%;aspect-ratio:16 / 9;max-height:280px;border-radius:22px;object-fit:cover}.section-visual figcaption{position:absolute;left:1.4rem;right:1.4rem;bottom:1.4rem;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.7);border-radius:18px;color:var(--ink);background:#ffffffd6;box-shadow:var(--shadow);font-weight:800}.filter-shell{display:flex;flex-wrap:wrap;gap:.7rem;padding:0 0 2rem}.filter-shell button{cursor:pointer}.filter-shell button:hover,.filter-shell button.is-active{color:#fff;background:linear-gradient(135deg,var(--navy),var(--blue),var(--aqua));border-color:transparent}.empty-state{margin-top:1.5rem;padding:1rem;border:1px solid var(--line);border-radius:var(--radius);background:#fff}.empty-state[hidden]{display:none}.portrait-card{overflow:hidden;align-self:start}.portrait-card img{width:100%;aspect-ratio:4 / 5;object-fit:cover}.portrait-card div,.contact-card{padding:1.3rem}.portrait-card strong,.portrait-card span,.info-list dt,.info-list dd,.site-footer a{display:block}.portrait-card span,.info-list dt{color:var(--muted)}.about-copy p{font-size:1.08rem}.info-list{display:grid;gap:.8rem;margin:2rem 0 0}.info-list div{display:grid;grid-template-columns:130px 1fr;gap:1rem;padding:.9rem 0;border-top:1px solid var(--line)}.primary-contact{background:radial-gradient(circle at 90% 0%,rgba(16,199,180,.16),transparent 18rem),#ffffffd1}.contact-card a:not(.btn){display:block;padding:.9rem 0;color:var(--ink);border-top:1px solid var(--line)}.social-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-top:1.5rem}.social-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;padding:2rem 1rem 1.6rem;overflow:hidden;border:1px solid color-mix(in srgb,var(--brand, var(--blue)) 20%,transparent);border-radius:20px;background:linear-gradient(180deg,color-mix(in srgb,var(--brand, var(--blue)) 7%,rgba(255,255,255,.92)),#ffffffdb),var(--panel);box-shadow:0 18px 48px #1f4b741f;text-align:center;color:var(--ink);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.social-card:hover{transform:translateY(-6px);box-shadow:0 30px 78px color-mix(in srgb,var(--brand, var(--blue)) 18%,rgba(31,75,116,.16));border-color:color-mix(in srgb,var(--brand, var(--blue)) 38%,transparent);background:#fff}.social-card img,.social-card svg{width:54px;height:54px;object-fit:contain;flex-shrink:0;padding:.35rem;border-radius:16px;background:#fff;box-shadow:0 12px 30px color-mix(in srgb,var(--brand, var(--blue)) 18%,rgba(19,32,47,.08))}.social-card.logo-missing:before{width:48px;height:48px;border-radius:16px;font-size:.85rem;flex-shrink:0}.social-card strong{display:block;font-size:1rem;color:var(--ink)}.social-card small{display:block;color:var(--muted);font-size:.8rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-footer{border-top:1px solid var(--line);background:#ffffffa8}.footer-minimal{width:min(var(--max),calc(100% - 2rem));margin:0 auto;padding:2rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.footer-links{display:flex;flex-wrap:wrap;gap:.55rem}.footer-links a{color:var(--muted);padding:.55rem .75rem;border:1px solid var(--line);border-radius:999px;background:#ffffff9e;font-weight:800}.footer-links a:hover{color:var(--blue);background:#fff}.footer-bottom{width:min(var(--max),calc(100% - 2rem));margin:0 auto;padding:1rem 0 1.4rem;border-top:1px solid var(--line);font-size:.9rem}[data-reveal]{opacity:1;transform:translateY(0);transition:none}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@keyframes entrance{0%{opacity:0;transform:translateY(2.2rem)}to{opacity:1;transform:translateY(0)}}@keyframes entrance-right{0%{opacity:0;transform:translate(3rem) translateY(1rem)}to{opacity:1;transform:translate(0) translateY(0)}}@media(max-width:980px){.hero,.split-section,.about-grid,.contact-grid,.page-hero-media{grid-template-columns:1fr}.featured-grid,.projects-list,.capability-grid,.principles-grid,.faq-grid,.skill-logo-grid{grid-template-columns:1fr 1fr}.hero{padding-top:3rem}.hero-showcase{min-height:auto;max-width:520px;margin:0 auto}.showcase-main>img{aspect-ratio:4 / 3}.section-visual{max-width:620px}main>section{padding:4rem 0}}@media(max-width:720px){.menu-toggle{display:block}.nav-links{position:absolute;top:76px;left:1rem;right:1rem;display:none;padding:.6rem;border:1px solid var(--line);border-radius:var(--radius);background:#fffcf6fa;box-shadow:var(--shadow)}.nav-links.is-open{display:grid}main>section{width:min(100% - 1.1rem,var(--max));padding:2.5rem 0}.hero,.page-hero-media,.featured-grid,.projects-list,.capability-grid,.principles-grid,.faq-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}.metrics-grid>div{padding:1rem .85rem}.metrics-grid strong{font-size:clamp(1.6rem,7vw,2.4rem)}.skill-logo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.skill-logo-grid article{min-height:108px;padding:.75rem}h1{font-size:clamp(2.15rem,11vw,3.2rem);line-height:1.02}h2{font-size:clamp(1.45rem,7.5vw,2.2rem)}p{font-size:.95rem}.brand small{display:none}.hero{min-height:auto;gap:1.5rem}.floating-card{display:none}.showcase-main{transform:none;max-width:420px;margin:0 auto}.showcase-main>img{aspect-ratio:4 / 3}.showcase-caption{position:static;margin-top:.75rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.hero-actions .btn{flex:1;min-width:130px;width:auto}.project-actions{display:grid;grid-template-columns:1fr}.project-actions .btn,.cta-section .btn,.center-action .btn{width:100%}.project-media,.project-media img{min-height:0;height:auto}.project-media img{aspect-ratio:16 / 9}.project-body,.contact-card,.portrait-card div{padding:1rem}.cta-section{align-items:flex-start;flex-direction:column;padding:1.3rem}.info-list div{grid-template-columns:1fr;gap:.25rem}.footer-minimal{align-items:flex-start;flex-direction:column;padding:1.5rem 0}.footer-links{width:100%}.footer-links a{flex:1;text-align:center}.social-grid{grid-template-columns:repeat(2,1fr)}.timeline-item{grid-template-columns:20px 1fr;gap:1rem;padding-bottom:1.75rem}.timeline-content{padding:1.2rem}.timeline-content:hover{transform:none}.social-card{padding:1.5rem .75rem 1.2rem}.social-card img,.social-card svg{width:40px;height:40px}.social-card small{font-size:.75rem}.logo-strip{gap:.5rem}.logo-strip span{width:44px;height:44px;border-radius:14px}.logo-strip img{width:24px;height:24px}}@media(max-width:480px){.metrics-grid,.social-grid{grid-template-columns:repeat(2,1fr)}.skill-logo-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}.nav-shell{min-height:64px}.brand-mark{width:38px;height:38px;border-radius:12px}main>section{padding:2rem 0}}.preview-grid{display:grid;grid-template-columns:1.65fr 1fr;grid-template-rows:1fr 1fr;gap:1.25rem;margin-top:2.5rem}.preview-card{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:var(--panel)}.preview-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}.preview-card:hover img{transform:scale(1.04)}.preview-card figcaption{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.25rem;background:linear-gradient(transparent,#0a1018d9);color:#fff;display:flex;flex-direction:column;gap:.15rem;transform:translateY(110%);transition:transform .32s ease}.preview-card:hover figcaption{transform:translateY(0)}.preview-card figcaption strong{font-size:.95rem;font-weight:600;letter-spacing:-.01em}.preview-card figcaption span{font-size:.78rem;opacity:.75}.preview-main{grid-row:1 / 3;min-height:360px}.preview-card:not(.preview-main){min-height:168px}.visuals-strip{padding:.5rem 0 3rem}.visuals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}.visual-item{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);position:relative}.visual-item img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block;transition:transform .4s ease}.visual-item:hover img{transform:scale(1.05)}.visual-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem;background:linear-gradient(transparent,#0a1018c7);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;opacity:0;transition:opacity .28s ease}.visual-item:hover figcaption{opacity:1}@media(max-width:720px){.preview-grid{grid-template-columns:1fr;grid-template-rows:auto}.preview-main{grid-row:auto;min-height:220px}.preview-card:not(.preview-main){min-height:140px}.visuals-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.visuals-grid{grid-template-columns:repeat(2,1fr);gap:.65rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
