.project-page{--bg: #ffffff;--bg-muted: #f7f9fc;--bg-card: #f7f9fc;--bg-elevated: #ffffff;--text: #202124;--text-secondary: #5f6368;--text-muted: #80868b;--text-dark: #ffffff;--line: #e5e7eb;--border: var(--line);--accent: #1a73e8;--accent-rgb: 26, 115, 232;--accent-soft: rgba(26, 115, 232, .08);--nav-height: 72px;--gutter: clamp(1rem, 4vw, 2.5rem);--container: min(1200px, 100% - 2rem);--radius: 12px;--radius-pill: 999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--font-display: "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;min-height:100vh;background:var(--bg);color:var(--text);font-family:var(--font-body)}.project-page .cursor,.project-page .cursor-follower{display:none!important}.project-nav{position:fixed;top:0;left:0;width:100%;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--gutter);z-index:9000;background:#fffffff2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.project-nav-left{display:flex;align-items:center;gap:1.5rem}.project-back{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);transition:color .3s;text-decoration:none}.project-back:hover{color:var(--accent)}.project-back svg{width:16px;height:16px}.project-nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text);font-weight:800;letter-spacing:.02em}.project-nav-logo .logo-mark{color:var(--accent)}.project-hero{padding:calc(var(--nav-height) + 4rem) var(--gutter) 4rem;max-width:var(--container);margin:0 auto;position:relative}.project-hero-tag{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2rem}.project-hero-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,7rem);font-weight:800;line-height:.95;letter-spacing:-.04em;margin-bottom:2rem}.project-hero-title .text-accent{color:var(--accent)}.project-hero-subtitle{font-size:clamp(1rem,2vw,1.35rem);line-height:1.6;color:var(--text-secondary);max-width:700px;margin-bottom:2.5rem}.project-hero-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.project-meta-pill{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;padding:.4em 1em;border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text-muted)}.project-meta-pill--accent{border-color:rgba(var(--accent-rgb),.35);color:var(--accent);background:var(--accent-soft)}.project-hero-visual{width:100%;aspect-ratio:21/9;border-radius:var(--radius);overflow:hidden;margin-top:3rem;position:relative}.project-hero-visual-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.project-hero-visual-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(32,33,36,.08) 1px,transparent 1px);background-size:24px 24px;opacity:.5;pointer-events:none}.project-content{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}.project-section{padding:clamp(3rem,6vw,6rem) 0;border-top:1px solid var(--border)}.project-section:first-child{border-top:none}.project-section-tag{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:1.5rem}.project-section-title{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,3rem);font-weight:700;line-height:1.1;letter-spacing:-.03em;margin-bottom:2rem}.project-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}.project-cols--3{grid-template-columns:1fr 1fr 1fr}.archi-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;overflow-x:auto}.archi-block pre{font-family:var(--font-mono);font-size:.75rem;line-height:1.7;color:var(--text-secondary);white-space:pre;margin:0}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:border-color .4s,transform .3s var(--ease-out)}.feature-card:hover{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 8px 24px #2021240f;transform:translateY(-2px)}.feature-card-icon{width:40px;height:40px;color:var(--accent);margin-bottom:1rem}.feature-card-icon svg{width:100%;height:100%}.feature-card-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:.75rem}.feature-card-desc{font-size:.9rem;line-height:1.6;color:var(--text-secondary)}.feature-card-list{margin-top:.75rem}.feature-card-list li{font-size:.85rem;line-height:1.7;color:var(--text-secondary);padding-left:1rem;position:relative}.feature-card-list li:before{content:"→";position:absolute;left:0;color:var(--accent);font-size:.75rem}.project-demo-links{display:flex;flex-wrap:wrap;gap:1rem 1.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.project-demo-links a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(var(--accent-rgb),.35);padding-bottom:.12em;transition:color .2s ease,border-color .2s ease}.project-demo-links a:hover{color:var(--text);border-bottom-color:var(--accent)}.spec-table{width:100%;border-collapse:collapse}.spec-table th,.spec-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}.spec-table th{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-card)}.spec-table td{color:var(--text-secondary)}.spec-table tr:hover td{color:var(--text);background:var(--accent-soft)}.spec-table code{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);background:var(--accent-soft);padding:.15em .45em;border-radius:4px}.project-stack{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.tech-pill{display:inline-flex;align-items:center;font-size:.78rem;font-weight:500;padding:.4em .85em;border-radius:var(--radius-pill);border:1px solid var(--line);background:#fff;color:var(--text-secondary)}.project-stack .tech-pill{font-size:.8rem;padding:.65em 1.3em}.project-text{font-size:1rem;line-height:1.8;color:var(--text-secondary)}.project-text p{margin-bottom:1rem}.project-text strong{color:var(--text);font-weight:600}.project-text a{color:var(--accent);text-decoration:underline;text-underline-offset:.2em;text-decoration-color:rgba(var(--accent-rgb),.45)}.project-text a:hover{text-decoration-color:var(--accent);color:var(--text)}.project-text ul,.project-text ol{margin:1rem 0;padding-left:0}.project-text li{padding-left:1.5rem;position:relative;margin-bottom:.5rem}.project-text li:before{content:"▸";position:absolute;left:0;color:var(--accent)}.api-group{margin-bottom:2rem}.api-group-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}.api-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--line);font-size:.85rem}.api-method{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;padding:.2em .6em;border-radius:4px;font-weight:600;min-width:3.2em;text-align:center}.api-method--get{background:#00c89626;color:#00c896}.api-method--post{background:#6496ff26;color:#6496ff}.api-method--delete{background:#ff505026;color:#ff5050}.api-endpoint{font-family:var(--font-mono);font-size:.8rem;color:var(--text)}.api-desc{color:var(--text-muted);font-size:.8rem;margin-left:auto}.sub-project-divider{padding:clamp(4rem,8vw,8rem) 0 2rem;text-align:center}.sub-project-divider-line{width:60px;height:2px;background:var(--accent);margin:0 auto 2rem}.sub-project-divider-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,4rem);font-weight:800;letter-spacing:-.03em}.file-tree{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;font-family:var(--font-mono);font-size:.75rem;line-height:1.8;color:var(--text-secondary);overflow-x:auto}.file-tree .ft-dir{color:var(--accent)}.file-tree .ft-file{color:var(--text-secondary)}.file-tree .ft-comment{color:var(--text-muted);font-style:italic}.project-cta-banner{background:linear-gradient(135deg,#1558b0 0%,var(--accent) 100%);padding:clamp(3rem,6vw,5rem) var(--gutter);text-align:center}.project-cta-banner h3{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;color:var(--text-dark);margin-bottom:1rem}.project-cta-banner p{color:#ffffffe0;font-size:1rem;margin-bottom:2rem;max-width:42rem;margin-left:auto;margin-right:auto}.project-cta-banner .btn-liquid{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:999px;border:2px solid rgba(255,255,255,.95);background:#ffffff1f;color:#fff;font-weight:600;font-size:.95rem;text-decoration:none;overflow:hidden;transition:background .2s ease,border-color .2s ease,transform .2s ease}.project-cta-banner .btn-liquid:hover{background:#fff;color:var(--accent);border-color:#fff;transform:translateY(-1px)}.project-cta-banner .btn-liquid-fill{display:none}.project-cta-banner .btn-liquid-text,.project-cta-banner .btn-liquid-icon{position:relative;z-index:1}.project-cta-banner .btn-liquid-icon svg{width:1.1em;height:1.1em}.project-cta-banner .btn-liquid--dark{display:inline-flex}.project-footer{border-top:1px solid var(--border);padding:2rem var(--gutter);display:flex;align-items:center;justify-content:space-between;max-width:var(--container);margin:0 auto}.project-footer-left{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.project-footer-right a{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);text-decoration:none;transition:color .3s}.project-footer-right a:hover{color:var(--accent)}.info-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 2rem}.info-block-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;display:block}.info-block-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text)}.info-block-value--accent{color:var(--accent)}.info-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:2rem}@media(max-width:1024px){.project-cols{grid-template-columns:1fr}.project-cols--3{grid-template-columns:1fr 1fr}}@media(max-width:768px){.project-page{--nav-height: 64px}.project-nav{height:var(--nav-height);padding:0 1rem}.project-nav-logo .logo-text{display:none}.project-back{font-size:.6rem;gap:.35rem}.project-back svg{width:14px;height:14px}.project-hero{padding:calc(var(--nav-height) + 2rem) 1rem 2rem}.project-hero-tag{font-size:.6rem;margin-bottom:1.25rem}.project-hero-title{font-size:clamp(2.25rem,10vw,4rem);margin-bottom:1.25rem}.project-hero-subtitle{font-size:.95rem;margin-bottom:1.5rem}.project-hero-meta{gap:.5rem}.project-meta-pill{font-size:.55rem;padding:.35em .75em}.project-hero-visual{aspect-ratio:16/9;margin-top:2rem}.project-content{padding:0 1rem}.project-section{padding:clamp(2rem,5vw,4rem) 0}.project-cols--3,.feature-grid{grid-template-columns:1fr}.api-desc{display:none}.info-row{grid-template-columns:1fr 1fr}.sub-project-divider{margin:2rem 0;padding:2rem 0}}@media(max-width:480px){.project-hero{padding:calc(var(--nav-height) + 1.25rem) .75rem 1.5rem}.project-hero-title{font-size:2rem}.project-hero-subtitle{font-size:.85rem}.project-hero-meta{gap:.4rem}.project-meta-pill{font-size:.5rem;padding:.3em .6em}.info-row{grid-template-columns:1fr}.feature-card{padding:1.25rem}.project-section-title{font-size:clamp(1.25rem,5vw,1.75rem)}.project-text{font-size:.9rem}.archi-block{padding:1rem;font-size:.6rem}.spec-table th,.spec-table td{padding:.6rem .75rem;font-size:.7rem}}
