.nav{background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.nav-inner{max-width:1200px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.nav-brand{font-family:var(--font-mono);font-weight:700;font-size:1.25rem;color:var(--text);text-decoration:none}.nav-brand:hover{text-decoration:none}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-links a{color:var(--text-muted);font-weight:500}.nav-links a:hover{color:var(--accent)}.nav-user-wrap{position:relative}.nav-user-trigger{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--text);font:inherit;cursor:pointer}.nav-user-trigger:hover{background:var(--bg-elevated);border-color:var(--border-subtle)}.nav-user-avatar{width:1.75rem;height:1.75rem;border-radius:50%;background:var(--accent);color:var(--bg);display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;font-family:var(--font-mono);flex-shrink:0}.nav-user-name{font-family:var(--font-mono);font-size:.9rem;max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-user-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:10rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:.25rem;z-index:200}.nav-user-dropdown-item{display:block;width:100%;padding:.5rem .75rem;text-align:left;border:none;background:transparent;color:var(--text);font:inherit;cursor:pointer;border-radius:var(--radius-md)}.nav-user-dropdown-item:hover{background:var(--bg-elevated);color:var(--accent)}.profile-modal-content{padding:0;min-width:340px;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-card) 24%);border-radius:var(--radius-lg);overflow:hidden}.profile-modal-header{text-align:center;padding:var(--space-8) var(--space-6) var(--space-6);position:relative}.profile-modal-header:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60%;height:1px;background:linear-gradient(90deg,transparent,var(--border-subtle),transparent)}.profile-modal-avatar{width:4rem;height:4rem;margin:0 auto var(--space-4);border-radius:50%;background:linear-gradient(145deg,var(--accent) 0%,var(--accent-hover) 100%);box-shadow:0 4px 14px #2563eb59,inset 0 1px #ffffff1f;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;font-family:var(--font-mono);color:#fff;letter-spacing:-.02em}.profile-modal-name{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 var(--space-1);letter-spacing:-.01em}.profile-modal-email{font-size:.8125rem;color:var(--text-muted);margin:0}.profile-modal-message{padding:var(--space-8) var(--space-6);color:var(--text-muted);line-height:1.6;text-align:center}.profile-modal-message p{margin:0}.profile-form{padding:var(--space-5) var(--space-6) var(--space-6)}.profile-form-error{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);color:var(--error);font-size:.875rem;border-left:3px solid var(--error)}.profile-form-section{margin-bottom:var(--space-5)}.profile-form-section:last-of-type{margin-bottom:var(--space-5)}.profile-form-section-card{background:#0f111580;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4);position:relative;padding-left:var(--space-5);border-left:3px solid var(--accent);box-shadow:0 1px #00000026}.profile-form-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 var(--space-3);padding:0}.profile-form-section-icon{font-size:.5rem;opacity:.9}.profile-form-hint{font-size:.8125rem;color:var(--text-muted);margin:0 0 var(--space-4);line-height:1.45;padding-left:.05rem}.profile-form-field{display:block;margin-bottom:var(--space-4)}.profile-form-field:last-child{margin-bottom:0}.profile-form-label{display:block;font-size:.8125rem;font-weight:600;color:var(--text);margin-bottom:var(--space-2);letter-spacing:.01em}.profile-form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:.9375rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-dark);color:var(--text);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:inset 0 1px 2px #0003}.profile-form-input::placeholder{color:var(--text-muted);opacity:.85}.profile-form-input:hover{border-color:var(--border);background:#0f1115e6}.profile-form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted),inset 0 1px 2px #00000026}.profile-form-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border-subtle)}.profile-form-save{min-width:130px;font-weight:600;box-shadow:0 2px 8px #2563eb40}.profile-form-save:hover:not(:disabled){box-shadow:0 4px 14px #2563eb59}.profile-form-actions .btn-ghost:hover{background:var(--bg-elevated);color:var(--text)}@media (max-width: 768px){.nav-user-trigger{width:100%;justify-content:flex-start;padding:var(--space-3) var(--space-4);min-height:48px}.nav-user-dropdown{left:0;right:auto;width:max-content;min-width:10rem;max-width:calc(100vw - var(--space-8));z-index:1001;box-shadow:var(--shadow-lg)}}.layout-main{flex:1;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;width:100%}:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--bg: #0f1115;--bg-dark: #0f1115;--bg-card: #181b21;--bg-elevated: #1e2229;--border: #2d333b;--border-subtle: rgba(45, 51, 59, .5);--text: #f0f2f5;--text-muted: #8b92a0;--accent: #2563eb;--accent-hover: #3b82f6;--accent-muted: rgba(37, 99, 235, .12);--accent-glow: rgba(37, 99, 235, .15);--success: #22c55e;--warning: #eab308;--error: #ef4444;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 14px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3);--focus-ring: 0 0 0 2px var(--bg-dark), 0 0 0 4px var(--accent);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box}html{height:100%;overflow-x:hidden}body{margin:0;min-height:100%;font-family:var(--font-sans);font-size:16px;background:var(--bg-dark);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;overflow-x:hidden}code,.mono{font-family:var(--font-mono)}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover);text-decoration:none}button{font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-md)}input,textarea{font-family:var(--font-sans)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#12151a 0%,var(--bg-dark) 50%,#0d0f12 100%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100%;max-width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-4);min-height:44px;border-radius:var(--radius-lg);font-weight:600;font-size:.9375rem;border:none;transition:background var(--transition),color var(--transition),border-color var(--transition),box-shadow var(--transition),transform .15s ease}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn:active:not(:disabled){transform:scale(.98)}.btn-sm{padding:var(--space-2) var(--space-3);min-height:38px;font-size:.875rem;border-radius:var(--radius-md)}.btn-primary{background:linear-gradient(180deg,var(--accent) 0%,#1d4ed8 100%);color:#fff;box-shadow:0 2px 6px #2563eb40,inset 0 1px #ffffff14}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,var(--accent-hover) 0%,var(--accent) 100%);color:#fff;box-shadow:0 4px 12px var(--accent-glow),inset 0 1px #ffffff1a}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:var(--accent-muted);color:var(--accent);border-color:#2563eb33}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);box-shadow:0 1px #00000026}.btn-secondary:hover:not(:disabled){background:#2d333b66;color:var(--text);border-color:var(--accent);box-shadow:0 2px 8px #2563eb1f}.btn-block{width:100%}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0 0 var(--space-2)}.text-muted{color:var(--text-muted);margin:0}.small{font-size:.8125rem}.legal-page{max-width:720px}.legal-content{font-size:.9375rem;line-height:1.7}.legal-content section{margin-bottom:var(--space-8)}.legal-content h2{font-size:1.125rem;font-weight:600;margin:0 0 var(--space-3);color:var(--text)}.legal-content p{margin:0 0 var(--space-4);color:var(--text-muted)}.legal-content p:last-child{margin-bottom:0}.legal-content ul{margin:0 0 var(--space-4);padding-left:var(--space-6);color:var(--text-muted)}.legal-content li{margin-bottom:var(--space-2)}.legal-content li:last-child{margin-bottom:0}.legal-content a{color:var(--accent);text-decoration:none}.legal-content a:hover{color:var(--accent-hover)}.legal-back{margin-top:var(--space-8);margin-bottom:0}.legal-back a{color:var(--text-muted);font-size:.9375rem}.legal-back a:hover{color:var(--accent)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:.9375rem}.projects-header{margin-bottom:var(--space-10)}.projects-intro{max-width:560px;font-size:1rem;line-height:1.6}.home .project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.project-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid transparent;border-radius:var(--radius-lg);overflow:hidden;color:var(--text);text-decoration:none;transition:border-color var(--transition),box-shadow var(--transition)}.project-card-thumb{width:100%;height:140px;background:var(--bg);flex-shrink:0;overflow:hidden;position:relative}.project-card-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.project-card-thumb-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--bg) 0%,var(--border-subtle) 100%)}.project-card-header,.project-card-desc,.project-card-link{padding-left:var(--space-6);padding-right:var(--space-6)}.project-card-header{padding-top:var(--space-4)}.project-card-link{padding-bottom:var(--space-6);margin-top:auto}.project-card:hover{border-color:var(--border);border-left:3px solid var(--accent);box-shadow:var(--shadow-md);text-decoration:none;color:var(--text)}.project-card-title{font-weight:600;font-size:1rem;letter-spacing:-.01em}.project-card-header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2);padding-top:var(--space-4)}.project-card-meta{font-size:.8125rem;color:var(--text-muted)}.project-card-desc{font-size:.9375rem;color:var(--text-muted);margin:0 0 var(--space-3);line-height:1.5;padding-left:var(--space-6);padding-right:var(--space-6)}.project-card-link{font-size:.875rem;font-weight:500;color:var(--accent);padding-left:1.5rem;padding-right:1.5rem;padding-bottom:1.5rem;margin-top:auto}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem 2rem;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-md)}.empty-state .mono{display:block;margin-bottom:.5rem;color:var(--text);font-size:1rem}.auth-page{position:relative;min-height:60vh;min-height:60dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-4) var(--space-3);overflow:hidden;background:var(--bg-dark)}.auth-code-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;display:flex;justify-content:center;padding:0 var(--space-4);mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 88%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 88%,transparent 100%)}.auth-code-bg-column{position:relative;overflow:hidden;width:100%;max-width:380px;height:100%}.auth-code-bg-track{display:flex;flex-direction:column;flex-shrink:0;animation:auth-code-scroll 40s linear infinite;will-change:transform;transform:translateZ(0)}@keyframes auth-code-scroll{0%{transform:translateZ(0) translateY(0)}to{transform:translateZ(0) translateY(-50%)}}.auth-code-bg-line{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-1) 0;font-family:var(--font-mono);font-size:.75rem;line-height:1.75;color:#cbd5e173;white-space:nowrap;flex-shrink:0}.auth-code-bg-num{flex-shrink:0;width:2.25ch;text-align:right;color:#94a3b880;-webkit-user-select:none;user-select:none;font-size:.7rem}.auth-code-token{color:inherit;background:none;padding:0;font-size:inherit;font-family:inherit}@media (prefers-reduced-motion: reduce){.auth-code-bg-track{animation:none}}.auth-page-content{position:relative;z-index:1;width:100%;max-width:360px}.auth-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-5) var(--space-5);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.auth-title{font-size:1.25rem;font-weight:600;margin:0 0 var(--space-3);letter-spacing:-.02em;color:var(--text)}.auth-oauth{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.auth-oauth-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;background:var(--bg-dark);border:1px solid var(--border-subtle);color:var(--text);transition:border-color var(--transition),background var(--transition)}.auth-oauth-btn:hover:not(:disabled){border-color:var(--border);background:var(--bg-elevated)}.auth-oauth-btn:disabled{opacity:.7;cursor:not-allowed}.auth-oauth-icon{flex-shrink:0;width:20px;height:20px;display:block}.auth-divider{font-size:.8125rem;color:var(--text-muted);text-align:center;margin:0 0 var(--space-3)}.auth-note{font-size:.8125rem;color:var(--text-muted);margin:0 0 var(--space-4);line-height:1.5}.auth-note strong{color:var(--text)}.auth-form label{display:block;margin-bottom:var(--space-3)}.auth-form label:last-of-type{margin-bottom:0}.auth-form .label-text{display:block;font-size:.8125rem;font-weight:500;margin-bottom:var(--space-1);color:var(--text-muted);transition:color var(--transition)}.auth-form label:focus-within .label-text{color:var(--text)}.label-text{display:block;font-size:.8125rem;font-weight:500;margin-bottom:var(--space-1);color:var(--text-muted)}.input{width:100%;padding:var(--space-2) var(--space-3);background:#0f111599;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text);font-size:.9375rem;transition:all var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.input:hover{border-color:#2d333bcc;background:#0f1115b3}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted),0 0 0 1px var(--accent);background:#0f1115cc}.auth-form .input{padding:var(--space-2) var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-dark);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.auth-form .input:hover{border-color:var(--border);background:#0f1115d9}.auth-form .input::placeholder{color:var(--text-muted);opacity:.8}.auth-form .input:focus,.auth-form .input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted);background:var(--bg-dark);border-left-width:3px;border-left-color:var(--accent);padding-left:calc(var(--space-3) - 2px)}.auth-form .btn-block:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-muted),0 2px 8px #2563eb33}.textarea{resize:vertical;min-height:88px}.auth-form .btn-block{margin-top:var(--space-3);padding:var(--space-2) var(--space-4);font-weight:600;font-size:.875rem;letter-spacing:-.01em;box-shadow:0 2px 8px #2563eb33;transition:all var(--transition)}.auth-form .btn-block:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.auth-form .btn-block:active:not(:disabled){transform:translateY(0)}.auth-error{background:#f851491a;color:var(--error);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);margin-bottom:var(--space-3);font-size:.8125rem;border:1px solid rgba(248,81,73,.25);word-break:break-word}.auth-footer{margin:var(--space-3) 0 0;text-align:center;color:var(--text-muted);font-size:.8125rem;line-height:1.5}.auth-footer a{color:var(--accent);font-weight:500;transition:color var(--transition)}.auth-footer a:hover{color:var(--accent-hover);text-decoration:none}.auth-hint{margin:var(--space-3) 0 0;padding:var(--space-2) var(--space-3);background:#2563eb0f;border:1px solid rgba(37,99,235,.12);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-muted);text-align:center;line-height:1.5}.auth-hint code{color:var(--accent);font-size:.75rem;background:#2563eb1a;padding:.125rem .25rem;border-radius:3px;font-weight:500}.project-detail-header{margin-bottom:var(--space-8)}.back-link{display:inline-flex;align-items:center;margin-bottom:var(--space-4);color:var(--text-muted);font-size:.9375rem;font-weight:500}.back-link:hover{color:var(--accent);text-decoration:none}.project-thumbnail-section{margin-bottom:2rem}.project-thumbnail{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:16 / 10;max-height:320px;display:flex;align-items:center;justify-content:center}.project-thumbnail-img{width:100%;height:100%;object-fit:cover;display:block}.project-thumbnail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;color:var(--text-muted)}.project-thumbnail-icon{font-size:2.5rem;line-height:1}.thumb-window{display:inline-flex;flex-direction:column;align-items:center;width:80px;padding:.5rem .75rem 1rem;background:var(--bg);border:1px solid var(--border-subtle);border-radius:6px;box-shadow:0 2px 8px #00000026}.thumb-bar{display:block;width:100%;height:6px;margin-bottom:.5rem;background:var(--border-subtle);border-radius:3px}.thumb-dots{font-size:.5rem;letter-spacing:.25em;color:var(--text-muted)}.project-thumbnail-label{margin:0;font-size:.9375rem;font-weight:600;color:var(--text)}.project-thumbnail-files{margin:0;font-size:.8125rem;font-family:var(--font-mono);color:var(--text-muted)}.project-demo-cta{margin-top:var(--space-5);display:flex;justify-content:flex-start}.btn-view-demo{padding:var(--space-3) var(--space-6);font-size:1rem;font-weight:600;border-radius:var(--radius-xl)}.btn-view-demo:disabled{opacity:.8;cursor:not-allowed}.project-description-section{margin-bottom:var(--space-8)}.project-description{margin-top:0;padding:var(--space-5) var(--space-5) var(--space-5) var(--space-4);background:var(--bg-card);border-radius:var(--radius-md);border-left:3px solid var(--accent);font-size:.9375rem;line-height:1.6}.section-title{font-size:1rem;font-weight:600;margin:0 0 var(--space-3);color:var(--text-muted)}.demo-section{margin-bottom:var(--space-8)}.demo-frame-wrap{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;min-height:400px;box-shadow:var(--shadow-sm)}.demo-iframe{width:100%;height:500px;border:none;display:block}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:960px;height:90vh;max-height:90vh;display:flex;flex-direction:column;animation:modal-slide-in .25s ease}.modal-box-compact{height:auto;max-height:90vh;max-width:480px}@keyframes modal-slide-in{0%{opacity:0;transform:scale(.98) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.modal-title{font-size:1rem;font-weight:600;margin:0;color:var(--text)}.modal-close{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:color var(--transition),background var(--transition)}.modal-close:hover{color:var(--text);background:var(--bg-elevated)}.modal-close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.modal-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;position:relative}.modal-box-compact .modal-body{flex:0 1 auto;overflow:visible}.demo-modal-error{padding:var(--space-4);margin:var(--space-4);background:#ef44441a;color:var(--error);font-size:.9375rem;border-radius:var(--radius-sm);border:1px solid rgba(239,68,68,.25);flex-shrink:0}.demo-modal-loading{padding:var(--space-6);margin:0;color:var(--text-muted);text-align:center;flex-shrink:0}.sign-in-modal-content{padding:var(--space-4)}.sign-in-modal-message{margin:0 0 var(--space-6);color:var(--text-muted);line-height:1.6;font-size:.9375rem}.sign-in-modal-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.sign-in-modal-actions .btn{text-decoration:none;flex:1;min-width:120px}.sign-in-modal-actions .btn:hover{text-decoration:none}.auth-required-notice{padding:var(--space-4);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-4)}.auth-required-text{margin:0;color:var(--text-muted);font-size:.9375rem;flex:1;min-width:200px}.demo-modal-frame-wrap{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-dark);overflow:auto;min-height:200px;-webkit-overflow-scrolling:touch}.demo-modal-iframe{width:100%;height:100%;min-height:200px;border:none;display:block;vertical-align:top}.files-section{margin-top:2rem}.files-bundle-row{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.files-bundle-hint{font-size:.875rem;color:var(--text-muted)}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-row{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:border-color var(--transition)}.file-row:hover{border-color:var(--border)}.file-name{color:var(--accent);font-size:.8125rem;font-weight:500;min-width:2.5rem}.file-filename{flex:1;font-size:.9375rem}.admin-upload{margin-bottom:2.5rem}.admin-form label{display:block;margin-bottom:1rem}.input-file{width:100%;padding:.5rem;color:var(--text-muted);font-size:.875rem}.admin-files-hint{margin:.5rem 0 0;line-height:1.5;max-width:520px}.admin-files-hint code{color:var(--accent);font-size:.8125rem}.admin-project-list{display:flex;flex-direction:column;gap:.75rem}.admin-project-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem 1.5rem;transition:border-color var(--transition)}.admin-project-card:hover{border-color:var(--border)}.admin-project-head{display:flex;justify-content:space-between;align-items:center;gap:1rem}.admin-project-head a{font-weight:600;font-size:.9375rem;color:var(--accent)}.admin-project-actions{display:flex;gap:.375rem}.admin-project-desc{margin:.75rem 0 0;font-size:.9375rem;color:var(--text-muted);line-height:1.5}.admin-edit-inline{margin-top:.75rem}.admin-edit-inline .textarea{margin-bottom:.5rem}.admin-edit-field,.admin-edit-files{display:block;margin-bottom:.5rem}.admin-edit-field .label-text,.admin-edit-files .label-text{display:block;margin-bottom:.25rem}.admin-edit-thumbnail{display:block;margin-bottom:.5rem}.admin-edit-thumbnail .label-text{display:block;margin-bottom:.25rem}.admin-edit-actions{display:flex;gap:.5rem}.nav{background:#0f1115eb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100;padding-top:env(safe-area-inset-top,0)}.nav-inner{max-width:1100px;margin:0 auto;padding:var(--space-3) var(--space-6);padding-left:calc(var(--space-6) + env(safe-area-inset-left,0));padding-right:calc(var(--space-6) + env(safe-area-inset-right,0));display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:48px}.nav-brand{font-family:var(--font-mono);font-weight:700;font-size:1.375rem;letter-spacing:-.03em;color:var(--text);text-decoration:none;transition:color var(--transition);flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center}.nav-brand:hover{color:var(--text);text-decoration:none}.nav-brand-text{display:inline-block;vertical-align:middle}.nav-brand-bracket{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap;justify-content:flex-end;min-width:0}.nav-links a{color:var(--text-muted);font-weight:500;font-size:.9375rem;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);white-space:nowrap}.nav-links a:hover{color:var(--accent);background:var(--accent-muted);text-decoration:none}.nav-links .btn{white-space:nowrap}.nav-user{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.nav-user-name{font-family:var(--font-mono);font-size:.875rem;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-user-role{color:var(--text-muted);font-size:.75rem;font-weight:500}.nav-toggle{display:none;flex-shrink:0;width:48px;height:48px;padding:0;border:none;background:transparent;color:var(--text-muted);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:6px;border-radius:var(--radius-md);transition:background .2s ease,color .2s ease,transform .15s ease}.nav-toggle:hover{background:var(--accent-muted);color:var(--text)}.nav-toggle:active{transform:scale(.96)}.nav-toggle:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--accent)}.nav-toggle-bar{display:block;width:22px;height:2.5px;background:currentColor;border-radius:2px;transition:transform .25s ease,opacity .2s ease}.nav--open .nav-toggle{color:var(--text)}.nav--open .nav-toggle-bar:nth-child(1){transform:translateY(8.5px) rotate(45deg)}.nav--open .nav-toggle-bar:nth-child(2){opacity:0}.nav--open .nav-toggle-bar:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}.layout-wrap{display:flex;flex-direction:column;min-height:100vh}.layout-main{flex:1;max-width:1100px;margin:0 auto;padding:var(--space-10) var(--space-6);width:100%;padding-left:calc(var(--space-6) + env(safe-area-inset-left,0));padding-right:calc(var(--space-6) + env(safe-area-inset-right,0))}.layout-main:has(.auth-page){padding-top:var(--space-4);padding-bottom:var(--space-4)}.site-footer{margin-top:auto;background:#181b21cc;border-top:1px solid var(--border-subtle);padding:var(--space-12) var(--space-6);padding-left:calc(var(--space-6) + env(safe-area-inset-left,0));padding-right:calc(var(--space-6) + env(safe-area-inset-right,0));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.footer-inner{max-width:1100px;margin:0 auto;text-align:center}.footer-brand{font-family:var(--font-mono);font-weight:700;font-size:.9375rem;letter-spacing:-.01em;color:var(--text-muted);margin-bottom:var(--space-5)}.footer-links{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-5) var(--space-8);margin-bottom:var(--space-5)}.footer-links a{color:var(--text-muted);font-weight:500;font-size:.9375rem}.footer-links a:hover{color:var(--accent)}.footer-social{display:flex;justify-content:center;gap:var(--space-4);margin-bottom:1.25rem}.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;color:var(--text-muted);border-radius:var(--radius-md);transition:color .2s ease,background .2s ease,transform .15s ease}.footer-social-link:hover{color:var(--accent);background:var(--accent-muted);transform:translateY(-2px)}.footer-social-link:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--accent)}.footer-info{max-width:420px;margin:0 auto;font-size:.875rem;color:var(--text-muted);line-height:1.6}.landing{padding-bottom:var(--space-12)}.hero{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-12);padding:var(--space-16) var(--space-6) var(--space-16);max-width:1100px;margin:0 auto}.hero-content{flex:1 1 320px;text-align:left;min-width:0}.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:flex-start}.hero-code-side{flex:0 1 360px;min-width:0;display:flex;justify-content:center;align-items:center}.hero-code-side .code-typing{max-width:100%;margin:0;width:100%}.hero-code-side .code-typing-content{font-size:.8rem;min-height:5rem}@media (max-width: 768px){.hero{flex-direction:column;text-align:center;padding:var(--space-12) var(--space-5) var(--space-16);gap:var(--space-3)}.hero-content{flex:0 0 auto;text-align:center}.hero-cta{justify-content:center}.hero-code-side{width:100%;max-width:340px;flex:0 0 auto}}.hero-badge{display:inline-block;font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--text-muted);margin-bottom:var(--space-5);letter-spacing:.06em;text-transform:uppercase}.hero-badge .hero-badge-comment{color:var(--accent)}.hero-title{font-family:var(--font-mono);font-size:clamp(2rem,5.5vw,3rem);font-weight:700;margin:0 0 var(--space-4);letter-spacing:-.04em;line-height:1.15}.hero-title-bracket{color:var(--accent)}.hero-subtitle{font-size:1rem;color:var(--text-muted);line-height:1.7;margin:0 0 var(--space-8);max-width:420px}.code-typing{max-width:420px;margin:0 auto 2rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md),0 0 0 1px #0003}.code-typing-header{display:flex;align-items:center;gap:8px;padding:var(--space-2) var(--space-4);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle)}.code-typing-dot{width:10px;height:10px;border-radius:50%}.code-typing-dot:nth-child(1){background:#ff5f57}.code-typing-dot:nth-child(2){background:#febc2e}.code-typing-dot:nth-child(3){background:#28c840}.code-typing-label{margin-left:var(--space-3);font-family:var(--font-mono);font-size:.6875rem;color:var(--text-muted)}.code-typing-body{display:flex;min-height:5.5rem}.code-typing-gutter{flex-shrink:0;width:2.25rem;padding:var(--space-3) var(--space-2);font-family:var(--font-mono);font-size:.8125rem;line-height:1.6;color:var(--text-muted);text-align:right;-webkit-user-select:none;user-select:none;border-right:1px solid var(--border-subtle);background:#0003}.code-typing-content{margin:0;padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:.8125rem;line-height:1.6;color:var(--text);flex:1}.code-typing-content code{color:var(--text)}.code-typing-cursor{display:inline-block;color:var(--accent);font-weight:700;animation:code-cursor-blink .9s step-end infinite;margin-left:2px}@keyframes code-cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.features{padding:var(--space-16) 0;border-top:1px solid var(--border-subtle)}.section-heading{font-family:var(--font-mono);font-size:.875rem;font-weight:600;letter-spacing:.02em;margin:0 0 var(--space-8);color:var(--text-muted)}.section-heading .mono{color:var(--accent);margin-right:var(--space-2)}.section-heading:after{content:"";display:block;width:2rem;height:3px;background:var(--accent);border-radius:2px;margin-top:var(--space-3)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-5)}.feature-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid transparent;border-radius:var(--radius-lg);padding:var(--space-6);transition:border-color var(--transition),box-shadow var(--transition)}.feature-card:hover{border-left-color:var(--accent);border-color:var(--border);box-shadow:var(--shadow-md)}.feature-icon{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:var(--accent-muted);color:var(--accent);border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:var(--space-4);font-family:var(--font-mono)}.feature-title{font-size:1rem;font-weight:600;margin:0 0 .375rem;letter-spacing:-.01em}.feature-desc{font-size:.9375rem;color:var(--text-muted);line-height:1.55;margin:0}.how-it-works{padding:var(--space-16) 0;border-top:1px solid var(--border-subtle)}.steps{display:flex;flex-direction:column;gap:var(--space-4)}.step{display:flex;gap:var(--space-5);align-items:flex-start;padding:var(--space-5) var(--space-6);background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid transparent;border-radius:var(--radius-lg);transition:border-color var(--transition)}.step:hover{border-left-color:var(--accent);border-color:var(--border)}.step-num{flex-shrink:0;color:var(--accent);font-weight:700;font-size:.875rem}.step h3{font-size:1rem;font-weight:600;margin:0 0 .25rem}.step p{font-size:.9375rem;color:var(--text-muted);margin:0;line-height:1.55}.recent-projects{padding:var(--space-16) 0;border-top:1px solid var(--border-subtle)}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,260px);justify-content:start;gap:var(--space-5);margin-bottom:var(--space-6)}.recent-card{display:flex;flex-direction:column;width:260px;max-width:260px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;color:var(--text);text-decoration:none;transition:border-color var(--transition),box-shadow var(--transition)}.recent-card-thumb{width:100%;height:120px;flex-shrink:0;overflow:hidden;position:relative;background:var(--bg)}.recent-card-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.recent-card-thumb-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--bg) 0%,var(--border-subtle) 100%)}.recent-card-title{font-weight:600;font-size:.9375rem;display:block;margin-bottom:var(--space-1);padding:var(--space-3) var(--space-4) 0;line-height:1.3}.recent-card-desc{font-size:.8125rem;color:var(--text-muted);margin:0 0 var(--space-2);line-height:1.45;padding:0 var(--space-4);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-card-link{font-size:.8125rem;font-weight:500;color:var(--accent);padding:0 var(--space-4) var(--space-3);margin-top:auto;display:block}.recent-card{border-left:3px solid transparent}.recent-card:hover{border-left-color:var(--accent);border-color:var(--border);box-shadow:var(--shadow-md);text-decoration:none;color:var(--text)}.recent-more{text-align:center;margin:0}.recent-more a{font-weight:500}.cta-section{padding:var(--space-16) 0 var(--space-8)}.cta-box{text-align:center;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-sm);border-left:3px solid var(--accent)}.cta-title{font-size:1.375rem;font-weight:600;margin:0 0 var(--space-2);letter-spacing:-.02em}.cta-desc{color:var(--text-muted);margin:0 0 var(--space-6);font-size:.9375rem}.cta-buttons{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.cta-buttons .btn-ghost:hover{color:var(--accent)}@media (max-width: 768px){.nav-inner{padding:var(--space-2) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0));gap:var(--space-2);min-height:48px;flex-wrap:wrap}.nav-brand{order:1;font-size:1.125rem;min-width:0;max-width:calc(100% - 52px)}.nav-brand-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-toggle{display:flex;order:2;margin-left:auto}.nav-links{order:3;flex-basis:100%;flex-direction:column;align-items:stretch;gap:0;max-height:0;overflow:hidden;padding:0;border-top:none;transition:max-height .25s ease}.nav--open .nav-links{max-height:320px;padding:var(--space-2) 0 var(--space-3);border-top:1px solid var(--border-subtle);margin-top:var(--space-2)}.nav.nav--dropdown-open .nav-links{overflow:visible}.nav-links a,.nav-links .btn{padding:var(--space-3) var(--space-4);min-height:48px;display:flex;align-items:center;font-size:.9375rem;border-radius:var(--radius-sm);justify-content:flex-start}.nav-user{flex-direction:column;align-items:stretch;gap:0;padding:var(--space-2) 0 0;border-top:1px solid var(--border-subtle);margin-top:var(--space-2)}.nav-user-name{max-width:none;padding:0 var(--space-4) var(--space-2);font-size:.8125rem;color:var(--text-muted)}.layout-main{padding:var(--space-5) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0))}.layout-main:has(.auth-page){padding-top:var(--space-3);padding-bottom:var(--space-3)}.page-header,.projects-header{margin-bottom:var(--space-5)}.hero{padding:var(--space-8) var(--space-5) var(--space-10);gap:var(--space-3)}.hero-content,.hero-code-side{flex:0 0 auto}.hero-subtitle{max-width:100%}.features{padding:var(--space-8) 0}.section-heading{margin-bottom:var(--space-5)}.features-grid{grid-template-columns:1fr;gap:var(--space-3)}.feature-card{padding:var(--space-4)}.how-it-works{padding:var(--space-8) 0}.steps{gap:var(--space-3)}.step{padding:var(--space-4) var(--space-4)}.recent-projects{padding:var(--space-8) 0}.recent-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));justify-content:stretch;gap:var(--space-3);margin-bottom:var(--space-4)}.recent-card{width:100%;max-width:100%}.cta-section{padding:var(--space-8) 0 var(--space-5)}.cta-box{padding:var(--space-6) var(--space-4)}.cta-desc{margin-bottom:var(--space-4)}.project-thumbnail{max-height:240px}.project-detail-header,.project-thumbnail-section,.project-description-section,.demo-section{margin-bottom:var(--space-5)}.demo-iframe{height:400px}.demo-frame-wrap{min-height:320px}.files-section{margin-top:var(--space-5)}.files-bundle-row,.file-row{padding:var(--space-2) var(--space-3)}.file-row{flex-wrap:wrap;gap:var(--space-2)}.admin-upload{margin-bottom:var(--space-6)}.admin-edit-actions{flex-wrap:wrap}.site-footer{padding:var(--space-6) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0))}.footer-brand{margin-bottom:var(--space-3)}.footer-links{gap:var(--space-3) var(--space-4);margin-bottom:var(--space-3)}}@media (max-width: 480px){body{font-size:15px}.nav-inner{padding:var(--space-2) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0))}.nav-brand{font-size:1.0625rem}.nav--open .nav-links{max-height:360px}.layout-main{padding:var(--space-5) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0))}.layout-main:has(.auth-page){padding-top:var(--space-3);padding-bottom:var(--space-3)}.page-header{margin-bottom:var(--space-4)}.page-title{font-size:1.25rem}.projects-header{margin-bottom:var(--space-4)}.projects-intro{font-size:.9375rem}.home .project-grid{grid-template-columns:1fr;gap:var(--space-3)}.project-card-header,.project-card-desc,.project-card-link{padding-left:var(--space-3);padding-right:var(--space-3)}.project-card-header{padding-top:var(--space-3)}.project-card-link{padding-bottom:var(--space-3)}.project-card-thumb{height:110px}.hero{padding:var(--space-6) var(--space-5) var(--space-8);gap:var(--space-3)}.hero-content,.hero-code-side{flex:0 0 auto}.hero-title{font-size:clamp(1.5rem,8vw,2rem);margin-bottom:var(--space-3)}.hero-subtitle{font-size:.9375rem;margin-bottom:var(--space-4)}.hero-cta{margin-bottom:0}.hero-cta .btn{width:100%;min-height:48px}.hero-code-side,.hero-code-side .code-typing{max-width:100%}.hero-code-side .code-typing-content{font-size:.75rem;overflow-x:auto;word-break:break-all}.code-typing-body{min-height:4.5rem}.code-typing-gutter{width:2rem;padding:var(--space-2) var(--space-1);font-size:.75rem}.section-heading{font-size:.8125rem;margin-bottom:var(--space-4)}.features{padding:var(--space-5) 0}.feature-card{padding:var(--space-3)}.how-it-works{padding:var(--space-5) 0}.steps{gap:var(--space-2)}.step{padding:var(--space-3) var(--space-3);gap:var(--space-3);flex-direction:column;align-items:flex-start}.recent-projects{padding:var(--space-5) 0}.recent-grid{grid-template-columns:1fr;gap:var(--space-3);margin-bottom:var(--space-3)}.recent-card-thumb{height:90px}.recent-card-title{padding:var(--space-2) var(--space-3) 0}.recent-card-desc{padding:0 var(--space-3);margin-bottom:var(--space-1)}.recent-card-link{padding:0 var(--space-3) var(--space-2)}.cta-section{padding:var(--space-5) 0 var(--space-4)}.cta-box{padding:var(--space-5) var(--space-4);margin:0 var(--space-1)}.cta-title{font-size:1.125rem;margin-bottom:var(--space-1)}.cta-desc{font-size:.875rem;margin-bottom:var(--space-3)}.cta-buttons{gap:var(--space-2)}.cta-buttons .btn{width:100%;min-height:48px}.auth-page{padding:var(--space-3) var(--space-2);min-height:50vh}.auth-page-content{max-width:100%}.auth-code-bg{padding:0 var(--space-2)}.auth-code-bg-line{font-size:.6875rem;color:#cbd5e161}.auth-code-bg-num{color:#94a3b866}.auth-card{padding:var(--space-4) var(--space-4)}.auth-title{font-size:1.125rem;margin-bottom:var(--space-2)}.auth-form label{margin-bottom:var(--space-3)}.input{padding:var(--space-2) var(--space-3);min-height:48px;font-size:16px}.project-detail-header,.project-thumbnail-section{margin-bottom:var(--space-4)}.project-thumbnail{max-height:180px;border-radius:var(--radius-md)}.project-description-section{margin-bottom:var(--space-4)}.project-description{padding:var(--space-3);font-size:.875rem}.section-title{margin-bottom:var(--space-2)}.project-demo-cta{margin-top:var(--space-3)}.btn-view-demo{width:100%;min-height:48px;padding:var(--space-3)}.demo-section{margin-bottom:var(--space-4)}.demo-frame-wrap{min-height:260px;border-radius:var(--radius-md)}.demo-iframe{height:300px}.files-section{margin-top:var(--space-4)}.files-bundle-row{padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2)}.file-row{padding:var(--space-2) var(--space-3)}.file-filename{font-size:.875rem;word-break:break-all}.back-link{min-height:44px;margin-bottom:var(--space-2);display:inline-flex;align-items:center}.empty-state{padding:var(--space-4) var(--space-3)}.admin-upload{margin-bottom:var(--space-5)}.admin-project-list{gap:var(--space-3)}.admin-project-card{padding:var(--space-3)}.admin-project-head{flex-wrap:wrap;gap:var(--space-2)}.admin-project-desc{margin-top:var(--space-2)}.admin-project-actions{flex-wrap:wrap;gap:var(--space-2)}.admin-edit-actions .btn{min-height:44px}.site-footer{padding:var(--space-5) var(--space-5);padding-left:calc(var(--space-5) + env(safe-area-inset-left,0));padding-right:calc(var(--space-5) + env(safe-area-inset-right,0))}.footer-brand{font-size:.875rem;margin-bottom:var(--space-2)}.footer-links{flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-2)}.footer-links a{min-height:44px;display:inline-flex;align-items:center;justify-content:center}.modal-overlay{padding:var(--space-4);padding-left:calc(var(--space-4) + env(safe-area-inset-left,0));padding-right:calc(var(--space-4) + env(safe-area-inset-right,0));padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0));align-items:center;justify-content:center}.modal-box{max-height:calc(100vh - var(--space-8));width:100%;border-radius:var(--radius-lg);border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle)}.modal-header{padding:var(--space-3) var(--space-4)}.modal-body:has(.demo-modal-frame-wrap){min-height:50vh;flex:1}.demo-modal-frame-wrap{min-height:280px}.demo-modal-iframe{min-height:260px}}@media (max-width: 1024px) and (min-width: 769px){.layout-main{padding:var(--space-6) var(--space-5)}.features,.how-it-works,.recent-projects{padding:var(--space-10) 0}.recent-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.recent-card{width:100%;max-width:100%}.cta-section{padding:var(--space-10) 0 var(--space-6)}}
