:root{--bg: #0e0c18;--panel: #181527;--panel-2: #1f1c30;--ink: #f6f4ff;--soft: #c8c4dc;--mute: #8a85a3;--rule: #221f33;--rule-hi: #2a2740;--pink: #ff7eb6;--violet: #a78bfa;--max: 1080px;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;--mono: "JetBrains Mono", "SF Mono", Menlo, ui-monospace, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--violet);text-decoration:none;transition:color .15s ease}a:hover{color:var(--pink)}h1,h2,h3,h4{color:var(--ink);letter-spacing:-.5px;line-height:1.15;margin:0 0 .4em;font-weight:600}p{margin:0 0 1em;color:var(--soft)}code,kbd,samp{font-family:var(--mono);font-size:.92em;background:var(--panel);border:1px solid var(--rule);padding:.08em .35em;border-radius:4px;color:var(--soft)}.container{max-width:var(--max);margin:0 auto;padding:0 32px}.site-header{padding:28px 0;border-bottom:1px solid var(--rule)}.site-header .row{display:flex;align-items:center;justify-content:flex-end;gap:16px}.site-mark{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.2px}.site-mark:hover{color:var(--ink)}.site-nav{display:flex;gap:28px;font-size:14px}.site-nav a{color:var(--soft)}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--ink)}.hero{padding:128px 0 88px}.hero .label{font-size:16px;color:var(--mute);margin:0 0 32px;letter-spacing:.005em}.hero h1{font-size:clamp(48px,7vw,76px);font-weight:600;line-height:1.08;letter-spacing:-1.8px;margin:0 0 32px;color:var(--ink)}.hero .lede{font-size:clamp(20px,2vw,24px);color:var(--soft);max-width:64ch;margin:0 0 18px;line-height:1.55}.hero .lede strong{color:var(--ink);font-weight:500}.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin:40px 0 0}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:500;text-decoration:none!important;border:none;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s,color .15s}.btn-primary{background:linear-gradient(135deg,var(--pink) 0%,var(--violet) 100%);color:#18112a!important;box-shadow:0 0 0 1px #ffffff26 inset,0 8px 24px -8px #a78bfa80}.btn-primary:hover{transform:translateY(-1px);color:#18112a!important;box-shadow:0 0 0 1px #ffffff2e inset,0 12px 32px -8px #a78bfaa6}.btn-ghost{background:var(--panel);color:var(--ink)!important;border:1px solid var(--rule-hi)}.btn-ghost:hover{background:var(--panel-2);color:var(--ink)!important}.section{padding:88px 0 120px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 36px;gap:16px}.section-head h2{font-size:30px;font-weight:600;letter-spacing:-.5px;margin:0;color:var(--ink)}.section-head .meta{font-size:14px;color:var(--soft)}.section-head .meta:hover{color:var(--ink)}.subsec-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 24px;gap:16px}.subsec-head h2{font-size:22px;font-weight:600;letter-spacing:-.3px;margin:0;color:var(--ink)}.subsec-head .meta{font-size:13px;color:var(--mute)}.subsection{padding:56px 0 0}.section-intro{font-size:17px;color:var(--soft);max-width:64ch;margin:-8px 0 32px;line-height:1.6}.section-intro strong{color:var(--ink);font-weight:500}hr.rule{border:0;border-top:1px solid var(--rule);margin:4rem 0}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}.card{position:relative;background:var(--panel);border:1px solid var(--rule);border-radius:14px;display:flex;flex-direction:column;color:inherit;transition:border-color .2s,background .2s,transform .2s;min-height:200px;overflow:hidden}.card:hover{border-color:var(--rule-hi);background:var(--panel-2);transform:translateY(-2px)}.card .card-link{position:absolute;inset:0;z-index:1;text-decoration:none;border:none}.card-actions{display:flex;gap:6px;z-index:2;position:relative}.card-head-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.card-action{display:inline-flex;align-items:center;gap:5px;padding:4px 9px 4px 8px;font-size:11px;font-weight:500;color:var(--soft)!important;background:#0e0c18b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--rule-hi);border-radius:999px;text-decoration:none!important;transition:color .15s,background .15s,border-color .15s}.card-action:hover{color:var(--ink)!important;background:var(--panel-2);border-color:var(--violet)}.card-action svg{display:block;flex-shrink:0}.card .card-cover{aspect-ratio:16 / 9;position:relative;overflow:hidden;background:radial-gradient(circle at 20% 0%,rgba(255,126,182,.18),transparent 55%),radial-gradient(circle at 90% 100%,rgba(167,139,250,.18),transparent 60%),var(--panel-2);border-bottom:1px solid var(--rule);padding:18px 18px 0;display:flex;align-items:flex-end}.card .card-cover .frame{width:100%;height:100%;border-radius:8px 8px 0 0;background:#fff;box-shadow:0 0 0 1px #0009,0 18px 36px -10px #0000008c,0 6px 12px -4px #0006;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease}.card .card-cover .frame-chrome{height:18px;background:linear-gradient(180deg,#f0f0f1,#e6e6e8);display:flex;align-items:center;padding:0 8px;gap:5px;flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06)}.card .card-cover .frame-chrome span{width:8px;height:8px;border-radius:50%;background:#0000002e}.card .card-cover .frame-chrome span:nth-child(1){background:#ff5f57}.card .card-cover .frame-chrome span:nth-child(2){background:#febc2e}.card .card-cover .frame-chrome span:nth-child(3){background:#28c840}.card .card-cover .frame img{width:100%;flex:1;object-fit:cover;object-position:top;display:block;min-height:0}.card:hover .card-cover .frame{transform:translateY(-2px)}.card .card-body{padding:26px 28px 24px;display:flex;flex-direction:column;gap:12px;flex:1}.card .card-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px}.card h3{margin:0;font-size:19px;font-weight:600;letter-spacing:-.3px;color:var(--ink)}.card .card-year{font-size:12px;color:var(--mute);font-family:var(--mono);white-space:nowrap}.card .card-tagline{margin:0;color:var(--soft);font-size:14.5px;line-height:1.55}.card .card-foot{margin-top:auto;padding-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid var(--rule)}.card .tech{font-size:12px;color:var(--mute);font-family:var(--mono);text-align:right;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px;background:var(--panel-2);border:1px solid var(--rule-hi);border-radius:999px;color:var(--soft);letter-spacing:.01em}.badge.live{color:#6ee7a7;border-color:#6ee7a740}.badge.active{color:#7fb3ff;border-color:#7fb3ff40}.badge.shipped{color:#c4a8ff;border-color:#c4a8ff40}.badge.wip{color:#ffb27a;border-color:#ffb27a40}.badge.ongoing{color:#6ee7a7;border-color:#6ee7a740}.badge.archived{color:var(--mute)}article.project{padding:56px 0 120px}article.project .back{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--mute);text-decoration:none!important}article.project .back:hover{color:var(--ink)}article.project h1{font-size:clamp(36px,5vw,56px);font-weight:600;letter-spacing:-1.2px;margin:18px 0 8px}article.project .tagline{font-size:19px;color:var(--soft);margin:0;line-height:1.5;max-width:60ch}article.project .hero-cover{margin:36px 0;border-radius:16px;overflow:hidden;aspect-ratio:16 / 9;background:radial-gradient(circle at 20% 0%,rgba(255,126,182,.2),transparent 55%),radial-gradient(circle at 90% 100%,rgba(167,139,250,.22),transparent 60%),var(--panel-2);padding:32px 32px 0;display:flex;align-items:flex-end;border:1px solid var(--rule)}article.project .hero-cover .frame{width:100%;height:100%;border-radius:10px 10px 0 0;background:#fff;box-shadow:0 0 0 1px #0009,0 32px 60px -14px #0009,0 12px 20px -6px #00000073;overflow:hidden;display:flex;flex-direction:column}article.project .hero-cover .frame-chrome{height:24px;background:linear-gradient(180deg,#f0f0f1,#e6e6e8);display:flex;align-items:center;padding:0 12px;gap:6px;flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06)}article.project .hero-cover .frame-chrome span{width:11px;height:11px;border-radius:50%}article.project .hero-cover .frame-chrome span:nth-child(1){background:#ff5f57}article.project .hero-cover .frame-chrome span:nth-child(2){background:#febc2e}article.project .hero-cover .frame-chrome span:nth-child(3){background:#28c840}article.project .hero-cover .frame img{width:100%;flex:1;object-fit:cover;object-position:top;display:block;min-height:0}article.project .meta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin:32px 0 18px;font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.04em}article.project .tech-list{display:flex;gap:6px;flex-wrap:wrap;margin:4px 0 36px}article.project .tech-list span{font-family:var(--mono);font-size:11px;background:var(--panel);border:1px solid var(--rule);color:var(--soft);padding:4px 9px;border-radius:6px;letter-spacing:.02em}article.project .body{font-size:17px;line-height:1.7;color:var(--soft);max-width:64ch}article.project .body p{color:var(--soft)}article.project .body p strong{color:var(--ink);font-weight:500}article.project .body a{color:var(--violet)}article.project .body a:hover{color:var(--pink)}article.project .links-row{display:flex;gap:10px;flex-wrap:wrap;margin:40px 0 0}.site-footer{border-top:1px solid var(--rule);padding:28px 0 40px;font-size:13px;color:var(--mute)}.site-footer .row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.site-footer a{color:var(--soft)}.site-footer a:hover{color:var(--ink)}
