.layout{display:flex;flex-direction:column;min-height:100dvh;background:var(--color-bg-primary)}.layout-header{position:sticky;top:0;z-index:var(--z-dropdown);background:var(--color-bg-primary);border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-lg)}.layout-header-content{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);max-width:768px;margin:0 auto}.layout-logo{font-size:var(--font-size-lg);color:var(--color-primary)}.layout-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0;letter-spacing:.05em}.layout-main{flex:1;display:flex;flex-direction:column;max-width:768px;width:100%;margin:0 auto;padding:var(--spacing-lg)}.layout-footer{display:none}.loading-container{display:flex;align-items:center;justify-content:center;flex:1;min-height:200px}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:inherit;font-weight:600;border-radius:var(--radius-xl);transition:all var(--transition-base);cursor:pointer;border:none;text-decoration:none;white-space:nowrap;letter-spacing:.02em}.btn--sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);min-height:36px;border-radius:var(--radius-lg)}.btn--md{padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-base);min-height:44px}.btn--lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md);min-height:52px;border-radius:var(--radius-2xl)}.btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:var(--color-bg-primary);box-shadow:0 4px 20px #00d4aa4d}.btn--primary:hover:not(:disabled){box-shadow:0 6px 30px #00d4aa66;transform:translateY(-2px)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #00d4aa4d}.btn--secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-bg-card);border-color:var(--color-primary)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn--full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn--loading{position:relative;color:transparent}.btn-spinner{position:absolute;width:20px;height:20px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--color-bg-primary);border-radius:50%;animation:spin .8s linear infinite}.progress-indicator{display:flex;flex-direction:column;gap:var(--spacing-sm)}.progress-text{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.progress-count{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.progress-current{font-weight:600;color:var(--color-primary);font-size:var(--font-size-lg)}.progress-separator,.progress-total{color:var(--color-text-muted)}.progress-bar-container{position:relative;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar-dots{position:absolute;top:0;left:0;right:0;height:100%;display:flex;justify-content:space-between;padding:0 2px}.progress-dot{width:4px;height:100%;background:transparent;border-radius:var(--radius-full);transition:all var(--transition-base)}.progress-dot--complete{background:#ffffff4d}.progress-dot--current{background:#fff;box-shadow:0 0 8px #fff9}.camera-engine{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.camera-engine__video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center}.camera-engine__canvas{position:absolute;pointer-events:none;visibility:hidden}.camera-engine__loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000e6;color:#fff;gap:1rem}.camera-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.camera-engine__flash{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;animation:flash .5s ease-out;pointer-events:none}@keyframes flash{0%{opacity:.8}to{opacity:0}}.camera-controls{position:absolute;bottom:2rem;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:2rem;padding:0 2rem}.camera-controls__flip{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;color:#fff;cursor:pointer;transition:all .2s ease}.camera-controls__flip:hover:not(:disabled){background:#000c;border-color:#ffffff80;transform:scale(1.05)}.camera-controls__flip:disabled{opacity:.5;cursor:not-allowed}.camera-controls__flip svg{width:24px;height:24px}.camera-controls__flip span{font-size:.75rem;font-weight:500}.camera-controls__shutter{position:relative;width:80px;height:80px;padding:0;background:transparent;border:none;cursor:pointer;transition:transform .2s ease}.camera-controls__shutter:hover:not(:disabled){transform:scale(1.1)}.camera-controls__shutter:active:not(:disabled){transform:scale(.95)}.camera-controls__shutter:disabled{opacity:.6;cursor:not-allowed}.shutter__outer{display:flex;align-items:center;justify-content:center;width:100%;height:100%;border:4px solid #fff;border-radius:50%;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.shutter__inner{width:64px;height:64px;background:#fff;border-radius:50%;transition:transform .2s ease}.camera-controls__shutter--capturing .shutter__inner{transform:scale(.8)}.shutter__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.camera-controls__info{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1rem;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;color:#fff;min-width:100px}.info__view-name{font-size:.875rem;font-weight:600}.info__view-index{font-size:.75rem;opacity:.8}.camera-engine__error-banner{position:absolute;top:1rem;left:1rem;right:1rem;padding:1rem;background:#dc2626e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;color:#fff;font-size:.875rem;text-align:center;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.camera-engine--error{display:flex;align-items:center;justify-content:center}.camera-error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;max-width:400px;text-align:center;color:#fff}.camera-error__icon{font-size:4rem}.camera-error__title{font-size:1.5rem;font-weight:700;margin:0}.camera-error__message{font-size:1rem;opacity:.8;line-height:1.5;margin:0}.camera-error__button{margin-top:1rem;padding:.75rem 1.5rem;background:#fff;color:#000;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.camera-error__button:hover{background:#f0f0f0;transform:scale(1.05)}.camera-error__button:active{transform:scale(.95)}@media(max-width:768px){.camera-controls{bottom:1rem;gap:1rem;padding:0 1rem}.camera-controls__shutter{width:72px;height:72px}.shutter__inner{width:56px;height:56px}.camera-controls__flip svg{width:20px;height:20px}.camera-error{padding:1.5rem}.camera-error__icon{font-size:3rem}.camera-error__title{font-size:1.25rem}.camera-error__message{font-size:.875rem}}@media(prefers-color-scheme:dark){.camera-controls__flip,.camera-controls__info{background:#ffffff1a;border-color:#fff3}.camera-controls__flip:hover:not(:disabled),.camera-controls__info:hover{background:#fff3;border-color:#ffffff4d}}.camera-controls__shutter:focus-visible,.camera-controls__flip:focus-visible{outline:2px solid #fff;outline-offset:4px}.camera-engine__video,.camera-engine__flash{will-change:transform;transform:translateZ(0)}.photo-review{position:relative;width:100%;height:100%;background-color:#000;display:flex;flex-direction:column;overflow:hidden}.photo-review__preview{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.photo-review__image{width:100%;height:100%;object-fit:cover;object-position:center}.photo-review__info{position:absolute;top:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 2rem;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#fff;z-index:10}.photo-review__view-name{font-size:1.25rem;font-weight:600;letter-spacing:.5px}.photo-review__progress{font-size:.875rem;opacity:.9}.photo-review__actions{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);display:flex;gap:2rem;z-index:10}.photo-review__button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 2rem;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px}.photo-review__button svg{width:32px;height:32px}.photo-review__button--retake{background:#ff3b30e6;color:#fff}.photo-review__button--retake:hover{background:#ff3b30;transform:scale(1.05)}.photo-review__button--retake:active{transform:scale(.98)}.photo-review__button--confirm{background:#34c759e6;color:#fff}.photo-review__button--confirm:hover{background:#34c759;transform:scale(1.05)}.photo-review__button--confirm:active{transform:scale(.98)}@media(max-width:768px){.photo-review__info{top:1rem;padding:.75rem 1.5rem}.photo-review__view-name{font-size:1rem}.photo-review__progress{font-size:.75rem}.photo-review__actions{bottom:2rem;gap:1.5rem}.photo-review__button{padding:1rem 1.5rem;min-width:120px;font-size:.875rem}.photo-review__button svg{width:24px;height:24px}}.capture-gallery{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.capture-gallery__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.capture-gallery__container{position:relative;width:100%;max-width:900px;max-height:90vh;background:#1a1a1a;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.capture-gallery__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:#252525;border-bottom:1px solid rgba(255,255,255,.1)}.capture-gallery__header-actions{display:flex;align-items:center;gap:1rem}.capture-gallery__title{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.capture-gallery__upload-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#00d4aa,#00a884);color:#fff;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00d4aa4d}.capture-gallery__upload-btn:hover:not(:disabled){background:linear-gradient(135deg,#00ecc0,#00c098);box-shadow:0 6px 16px #00d4aa66;transform:translateY(-2px)}.capture-gallery__upload-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.capture-gallery__upload-btn svg{width:18px;height:18px}.capture-gallery__spinner{animation:spin 1s linear infinite}.capture-gallery__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;color:#fff}.capture-gallery__close:disabled{opacity:.4;cursor:not-allowed}.capture-gallery__close svg{width:20px;height:20px}.capture-gallery__close:hover:not(:disabled){background:#fff3;transform:scale(1.05)}.capture-gallery__grid{flex:1;overflow-y:auto;padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem;align-content:start}.capture-gallery__item{position:relative;aspect-ratio:9 / 16;border-radius:12px;overflow:visible;transition:all .2s ease;background:#2a2a2a}.capture-gallery__item--captured{border:2px solid rgba(52,199,89,.5);cursor:default;opacity:1}.capture-gallery__item--captured:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0006;border-color:#34c759cc}.capture-gallery__item--empty{border:2px dashed rgba(255,255,255,.15);cursor:default;opacity:.4;background:#1a1a1a}.capture-gallery__item--current{border-color:#007affcc;box-shadow:0 0 0 3px #007aff4d}.capture-gallery__media{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:12px}.capture-gallery__image{width:100%;height:100%;object-fit:cover;display:block;border-radius:12px}.capture-gallery__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffff26;border-radius:12px}.capture-gallery__placeholder svg{width:40px;height:40px;opacity:.5}.capture-gallery__label{position:absolute;bottom:0;left:0;right:0;padding:.75rem .5rem;background:linear-gradient(to top,rgba(0,0,0,.95),rgba(0,0,0,.7) 70%,transparent);display:flex;flex-direction:column;gap:.25rem;color:#fff;border-radius:0 0 12px 12px;pointer-events:none}.capture-gallery__view-number{font-size:.7rem;font-weight:600;opacity:.7;line-height:1}.capture-gallery__view-info{display:flex;align-items:center;gap:.5rem}.capture-gallery__view-name{font-size:.75rem;font-weight:700;color:#34c759;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.8)}.capture-gallery__current-indicator{font-size:.65rem;font-weight:600;color:#007aff;text-transform:uppercase;letter-spacing:.5px;padding:.125rem .375rem;background:#007aff33;border-radius:4px;border:1px solid rgba(0,122,255,.5)}.capture-gallery__actions{position:absolute;top:.5rem;right:.5rem;display:flex;flex-direction:column;gap:.5rem;opacity:0;transition:opacity .2s ease;z-index:10}.capture-gallery__item--captured:hover .capture-gallery__actions{opacity:1}.capture-gallery__action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.capture-gallery__action-btn:disabled{opacity:.4;cursor:not-allowed}.capture-gallery__action-btn svg{width:16px;height:16px}.capture-gallery__action-btn--upload:hover:not(:disabled){background:#00d4aae6;transform:scale(1.1)}.capture-gallery__action-btn--upload.capture-gallery__action-btn--error{background:#ff9500cc;animation:pulseError 2s ease-in-out infinite}.capture-gallery__action-btn--upload.capture-gallery__action-btn--error:hover{background:#ff9500f2;transform:scale(1.1);animation:none}@keyframes pulseError{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.capture-gallery__action-btn--recapture:hover{background:#007affe6;transform:scale(1.1)}.capture-gallery__action-btn--delete:hover{background:#ff3b30e6;transform:scale(1.1)}.capture-gallery__upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border-radius:12px}.capture-gallery__upload-progress{width:70%;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.capture-gallery__upload-progress-bar{height:100%;background:linear-gradient(90deg,#00d4aa,#00ecc0);transition:width .3s ease;border-radius:2px}.capture-gallery__upload-percent{font-size:.875rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8)}.capture-gallery__upload-success{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;background:#34c759f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;animation:uploadSuccess .3s ease;z-index:20;pointer-events:none}.capture-gallery__upload-success svg{width:18px;height:18px;pointer-events:none}@keyframes uploadSuccess{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.capture-gallery__upload-error{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;background:#ff3b30f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:help;animation:uploadError .3s ease;z-index:20}.capture-gallery__upload-error svg{width:18px;height:18px;pointer-events:none}.capture-gallery__error-tooltip{position:absolute;top:100%;right:0;margin-top:.5rem;padding:.5rem .75rem;background:#ff3b30fa;color:#fff;font-size:.75rem;font-weight:500;border-radius:6px;white-space:normal;max-width:220px;min-width:150px;word-wrap:break-word;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;pointer-events:none;z-index:30;box-shadow:0 4px 16px #000000b3;border:1px solid rgba(255,255,255,.1)}.capture-gallery__upload-error:hover .capture-gallery__error-tooltip{opacity:1;visibility:visible}@keyframes uploadError{0%,20%,40%,60%,80%{transform:translate(0)}10%,50%{transform:translate(-4px)}30%,70%{transform:translate(4px)}to{transform:translate(0)}}@media(max-width:768px){.capture-gallery__grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;padding:1rem}.capture-gallery__header{padding:1rem}.capture-gallery__title{font-size:1rem}.capture-gallery__view-name{font-size:.7rem}}.home-page{display:flex;flex-direction:column;align-items:center;justify-content:space-between;min-height:calc(100dvh - 80px);padding:var(--spacing-xl) var(--spacing-lg);text-align:center}.home-logo{margin-top:var(--spacing-xl)}.home-logo-icon{width:80px;height:80px;color:var(--color-primary);animation:pulse-glow 3s ease-in-out infinite}.home-logo-icon svg{width:100%;height:100%}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 8px var(--color-primary-glow));transform:scale(1)}50%{filter:drop-shadow(0 0 20px var(--color-primary-glow));transform:scale(1.02)}}.home-branding{margin:var(--spacing-lg) 0}.home-title{font-size:var(--font-size-4xl);font-weight:700;letter-spacing:.1em;margin-bottom:var(--spacing-xs);display:flex;justify-content:center;gap:var(--spacing-sm)}.home-title-halo{color:var(--color-text-primary)}.home-title-eye{color:var(--color-primary)}.home-subtitle{font-size:var(--font-size-md);color:var(--color-text-muted);letter-spacing:.2em;text-transform:uppercase}.home-features{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%;max-width:360px;margin:var(--spacing-xl) 0}.home-feature-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.home-feature-card:hover{border-color:var(--color-primary);transform:translate(4px);box-shadow:-4px 0 0 var(--color-primary)}.home-feature-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 100%);border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0}.home-feature-icon svg{width:22px;height:22px}.home-feature-content{text-align:left}.home-feature-content h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.home-feature-content p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.home-cta{width:100%;max-width:360px;margin-top:auto}.home-cta-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-md)}.home-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:var(--spacing-md)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.home-loading p{color:var(--color-text-muted);font-size:var(--font-size-sm)}.home-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);text-align:center}.home-error h2{color:var(--color-error);font-size:var(--font-size-lg)}.home-error p{color:var(--color-text-muted)}.home-pending-session{display:flex;flex-direction:column;gap:var(--spacing-md)}.pending-session-info h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.session-progress{display:flex;flex-direction:column;gap:var(--spacing-xs)}.progress-bar{width:100%;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:var(--radius-sm);transition:width var(--transition-base)}.progress-text{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center}.home-default-template{display:flex;flex-direction:column;gap:var(--spacing-md)}.template-info h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.template-info p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.home-template-selection{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.home-template-selection h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.template-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto}.template-option{padding:var(--spacing-md);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left;width:100%;font-family:inherit;font-size:inherit;color:inherit}.template-option:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.template-option.selected{border-color:var(--color-primary);background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-tertiary) 100%)}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.template-header h4{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0}.template-code{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-weight:500}.template-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;line-height:1.4}.home-error-message{padding:var(--spacing-md);background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);text-align:center}.home-error-message p{color:var(--color-error);font-size:var(--font-size-sm);margin:0}.home-footer{margin-top:var(--spacing-lg)}.home-version{font-size:var(--font-size-xs);color:var(--color-text-muted);letter-spacing:.1em}:root{--color-primary: #00d4aa;--color-primary-hover: #00e6b8;--color-primary-active: #00c49a;--color-primary-glow: rgba(0, 212, 170, .3);--color-accent: #00bcd4;--color-accent-secondary: #26c6da;--color-success: #4caf50;--color-success-light: #81c784;--color-warning: #ff9800;--color-error: #f44336;--color-bg-primary: #0a0a0a;--color-bg-secondary: #141414;--color-bg-tertiary: #1e1e1e;--color-bg-card: #1a1a1a;--color-bg-overlay: rgba(0, 0, 0, .85);--color-text-primary: #ffffff;--color-text-secondary: #b0b0b0;--color-text-muted: #666666;--color-text-hint: #888888;--color-border: #2a2a2a;--color-border-light: #333333;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .625rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--shadow-glow: 0 0 20px var(--color-primary-glow);--shadow-glow-strong: 0 0 40px var(--color-primary-glow);--z-base: 1;--z-dropdown: 100;--z-overlay: 200;--z-modal: 300;--z-toast: 400}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed;opacity:.5}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background:var(--color-primary);color:var(--color-bg-primary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.gradient-text{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass{background:#1a1a1acc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border)}
