:root{--font-display: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "DM Sans", "PingFang SC", "Noto Sans SC", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "Geist Mono", "SF Mono", "Fira Code", monospace}:root{--bg: #FFF8F0;--surface: #FFFAF5;--surface-raised: #FFFFFF;--text: #2D2420;--text-muted: #8C7B6F;--accent: #FF6B5B;--accent-hover: #E85A4A;--accent-text: #FFFFFF;--secondary: #66B88C;--secondary-hover: #57A67B;--border: #E8DDD4;--success: #4CAF50;--warning: #FF9800;--error: #E53935;--shadow-sm: 0 1px 3px rgba(45, 36, 32, .06);--shadow-md: 0 4px 12px rgba(45, 36, 32, .08);--shadow-lg: 0 8px 24px rgba(45, 36, 32, .1);--grain-opacity: .03}@media(prefers-color-scheme:dark){:root{--bg: #1A1614;--surface: #252220;--surface-raised: #2E2A28;--text: #F5EDE6;--text-muted: #9C8B7F;--accent: #FF7D6F;--accent-hover: #FF9080;--accent-text: #1A1614;--secondary: #7CCAA0;--secondary-hover: #8DD6AE;--border: #3A3432;--success: #66BB6A;--warning: #FFA726;--error: #EF5350;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--grain-opacity: .04}}:root{--sp-2xs: 2px;--sp-xs: 4px;--sp-sm: 8px;--sp-md: 16px;--sp-lg: 24px;--sp-xl: 32px;--sp-2xl: 48px;--sp-3xl: 64px}:root{--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px}:root{--ease-enter: cubic-bezier(0, 0, .2, 1);--ease-exit: cubic-bezier(.4, 0, 1, 1);--ease-move: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-micro: .1s;--dur-short: .2s;--dur-medium: .35s;--dur-long: .5s}:root{--max-width: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-size:16px;line-height:1.5;color:var(--text);background-color:var(--bg);min-height:100dvh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}img,video{max-width:100%;display:block}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}.t-display{font-family:var(--font-display);font-weight:700;font-size:48px;line-height:1.1;letter-spacing:-.02em}.t-heading{font-family:var(--font-display);font-weight:700;font-size:32px;line-height:1.2;letter-spacing:-.01em}.t-title{font-family:var(--font-display);font-weight:600;font-size:24px;line-height:1.3}.t-subtitle{font-family:var(--font-display);font-weight:500;font-size:20px;line-height:1.4}.t-body{font-size:16px;line-height:1.5}.t-small{font-size:14px;line-height:1.5}.t-caption{font-size:12px;line-height:1.5;color:var(--text-muted)}.t-muted{color:var(--text-muted)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--sp-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-sm);padding:var(--sp-sm) var(--sp-lg);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:600;font-size:16px;line-height:1;transition:all var(--dur-short) var(--ease-enter);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:active{transform:scale(.96)}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:var(--secondary-hover)}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface);border-color:var(--text-muted)}.btn-large{padding:var(--sp-md) var(--sp-xl);font-size:18px;border-radius:var(--radius-lg)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-short) var(--ease-enter),transform var(--dur-short) var(--ease-spring)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.input{width:100%;padding:var(--sp-sm) var(--sp-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:16px;color:var(--text);transition:border-color var(--dur-short) var(--ease-enter),box-shadow var(--dur-short) var(--ease-enter);outline:none}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff6b5b26}.input::placeholder{color:var(--text-muted)}#app{min-height:100dvh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.app-header-inner{max-width:var(--max-width);margin:0 auto;padding:var(--sp-sm) var(--sp-md);display:flex;align-items:center;justify-content:space-between;height:56px}.app-logo{font-family:var(--font-display);font-weight:900;font-size:20px;color:var(--text);display:flex;align-items:center;gap:var(--sp-sm)}.app-logo-icon{width:28px;height:28px}.app-main{flex:1;padding:var(--sp-lg) 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes springIn{0%{opacity:0;transform:scale(.9)}60%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{to{transform:rotate(360deg)}}.anim-fade-in{animation:fadeIn var(--dur-medium) var(--ease-enter)}.anim-slide-up{animation:slideUp var(--dur-medium) var(--ease-enter)}.anim-spring-in{animation:springIn var(--dur-long) var(--ease-spring)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.wizard{max-width:560px;margin:0 auto;padding:var(--sp-2xl) var(--sp-md)}.wizard-steps{display:flex;align-items:center;justify-content:center;gap:var(--sp-sm);margin-bottom:var(--sp-2xl)}.wizard-step{width:8px;height:8px;border-radius:var(--radius-full);background:var(--border);transition:all var(--dur-short) var(--ease-enter)}.wizard-step.active{width:32px;background:var(--accent)}.wizard-step.done{background:var(--secondary)}.wizard-content{text-align:center}.upload-area{position:relative;border:2px dashed var(--border);border-radius:var(--radius-xl);padding:var(--sp-3xl) var(--sp-lg);text-align:center;cursor:pointer;transition:all var(--dur-short) var(--ease-enter);background:var(--surface)}.upload-area:hover,.upload-area.drag-over{border-color:var(--accent);background:var(--surface-raised)}.upload-area.drag-over{transform:scale(1.01)}.upload-icon{width:64px;height:64px;margin:0 auto var(--sp-md);color:var(--text-muted)}.upload-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.view-toggle{display:flex;gap:var(--sp-sm);justify-content:center;margin-top:var(--sp-lg)}.view-toggle-btn{padding:var(--sp-sm) var(--sp-md);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);font-family:var(--font-display);font-weight:500;font-size:14px;transition:all var(--dur-short) var(--ease-enter)}.view-toggle-btn.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.preview-image{max-width:280px;margin:0 auto var(--sp-lg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.preview-image img{width:100%;aspect-ratio:9 / 16;object-fit:cover}.generating{padding:var(--sp-3xl) 0}.generating-avatar{width:120px;height:120px;margin:0 auto var(--sp-lg);border-radius:var(--radius-full);background:var(--surface);display:flex;align-items:center;justify-content:center;position:relative}.generating-avatar:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-full);border:3px solid transparent;border-top-color:var(--accent);animation:spin 1s linear infinite}.generating-progress{width:200px;height:4px;margin:var(--sp-md) auto;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.generating-progress-bar{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--dur-long) var(--ease-move)}.complete-avatar{width:340px;height:400px;margin:0 auto var(--sp-lg);position:relative;border-radius:var(--radius-xl);overflow:hidden;background:#fff}.complete-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;border-radius:var(--radius-xl);box-shadow:inset 0 0 30px 20px var(--bg)}.complete-avatar video{width:100%;height:100%;object-fit:contain}@media(prefers-color-scheme:dark){.complete-avatar{background:#1a1614}}.complete-glow{position:absolute;top:-30px;right:-30px;bottom:-30px;left:-30px;border-radius:var(--radius-full);background:radial-gradient(circle,rgba(255,107,91,.12) 0%,transparent 65%);pointer-events:none;animation:pulse 3s ease-in-out infinite;z-index:-1}.name-input-group{max-width:300px;margin:0 auto var(--sp-lg)}.color-picker{display:flex;gap:var(--sp-sm);justify-content:center;margin-bottom:var(--sp-lg)}.color-swatch{width:32px;height:32px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--dur-short) var(--ease-enter)}.color-swatch.active{border-color:var(--text);transform:scale(1.15)}.gallery-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--sp-lg);gap:var(--sp-md)}.gallery-sort{display:flex;gap:var(--sp-xs)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-md)}.gallery-empty{grid-column:1 / -1;text-align:center;padding:var(--sp-3xl) 0}.avatar-card{cursor:pointer}.avatar-card-media{position:relative;aspect-ratio:3 / 4;background:var(--surface);overflow:hidden}.avatar-card-video,.avatar-card-poster{width:100%;height:100%;object-fit:cover}.avatar-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface)}.avatar-card-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center bottom,color-mix(in srgb,var(--avatar-color, var(--secondary)) 15%,transparent) 0%,transparent 60%);pointer-events:none}.avatar-card-info{padding:var(--sp-sm) var(--sp-md) var(--sp-md)}.avatar-card-name{margin-bottom:var(--sp-2xs)}.avatar-card-meta{margin-bottom:var(--sp-xs)}.avatar-card-stats{display:flex;gap:var(--sp-md)}.avatar-badge-ai{display:inline-block;padding:1px 6px;border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-text);font-size:10px;font-weight:700;vertical-align:middle;margin-left:var(--sp-xs)}.viewer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-lg);gap:var(--sp-md)}.viewer-title{display:flex;align-items:center;gap:var(--sp-sm)}.viewer-stage{position:relative;width:100%;height:480px;border-radius:var(--radius-xl);overflow:hidden;background:#fff}.viewer-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:linear-gradient(to right,var(--bg) 0%,transparent 3%,transparent 97%,var(--bg) 100%),linear-gradient(to bottom,var(--bg) 0%,transparent 4%,transparent 100%)}.viewer-stage:after{content:"";position:absolute;bottom:20px;left:15%;right:15%;height:8px;border-radius:50%;background:radial-gradient(ellipse,rgba(0,0,0,.06) 0%,transparent 70%);z-index:1}@media(prefers-color-scheme:dark){.viewer-stage{background:#1a1614}}.viewer-avatar{position:absolute;bottom:20px;left:0;width:220px;height:360px;transition:none;will-change:transform;z-index:1}.viewer-avatar video{width:100%;height:100%;object-fit:contain}.viewer-effects-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.skill-panel{margin-top:var(--sp-lg)}.skill-buttons{display:flex;gap:var(--sp-sm);justify-content:center;flex-wrap:wrap}.skill-btn{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2xs);padding:var(--sp-sm) var(--sp-md);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);transition:all var(--dur-short) var(--ease-enter);min-width:64px}.skill-btn:hover{background:var(--surface-raised);border-color:var(--skill-color, var(--secondary));box-shadow:0 0 8px color-mix(in srgb,var(--skill-color, var(--secondary)) 20%,transparent)}.skill-btn:active{transform:scale(.92)}.skill-btn-icon{font-size:24px;line-height:1}.skill-btn-label{font-size:11px;color:var(--text-muted);font-family:var(--font-display);font-weight:500}.comments-section{margin-top:var(--sp-xl);max-width:640px;margin-left:auto;margin-right:auto}.comments-header{margin-bottom:var(--sp-md)}.comments-input-group{display:flex;gap:var(--sp-sm);align-items:center;margin-bottom:var(--sp-lg)}.comments-avatar-mini{width:36px;height:36px;border-radius:var(--radius-full);background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.comments-input{flex:1}.comments-list{display:flex;flex-direction:column;gap:var(--sp-md)}.comment{display:flex;gap:var(--sp-sm);align-items:flex-start}.comment-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;flex-shrink:0}.comment-body{flex:1;min-width:0}.comment-meta{display:flex;gap:var(--sp-sm);align-items:baseline;margin-bottom:var(--sp-2xs)}.comment-author{font-weight:600;font-family:var(--font-display)}.comment-time{flex-shrink:0}.comment-text{font-size:15px;line-height:1.5;word-break:break-word}@keyframes shake{0%,to{transform:translate(0) rotate(0)}10%{transform:translate(-4px) rotate(-2deg)}30%{transform:translate(4px) rotate(2deg)}50%{transform:translate(-3px) rotate(-1deg)}70%{transform:translate(3px) rotate(1deg)}90%{transform:translate(-1px) rotate(0)}}.anim-shake{animation:shake .5s ease-in-out}.profile{max-width:640px;margin:0 auto;padding:var(--sp-lg) var(--sp-md)}.profile-header{text-align:center;margin-bottom:var(--sp-xl)}.profile-avatar-large{width:80px;height:80px;margin:0 auto;border-radius:var(--radius-full);background:var(--surface);border:2px solid var(--border);display:flex;align-items:center;justify-content:center}.profile-stats{display:flex;justify-content:center;gap:var(--sp-2xl)}.profile-stat{text-align:center}.profile-empty{text-align:center;padding:var(--sp-xl) 0;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.profile-companion-list{display:flex;flex-direction:column;gap:var(--sp-md)}.profile-companion-card{display:flex;align-items:center;gap:var(--sp-lg);padding:var(--sp-md);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.profile-companion-media{width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:var(--surface)}.profile-companion-media video,.profile-companion-media img{width:100%;height:100%;object-fit:cover}.profile-companion-info{flex:1;min-width:0}.profile-companion-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--sp-md)}.modal{background:var(--surface-raised);border-radius:var(--radius-xl);padding:var(--sp-xl);width:100%;max-width:400px;position:relative;box-shadow:var(--shadow-lg)}.modal-close{position:absolute;top:var(--sp-md);right:var(--sp-md);font-size:20px;color:var(--text-muted);opacity:.6}.modal-close:hover{opacity:1}.user-avatar-btn{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent);color:var(--accent-text);font-weight:700;font-size:14px;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;transition:transform var(--dur-short) var(--ease-spring)}.user-avatar-btn:hover{transform:scale(1.1)}.mobile-tab-bar{display:none}@media(max-width:640px){.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface-raised);border-top:1px solid var(--border);padding:var(--sp-xs) 0 env(safe-area-inset-bottom,var(--sp-xs));z-index:200;justify-content:space-around}.mobile-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-xs) var(--sp-sm);color:var(--text-muted);font-size:10px;font-family:var(--font-display);font-weight:500;text-decoration:none;transition:color var(--dur-short) var(--ease-enter)}.mobile-tab.active{color:var(--accent)}.mobile-tab-icon{font-size:22px;line-height:1}.app-header nav{display:none!important}.app-main{padding-bottom:72px}}@media(max-width:640px){.t-display{font-size:32px}.t-heading{font-size:24px}.t-title{font-size:20px}.wizard{padding:var(--sp-lg) var(--sp-md)}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-sm)}.gallery-header{flex-direction:column}.viewer-stage{height:340px}.viewer-avatar{width:160px;height:260px}.skill-btn{min-width:52px;padding:var(--sp-xs) var(--sp-sm)}}.companion-setup{max-width:600px;margin:0 auto;padding:var(--sp-2xl) 0}.companion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-md)}.companion-card{background:var(--surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:box-shadow var(--dur-short) var(--ease-enter)}.companion-card:hover{box-shadow:var(--shadow-md)}.companion-card-media{aspect-ratio:16 / 9;overflow:hidden;background:var(--bg)}.companion-card-media video,.companion-card-media img{width:100%;height:100%;object-fit:cover}.companion-card-info{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-sm) var(--sp-md)}.companion-card-delete{opacity:.4;font-size:14px;cursor:pointer;background:none;border:none;color:var(--text);transition:opacity var(--dur-micro)}.companion-card-delete:hover{opacity:1;color:var(--error)}.companion-settings{display:flex;flex-wrap:wrap;gap:var(--sp-lg);align-items:center}.companion-scene-picker{display:flex;flex-wrap:wrap;gap:var(--sp-sm)}.companion-scene-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-sm) var(--sp-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--dur-short) var(--ease-enter);min-width:72px}.companion-scene-btn:hover{border-color:var(--accent);background:var(--surface-raised)}.companion-scene-btn.active{border-color:var(--accent);background:var(--accent);color:var(--accent-text)}.companion-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#fff;overflow:hidden;cursor:pointer}.companion-video-wrap{position:absolute;top:0;right:0;bottom:0;left:0;background:#000}.companion-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:bottom center;opacity:0;transition:opacity .8s ease}.companion-video.active{opacity:1}.companion-fx-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}.companion-ripple{position:absolute;width:40px;height:40px;margin-left:-20px;margin-top:-20px;border-radius:50%;border:2px solid rgba(255,255,255,.4);pointer-events:none;z-index:1;animation:companion-ripple-out .6s ease-out forwards}.companion-ripple-large{animation:companion-ripple-out .8s ease-out forwards}@keyframes companion-ripple-out{0%{transform:scale(.5);opacity:1}to{transform:scale(4);opacity:0}}.companion-ripple-large{border-color:#ff6b5b80}@keyframes companion-pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.1);opacity:1}}.qr-waiting-dot{width:8px;height:8px;border-radius:50%;background:var(--accent, #007aff);animation:qr-blink 1.4s ease-in-out infinite}@keyframes qr-blink{0%,to{opacity:.3}50%{opacity:1}}.companion-bubble{position:absolute;transform:translate(-50%,-100%);background:#ffffffeb;color:#1d1d1f;padding:18px 32px;border-radius:28px;font-size:28px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:10;box-shadow:0 2px 16px #0000001f;animation:bubble-in .35s cubic-bezier(.34,1.56,.64,1) forwards}.companion-bubble:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:12px;height:12px;background:#ffffffeb;border-radius:50%}.companion-bubble-out{animation:bubble-out .4s ease-in forwards}@keyframes bubble-in{0%{opacity:0;transform:translate(-50%,-80%) scale(.5)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}@keyframes bubble-out{0%{opacity:1;transform:translate(-50%,-100%) scale(1)}to{opacity:0;transform:translate(-50%,-120%) scale(.8)}}.companion-top-bar{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;z-index:10;opacity:0;transition:opacity .3s ease}.companion-fullscreen:hover .companion-top-bar,.companion-fullscreen:active .companion-top-bar{opacity:1}.companion-nav-btn{display:flex;align-items:center;gap:4px;background:#ffffff26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:8px 14px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;text-shadow:0 1px 4px rgba(0,0,0,.3);transition:background .2s}.companion-nav-btn:hover{background:#ffffff40}.companion-branding{font-size:15px;font-weight:500;opacity:.7;margin-top:8px;letter-spacing:.5px}.companion-create-btn{position:absolute;bottom:32px;right:32px;display:flex;align-items:center;gap:8px;background:#ffffff26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:14px 24px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;z-index:10;text-shadow:0 1px 4px rgba(0,0,0,.3);transition:background .2s,transform .15s;opacity:0;transition:opacity .3s ease,background .2s,transform .15s}.companion-fullscreen:hover .companion-create-btn{opacity:1}.companion-create-btn:hover{background:#ffffff40;transform:scale(1.03)}.companion-panel{position:absolute;top:0;right:0;bottom:0;width:320px;background:#141414d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;z-index:20;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.companion-panel.open{transform:translate(0)}.companion-panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.companion-panel-list{flex:1;overflow-y:auto;padding:12px}.companion-panel-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;margin-bottom:4px;transition:background .15s}.companion-panel-item:hover{background:#ffffff14}.companion-panel-item.active{background:#ffffff1f}.companion-panel-settings{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:12px}.companion-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:30;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}.companion-upload-overlay.open{opacity:1;pointer-events:all}.companion-upload-card{background:#fff;border-radius:20px;padding:32px;max-width:600px;width:90%;position:relative;color:#1d1d1f}.companion-clock{position:absolute;top:72px;left:var(--sp-2xl);color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.5),0 0 20px rgba(0,0,0,.3);-webkit-user-select:none;user-select:none;z-index:2}.companion-clock-time{font-family:var(--font-display);font-size:72px;font-weight:700;letter-spacing:-2px;line-height:1}.companion-clock-date{font-family:var(--font-body);font-size:18px;opacity:.8;margin-top:var(--sp-xs)}.companion-dots{position:absolute;bottom:var(--sp-lg);left:50%;transform:translate(-50%);display:flex;gap:var(--sp-sm);z-index:2}.companion-dot{width:8px;height:8px;border-radius:var(--radius-full);background:#2d242033;cursor:pointer;transition:all var(--dur-short) var(--ease-enter)}.companion-dot.active{background:#2d242099;width:24px}.companion-exit-btn{display:none;position:absolute;top:var(--sp-lg);right:var(--sp-lg);width:40px;height:40px;border-radius:var(--radius-full);background:#2d24201a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#2d2420;font-size:18px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--dur-medium) var(--ease-enter);z-index:3}.companion-fullscreen:hover .companion-exit-btn{opacity:1}.companion-empty{display:flex;flex-direction:column;align-items:center;gap:var(--sp-md);color:#2d242080}@media(max-width:640px){.companion-clock{top:var(--sp-xl);left:var(--sp-lg)}.companion-clock-time{font-size:48px}.companion-clock-date{font-size:14px}.companion-grid{grid-template-columns:repeat(2,1fr)}}
