.header{display:grid;gap:.75rem;padding:1.25rem}.header-name{font-size:1.6rem;font-weight:700;letter-spacing:-.01em;color:#0f172a}.header-role{font-size:.95rem;font-weight:500;color:#2563eb}.hero-subtitle{max-width:65ch;font-size:1.05rem;line-height:1.7;color:#334155}.brand{display:grid;grid-template-columns:64px 1fr;gap:.75rem;align-items:center}.brand__logo{width:64px;height:64px;object-fit:contain}.brand__name{margin:0;font-size:1.75rem;line-height:1.2}.brand__role{margin:0;color:#64748b;font-weight:500}.brand__tagline{margin:0;color:#334155}.themeBtn{border:1px solid var(--border);background:#0f172a0a;color:var(--text);padding:.45rem .7rem;border-radius:999px;font-weight:650}:root[data-theme=dark] .themeBtn{background:#ffffff0f}.brand__avatar{width:64px;height:64px;border-radius:50%;object-fit:cover}@media(min-width:768px){.profile-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;object-position:center 20%;display:block}}.project-card{border:1px solid var(--border);border-radius:18px;background:#fff;padding:1rem;box-shadow:var(--shadow, 0 18px 50px rgba(0, 0, 0, .18));transition:transform .15s ease,box-shadow .15s ease}.project-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px #0f172a1f}.project-card__title{margin:0 0 .25rem;font-size:1.1rem;font-weight:700}.project-card__desc{margin:0 0 .75rem;color:#475569}.project-card__tech{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0 .75rem;padding:0;list-style:none}.project-card__chip{background:#f1f5f9;display:inline-flex;align-items:center;gap:.35rem}.project-card__chip-text{color:#0f172a;font-size:.8rem;font-weight:600}.project-card__actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .9rem;border-radius:10px;font-weight:600;text-decoration:none;border:1px solid transparent;transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .12s ease,box-shadow .18s ease}.btn--primary{background:#2563eb;color:#fff;border-color:#1e4fd6}.btn--primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 8px 18px #2563eb40}.btn--primary:active{transform:translateY(0);box-shadow:0 3px 10px #2563eb40}.btn--secondary{background:#f8fafc;color:#0f172a;border-color:#e2e8f0}.btn--secondary:hover{background:#eef2f7;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 8px 18px #0206171a}.btn--secondary:active{transform:translateY(0);box-shadow:0 3px 10px #0206171a}.btn:focus-visible{outline:3px solid rgba(99,102,241,.55);outline-offset:3px}@media(prefers-reduced-motion:reduce){.btn,.project-card{transition:none}}body.dark{background:#020617;color:#e5e7eb}body.dark .project-card{background:#020617;border-color:#1e293b}.dark .project-card{background:#0b1220;border-color:#1f2937}.dark .project-card__desc{color:#cbd5e1}.dark .project-card__chip{background:#111827}.dark .project-card__chip-text{color:#e5e7eb}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.project-card{border:1px solid var(--border);border-radius:16px;background:#ffffff0f;padding:1rem;box-shadow:var(--shadow, 0 18px 50px rgba(0, 0, 0, .18));transition:transform .15s ease,box-shadow .15s ease}.project-card__thumb{aspect-ratio:16 / 9;width:100%;object-fit:cover;background:#f1f5f9}.project-card__body{padding:.75rem 1rem}.project-card__title{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.project-card__desc{margin:0 0 .5rem}.project-card__meta{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0}.project-card__chip{font-size:.75rem;padding:.25rem .5rem;border-radius:999px;background:#f1f5f9}.tech-chip{font-size:.8rem;font-weight:600}.project-card__actions{display:flex;gap:.75rem}.project-card__link{color:#2563eb;text-decoration:none;font-weight:600}.project-card__link:hover{text-decoration:underline}:root{--bg: #0b1220;--card: rgba(255, 255, 255, .06);--card-2: rgba(255, 255, 255, .04);--text: rgba(255, 255, 255, .9);--muted: rgba(255, 255, 255, .65);--border: rgba(255, 255, 255, .1);--shadow: 0 18px 50px rgba(0, 0, 0, .35);--radius: 18px}.about{padding:clamp(3rem,5vw,5rem) 1rem;background:radial-gradient(900px 600px at 10% 10%,rgba(99,102,241,.22),transparent 55%),radial-gradient(900px 600px at 90% 20%,rgba(34,211,238,.18),transparent 55%),radial-gradient(900px 600px at 50% 100%,rgba(244,114,182,.1),transparent 60%),var(--bg);color:var(--text)}.about__container{max-width:1100px;margin:0 auto}.about__header{margin-bottom:1.5rem;text-align:left}.about__eyebrow{margin:0 0 .4rem;font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#0f172a8c}.about[data-theme=dark] .about__eyebrow{color:#ffffff8c}.about__title{margin:0;font-size:clamp(1.8rem,3vw,2.4rem);line-height:1.15}.about__subtitle{margin:.75rem 0 0;max-width:68ch;font-size:1.1rem;line-height:1.7;font-weight:400;color:#0f172abf}.about[data-theme=dark] .about__subtitle{color:#ffffffb8}.about__grid{display:grid;gap:1rem;grid-template-columns:1.25fr .85fr;align-items:start}@media(max-width:900px){.about__grid{grid-template-columns:1fr}.stack__label{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;letter-spacing:.02em;color:#0f172af2}.about[data-theme=dark] .stack__label{color:#ffffffe6}}.card{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(180deg,var(--card),var(--card-2));box-shadow:var(--shadow);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:clamp(1.1rem,2.2vw,1.6rem)}.card--main{position:relative;overflow:hidden}.card--main:before{content:"";position:absolute;inset:-2px;background:radial-gradient(700px 200px at 20% 0%,rgba(34,211,238,.22),transparent 55%);pointer-events:none;opacity:.9}.card--main>*{position:relative;z-index:1}.card__top{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.badge{font-size:.85rem;padding:.35rem .6rem;border-radius:999px;border:1px solid var(--border);color:#ffffffd9;background:#0000002e}.badge--muted{color:var(--muted)}.card__text2{margin:.75rem 0 0;font-size:1.02rem;line-height:1.75}.card__text2 strong{font-weight:650}.card__title{margin:0 0 1rem;font-size:1.15rem;letter-spacing:.01em}.stack{display:grid;gap:.9rem}.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none}.chip{border:1px solid var(--border);background:#0000002e;color:#ffffffd1;padding:.45rem .6rem;border-radius:999px;font-size:.92rem;line-height:1;white-space:nowrap}.cta{display:flex;gap:.65rem;margin-top:1.2rem;flex-wrap:wrap}.button{display:inline-flex;align-items:center;justify-content:center;padding:.65rem .9rem;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#6366f138;color:#ffffffeb;text-decoration:none;font-weight:600;transition:transform .16s ease,background .16s ease,border-color .16s ease}.button:hover{transform:translateY(-1px);background:#6366f147;border-color:#ffffff38}.button--ghost{background:#0000002e;color:#ffffffdb}.button--ghost:hover{background:#ffffff14}.project-card__chip{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .65rem;border-radius:999px;font-size:.9rem;line-height:1;white-space:nowrap;background:#22d3ee33;border:1px solid rgba(34,211,238,.45);color:#0f172a;font-weight:600;-webkit-backdrop-filter:none;backdrop-filter:none}.project-card__chip-text{color:#0f172a}.cs{padding:clamp(2.5rem,5vw,4rem) 1rem;background:radial-gradient(800px 420px at 20% 0%,rgba(37,99,235,.14),transparent 60%),radial-gradient(700px 380px at 80% 10%,rgba(34,211,238,.12),transparent 55%),var(--bg);color:var(--text)}.cs__inner{max-width:1100px;margin:0 auto}.cs__header{margin-bottom:1.25rem}.cs__eyebrow{margin:0 0 .35rem;font-size:.75rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.cs__title{margin:0;font-size:clamp(1.7rem,3vw,2.3rem);line-height:1.15;letter-spacing:-.02em}.cs__subtitle{margin:.75rem 0 0;max-width:72ch;font-size:1.05rem;line-height:1.7;color:var(--muted)}.cs__topRow{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-top:1rem;flex-wrap:wrap}.cs__stack{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none}.cs__chip{display:inline-flex;align-items:center;padding:.45rem .65rem;border-radius:999px;border:1px solid var(--border);background:#22d3ee24;color:var(--text);font-weight:650;font-size:.88rem;white-space:nowrap}.cs__chip--soft{background:#2563eb1a}.cs__links{display:flex;gap:.5rem;flex-wrap:wrap}.cs__link{border:1px solid var(--border);background:#ffffff0f;color:var(--text);text-decoration:none;padding:.5rem .7rem;border-radius:12px;font-weight:650;transition:transform .16s ease,background .16s ease}.cs__link:hover{transform:translateY(-1px);background:#ffffff1a}.cs__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:1rem}.cs__stat{border:1px solid var(--border);border-radius:16px;background:#ffffff0f;padding:.8rem .9rem}.cs__statValue{font-size:1.15rem;font-weight:750}.cs__statLabel{margin-top:.2rem;color:var(--muted);font-size:.9rem;font-weight:600}.cs__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;align-items:start}@media(max-width:980px){.cs__grid{grid-template-columns:1fr}}.cs__right{display:grid;gap:1rem}.cs__card{border:1px solid var(--border);border-radius:18px;background:#ffffff0f;box-shadow:var(--shadow, 0 18px 50px rgba(0,0,0,.18));padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cs__cardHeader{margin-bottom:.75rem}.cs__cardTitle{margin:0;font-size:1.05rem;letter-spacing:-.01em}.cs__cardHint{margin:.35rem 0 0;font-size:.92rem;color:var(--muted)}.cs__viewer{border-radius:16px;border:1px solid var(--border);background:#0000001a;overflow:hidden}.cs__viewerImg{width:100%;height:auto;display:block}.cs__thumbs{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.cs__thumb{border:1px solid var(--border);background:#ffffff0f;border-radius:12px;padding:4px;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease}.cs__thumb:hover{transform:translateY(-1px);background:#ffffff1a}.cs__thumb.is-active{border-color:#22d3ee8c}.cs__thumb img{width:92px;height:56px;object-fit:cover;display:block;border-radius:10px}.cs__figure{margin:0}.cs__figureImg{width:100%;height:auto;display:block;border-radius:16px;border:1px solid var(--border);background:#0000001a}.cs__figcap{margin-top:.5rem;color:var(--muted);font-size:.92rem}.cs__acc{border-top:1px solid var(--border);padding-top:.75rem;margin-top:.75rem}.cs__acc__btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:.75rem;background:transparent;border:0;color:var(--text);padding:.25rem 0;cursor:pointer;font-weight:750;font-size:.95rem}.cs__acc__chev{transition:transform .16s ease;opacity:.7}.cs__acc__chev.is-open{transform:rotate(180deg)}.cs__acc__panel{margin-top:.65rem;color:var(--muted)}.cs__bullets{margin:0;padding-left:1.1rem}.cs__bullet{margin:.35rem 0}.cs__chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none}.cs__code{margin:0;padding:.85rem;border-radius:14px;border:1px solid var(--border);background:#00000024;overflow:auto;color:var(--text);font-size:.9rem;line-height:1.5}.cs__list{margin:0;padding-left:1.1rem}.cs__empty{border:1px dashed var(--border);border-radius:14px;padding:.9rem;color:var(--muted);background:#ffffff0a}.case-study{max-width:1200px;margin:auto;padding:4rem 1.5rem}.cs-section{margin-bottom:4rem}.cs-section h3{font-size:1.6rem;font-weight:700;margin-bottom:.5rem}.cs-description{color:#64748b;max-width:700px;margin-bottom:1.5rem}.cs-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.cs-gallery img{width:100%;border-radius:12px;border:1px solid #e5e7eb;background:#fff;transition:transform .25s ease,box-shadow .25s ease;cursor:pointer}.cs-gallery img:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 20px 40px #00000014}.arch{max-width:1100px;margin:0 auto;padding:28px 16px 12px}.arch__header{display:flex;gap:18px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.arch__title{margin:0;font-size:1.6rem;letter-spacing:-.02em;color:var(--text)}.arch__lead{margin:.5rem 0 0;max-width:70ch;color:var(--muted);line-height:1.6}.arch__badges{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.badge{display:inline-flex;align-items:center;padding:.38rem .6rem;border-radius:999px;border:1px solid var(--border);font-weight:700;font-size:.82rem;color:var(--text);background:#0f172a08}:root[data-theme=dark] .badge{background:#ffffff0f}.badge--blue{background:#2563eb1a;border-color:#2563eb40}.badge--cyan{background:#22d3ee1a;border-color:#22d3ee38}.badge--green{background:#22c55e1a;border-color:#22c55e38}.badge--slate{background:#64748b1a;border-color:#64748b38}.badge--violet{background:#8b5cf61a;border-color:#8b5cf638}.arch__overview{margin-top:16px;display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:start}@media(max-width:900px){.arch__overview{grid-template-columns:1fr}}.arch__diagram{border:1px solid var(--border);border-radius:16px;padding:14px;background:radial-gradient(700px 220px at 10% 0%,rgba(37,99,235,.12),transparent 55%),radial-gradient(700px 220px at 90% 20%,rgba(34,211,238,.1),transparent 55%),#ffffff8c;box-shadow:0 10px 30px #0f172a14}:root[data-theme=dark] .arch__diagram{background:radial-gradient(700px 220px at 10% 0%,rgba(96,165,250,.14),transparent 55%),radial-gradient(700px 220px at 90% 20%,rgba(34,211,238,.12),transparent 55%),#ffffff0d;box-shadow:0 18px 55px #00000059}.diagram__row{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin:10px 0}.diagram__row--services{margin-top:14px}.diagram__row--db{margin-top:12px;opacity:.95}.node{display:inline-flex;align-items:center;justify-content:center;padding:.55rem .75rem;border-radius:14px;border:1px solid var(--border);font-weight:800;font-size:.92rem;color:var(--text);background:#ffffffa6;min-width:160px;text-align:center}:root[data-theme=dark] .node{background:#ffffff0f}.node--ui{border-color:#22d3ee59}.node--gw{border-color:#2563eb59}.node--svc{border-color:#8b5cf647;min-width:150px}.node--db{border-color:#22c55e47;min-width:120px}.arrow{font-weight:900;opacity:.6}.arch__highlights{margin:0;padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#ffffff8c;color:var(--text);line-height:1.6}:root[data-theme=dark] .arch__highlights{background:#ffffff0d}.arch__highlights li{margin:.4rem 0;color:var(--muted)}.arch__highlights strong{color:var(--text)}.arch__grid{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media(max-width:900px){.arch__grid{grid-template-columns:1fr}}.archCard{border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff9;box-shadow:0 10px 30px #0f172a0f}:root[data-theme=dark] .archCard{background:#ffffff0d;box-shadow:0 18px 55px #0000004d}.archCard__top{display:flex;align-items:center;justify-content:space-between;gap:10px}.archCard__title{margin:0;font-size:1.05rem;letter-spacing:-.01em;color:var(--text)}.archCard__desc{margin:.55rem 0 0;color:var(--muted);line-height:1.55}.archCard__list{list-style:none;padding:0;margin:.75rem 0 0;display:grid;gap:.45rem;color:var(--muted)}.dot{width:9px;height:9px;border-radius:99px;display:inline-block;margin-right:.55rem;translate:0 -1px}.dot--clean{background:#8b5cf6cc}.dot--infra{background:#22c55ecc}.dot--api{background:#2563ebcc}.dot--bll{background:#22d3eecc}.dot--db{background:#22c55ecc}.dot--gw{background:#f59e0be6}.pill{display:inline-flex;align-items:center;padding:.28rem .55rem;border-radius:999px;border:1px solid var(--border);font-size:.78rem;font-weight:800;color:var(--text);background:#0f172a08;white-space:nowrap}:root[data-theme=dark] .pill{background:#ffffff0f}.pill--clean{border-color:#8b5cf659}.pill--minimal{border-color:#22d3ee59}.pill--layered{border-color:#64748b59}.pill--gateway{border-color:#f59e0b59}.archCard__stack{margin-top:10px;display:flex;gap:.45rem;flex-wrap:wrap}.mini{display:inline-flex;padding:.28rem .5rem;border-radius:999px;border:1px solid var(--border);font-size:.78rem;font-weight:750;color:var(--text);background:#fff9}:root[data-theme=dark] .mini{background:#ffffff0f}:root{--cs-bg: #f7f8fb;--cs-surface: rgba(255,255,255,.78);--cs-surface-solid: #ffffff;--cs-border: rgba(15, 23, 42, .1);--cs-text: #0f172a;--cs-muted: rgba(15,23,42,.68);--cs-accent: #2563eb;--cs-accent-2: #06b6d4;--cs-ring: rgba(37, 99, 235, .28);--cs-shadow: 0 12px 35px rgba(15, 23, 42, .1);--cs-shadow-sm: 0 10px 24px rgba(15, 23, 42, .08);--cs-radius: 18px;--cs-max: 1100px;--cs-pad: clamp(16px, 2.8vw, 28px)}.dark,[data-theme=dark]{--cs-bg: #070a12;--cs-surface: rgba(17, 24, 39, .65);--cs-surface-solid: #0b1220;--cs-border: rgba(148, 163, 184, .18);--cs-text: #e5e7eb;--cs-muted: rgba(229, 231, 235, .68);--cs-accent: #60a5fa;--cs-accent-2: #22d3ee;--cs-ring: rgba(96, 165, 250, .3);--cs-shadow: 0 16px 45px rgba(0,0,0,.45);--cs-shadow-sm: 0 12px 28px rgba(0,0,0,.35)}.cs{min-height:100vh;color:var(--cs-text);background:radial-gradient(900px 480px at 15% 10%,rgba(37,99,235,.18),transparent 60%),radial-gradient(900px 480px at 80% 0%,rgba(6,182,212,.16),transparent 55%),radial-gradient(900px 520px at 70% 65%,rgba(124,58,237,.1),transparent 60%),var(--cs-bg);padding:clamp(22px,3.2vw,40px) 0}.cs a{color:inherit;text-decoration:none}.cs strong{font-weight:700}.cs-hero,.cs-section,.cs-footer{width:min(var(--cs-max),calc(100% - (var(--cs-pad) * 2)));margin:0 auto}.cs-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(16px,3vw,28px);align-items:stretch;padding:var(--cs-pad);border:1px solid var(--cs-border);border-radius:calc(var(--cs-radius) + 6px);background:linear-gradient(180deg,var(--cs-surface),rgba(255,255,255,.5));box-shadow:var(--cs-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cs-hero__inner{display:flex;flex-direction:column;justify-content:center;gap:14px;min-width:0}.cs-badges{display:flex;flex-wrap:wrap;gap:10px}.cs-badge{font-size:12px;font-weight:700;letter-spacing:.02em;padding:8px 10px;border-radius:999px;border:1px solid var(--cs-border);background:#ffffff8c}.dark .cs-badge,[data-theme=dark] .cs-badge{background:#0b1220b3}.cs-h1{font-size:clamp(26px,3.4vw,40px);line-height:1.12;letter-spacing:-.02em;margin:4px 0 0}.cs-lead{font-size:clamp(15px,1.35vw,17px);line-height:1.65;color:var(--cs-muted);margin:0;max-width:62ch}.cs-ctaRow{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.cs-hero__media{border-radius:var(--cs-radius);overflow:hidden;border:1px solid var(--cs-border);background:var(--cs-surface-solid);box-shadow:var(--cs-shadow-sm)}.cs-hero__img{width:100%;height:100%;display:block;object-fit:cover}.cs-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--cs-border);background:#fff9;font-weight:700;font-size:14px;transition:transform .12s ease,background .12s ease,box-shadow .12s ease,border-color .12s ease}.dark .cs-btn,[data-theme=dark] .cs-btn{background:#0b1220b3}.cs-btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px #0f172a1a;border-color:#2563eb4d}.cs-btn--primary{background:linear-gradient(135deg,var(--cs-accent),var(--cs-accent-2));border-color:#ffffff1a;color:#fff;box-shadow:0 14px 26px #2563eb38}.cs-btn--primary:hover{box-shadow:0 18px 34px #2563eb47}.cs-section{margin-top:clamp(18px,3vw,28px);padding:var(--cs-pad);border:1px solid var(--cs-border);border-radius:calc(var(--cs-radius) + 2px);background:linear-gradient(180deg,var(--cs-surface),rgba(255,255,255,.5));box-shadow:var(--cs-shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cs-section__head{margin-bottom:14px}.cs-h2{font-size:clamp(18px,2vw,24px);letter-spacing:-.01em;margin:0 0 8px}.cs-h3{font-size:16px;margin:0 0 10px}.cs-muted{color:var(--cs-muted);line-height:1.65;margin:0}.cs-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}.cs-card{padding:14px 14px 12px;border-radius:16px;border:1px solid var(--cs-border);background:#ffffffa8}.dark .cs-card,[data-theme=dark] .cs-card{background:#0b1220b3}.cs-list{margin:0;padding-left:18px;color:var(--cs-muted);line-height:1.65}.cs-list li{margin:6px 0}.cs-callout{margin-top:14px;padding:14px;border-radius:16px;border:1px solid rgba(37,99,235,.25);background:#2563eb14;line-height:1.65}.cs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}.cs-shot{border-radius:16px;overflow:hidden;border:1px solid var(--cs-border);background:var(--cs-surface-solid);box-shadow:0 10px 18px #0f172a14}.cs-shot__img{width:100%;display:block;aspect-ratio:16 / 9;object-fit:cover;background:#94a3b81a}.cs-shot__cap{padding:10px 12px 12px;font-size:13px;line-height:1.45;color:var(--cs-muted);border-top:1px solid var(--cs-border)}.cs-footer{margin-top:clamp(18px,3vw,28px);padding:var(--cs-pad);border-radius:calc(var(--cs-radius) + 2px);border:1px solid var(--cs-border);background:linear-gradient(135deg,#2563eb1a,#06b6d414)}.cs-footer__inner{display:grid;gap:10px}@media(max-width:900px){.cs-hero,.cs-cards,.cs-grid{grid-template-columns:1fr}}.cs{padding:24px 16px 64px;max-width:1100px;margin:0 auto}.cs__hero{position:relative;border-radius:22px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:linear-gradient(135deg,#0949a11a,#00bcd41a);box-shadow:0 18px 60px #0000001a}.cs__heroInner{position:relative;padding:34px 26px;z-index:1}.cs__heroGlow{position:absolute;inset:-60px;background:radial-gradient(circle at 20% 20%,rgba(0,140,255,.2),transparent 50%),radial-gradient(circle at 80% 30%,rgba(0,200,180,.18),transparent 45%),radial-gradient(circle at 60% 80%,rgba(120,90,255,.12),transparent 50%);filter:blur(10px);opacity:.9}.cs__badge{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:12px;letter-spacing:.3px;background:#ffffffa6;border:1px solid rgba(0,0,0,.08);margin:0 0 10px}.cs__title{font-size:clamp(28px,3vw,40px);margin:0 0 10px;line-height:1.1}.cs__subtitle{margin:0 0 18px;max-width:72ch;color:#000000bf;font-size:15px;line-height:1.6}.cs__meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0 20px}.cs__metaItem{background:#ffffffb8;border:1px solid rgba(0,0,0,.07);border-radius:16px;padding:12px}.cs__metaLabel{display:block;font-size:12px;color:#0000008c;margin-bottom:4px}.cs__metaValue{display:block;font-weight:650;font-size:13px}.cs__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.cs__btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;text-decoration:none;font-weight:650;font-size:14px;border:1px solid rgba(0,0,0,.12)}.cs__btn--primary{background:#0078d4;color:#fff;border-color:#0078d4;box-shadow:0 10px 24px #0078d440}.cs__btn--primary:hover{transform:translateY(-1px)}.cs__btn--ghost{background:#ffffffa6;color:#000c}.cs__content{margin-top:18px}.cs__grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}.cs__grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.cs__card{background:#ffffffdb;border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:18px 16px;box-shadow:0 10px 28px #0000000f}.cs__card--wide{margin-top:14px}.cs__h2{margin:0 0 10px;font-size:18px}.cs__h3{margin:0 0 6px;font-size:15px}.cs__p{margin:0;color:#000000c7;line-height:1.65;font-size:14px}.cs__muted{color:#00000094}.cs__list{margin:0;padding-left:18px;color:#000000c7;line-height:1.7;font-size:14px}.cs__screens{margin-top:18px}.cs__sectionHead{margin:18px 0 12px}.cs__shots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.cs__shot{margin:0;border-radius:18px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#ffffffe6;box-shadow:0 12px 30px #00000014}.cs__shotImgWrap{background:linear-gradient(180deg,#0000000a,#0000);padding:10px}.cs__shotImg{width:100%;height:auto;display:block;border-radius:12px;border:1px solid rgba(0,0,0,.06)}.cs__shotCap{padding:12px 12px 14px}.cs__shotTitle{font-weight:750;margin-bottom:4px}.cs__shotDesc{color:#000000a6;font-size:13px;line-height:1.55}.cs__footer{margin-top:18px;padding:14px 4px 0}.cs__modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.cs__modalContent{position:relative;max-width:90vw;max-height:90vh;background:#fff;border-radius:14px;padding:1rem;overflow:hidden;box-shadow:0 20px 60px #00000059}.cs__modalImg{max-width:100%;max-height:70vh;object-fit:contain;display:block;margin:0 auto}.cs__modalCaption{margin-top:1rem;text-align:center}.cs__modalCaption h3{margin:0;font-size:1.1rem}.cs__modalCaption p{margin:.25rem 0 0;color:#666;font-size:.9rem}.cs__modalClose{position:absolute;top:.5rem;right:.5rem;border:none;background:#000;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px}@media(max-width:900px){.cs__meta,.cs__grid3,.cs__grid2,.cs__shots{grid-template-columns:1fr}}@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}@theme{ --color-primary: #0ea5e9; --color-primary-600: #0284c7; }.btn{@apply px-3 py-2 rounded-lg text-white bg-primary;}:root{--bg: #f7f8fa;--text: #111;--muted: #5b616e;--border: #e5e7eb}:root[data-theme=dark]{--bg: #020617;--text: rgba(255,255,255,.92);--muted: rgba(255,255,255,.7);--border: rgba(255,255,255,.14)}body{background:var(--bg);color:var(--text)}.container{max-width:960px;margin:0 auto;padding:24px}.header{padding:32px 0 16px}.title{font-size:2.2rem;margin:0}.subtitle{color:var(--primary);font-weight:600;margin:4px 0 8px}.intro{color:var(--muted)}.nav{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.nav a{color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:8px}.nav a.active{background:var(--card, rgba(255,255,255,.7));color:var(--text);border:1px solid var(--border)}.nav-link.active{background:#eef2ff;color:#1d4ed8;font-weight:600;border-radius:10px}main section{padding:16px 0 24px}h2{margin:0 0 8px;font-size:1.4rem}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.card{background:#ffffffd9;color:var(--text)}:root[data-theme=dark] .card{background:#ffffff0f}.card h3{margin-top:0}.tags{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.tag{background:#2563eb1f;color:#2563eb;border:1px solid rgba(37,99,235,.25)}:root[data-theme=dark] .tag{color:#93c5fd}.actions{display:flex;gap:8px}.btn{@apply inline-block px-3 py-2 rounded-lg text-white bg-primary no-underline;}.btn-secondary{@apply bg-neutral-900;}.btn-primary{background:#2563eb;font-weight:600;border-radius:10px}.btn-primary:hover{background:#1d4ed8}.skills{list-style:disc;margin-left:20px}.contact-list{list-style:none;padding:0;margin:12px 0}.contact-list li{display:flex;align-items:center;gap:8px;padding:8px 0}.contact-list a{color:var(--text)}.footer{padding:24px 0;border-top:1px solid var(--border);color:var(--muted)}.section-title{font-size:1.4rem;font-weight:700;margin-bottom:.4rem}.section-subtitle{font-size:.95rem;color:#475569;max-width:70ch}
