*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-start: #1a1a2e;--bg-mid: #16213e;--bg-end: #533483;--accent: rgba(200, 160, 255, 1);--accent-rgb: 200, 160, 255;--accent-blue: rgba(100, 180, 255, 1);--accent-blue-rgb: 100, 180, 255;--text: #e0d0ff;--text-dim: rgba(200, 180, 240, .6);--text-muted: rgba(200, 180, 240, .4);--bubble-user: rgba(100, 140, 255, .18);--bubble-user-border: rgba(100, 140, 255, .15);--bubble-nova: rgba(200, 160, 255, .1);--bubble-nova-border: rgba(200, 160, 255, .12);--glass: rgba(200, 160, 255, .08);--glass-border: rgba(200, 160, 255, .12);--glass-blur: blur(20px);--tab-height: 72px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html{overscroll-behavior:none}body{background:linear-gradient(160deg,var(--bg-start) 0%,var(--bg-mid) 30%,#0f3460 60%,var(--bg-end) 100%);color:var(--text);font-family:-apple-system,SF Pro Display,system-ui,sans-serif;overflow:hidden;height:100vh;width:100vw;-webkit-font-smoothing:antialiased;touch-action:manipulation;overscroll-behavior:none}button,input,a{-webkit-tap-highlight-color:transparent}#root{height:100vh;width:100vw}.app{display:flex;height:100vh;width:100vw;position:relative;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1}.avatar-container{width:50vw;max-width:360px;display:flex;align-items:center;justify-content:center;position:relative;transition:all .4s ease-in-out}.avatar-container.hero{width:160px;max-width:160px;height:160px}.avatar-container.hero .avatar-image-wrapper{width:160px;height:160px}.avatar-container.collapsed{width:36px;max-width:36px;height:36px}.avatar-container.collapsed .avatar-image-wrapper{width:36px;height:36px}.avatar-container.collapsed .avatar-image-glow{display:none}.avatar-image-wrapper{position:relative;width:280px;height:280px;border-radius:50%;overflow:hidden}.avatar-image{width:100%;height:100%;object-fit:cover;object-position:center 15%;border-radius:50%;border:3px solid rgba(200,160,255,.4);transition:all .5s ease-in-out;filter:brightness(1) saturate(1)}.avatar-image-glow{position:absolute;top:-15px;right:-15px;bottom:-15px;left:-15px;border-radius:50%;background:radial-gradient(circle,rgba(200,160,255,1) 0%,transparent 70%);opacity:.12;z-index:-1;animation:glowPulse 4s ease-in-out infinite;transition:all .5s ease-in-out;box-shadow:0 0 40px #c8a0ff40}@keyframes glowPulse{0%,to{opacity:.12;transform:scale(1)}50%{opacity:.2;transform:scale(1.05)}}.avatar--listening .avatar-image{border-color:#c8a0ffcc;filter:brightness(1.05);transform:scale(1.02)}.avatar--listening .avatar-image-glow{background:radial-gradient(circle,rgba(200,160,255,1) 0%,transparent 70%);opacity:.3;animation:listenPulse 1.5s ease-in-out infinite;box-shadow:0 0 40px #c8a0ff80}@keyframes listenPulse{0%,to{opacity:.2}50%{opacity:.4}}.avatar--thinking .avatar-image{border-color:#7c6cf0cc;filter:brightness(.95) saturate(.9)}.avatar--thinking .avatar-image-glow{background:radial-gradient(circle,rgba(124,108,240,1) 0%,transparent 70%);opacity:.2;box-shadow:0 0 40px #7c6cf066}.avatar--happy .avatar-image{border-color:#c8a0ffcc;filter:brightness(1.1) saturate(1.1);transform:scale(1.03)}.avatar--happy .avatar-image-glow{background:radial-gradient(circle,rgba(200,160,255,1) 0%,transparent 70%);opacity:.25;box-shadow:0 0 40px #c8a0ff66}.avatar--excited .avatar-image{border-color:#ff6b9dcc;filter:brightness(1.15) saturate(1.2);transform:scale(1.05)}.avatar--excited .avatar-image-glow{background:radial-gradient(circle,rgba(255,107,157,1) 0%,transparent 70%);opacity:.3;animation:excitedPulse .8s ease-in-out infinite;box-shadow:0 0 40px #ff6b9d66}@keyframes excitedPulse{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.35;transform:scale(1.08)}}.avatar--flirty .avatar-image{border-color:#e88ca5cc;filter:brightness(1.08) saturate(1.15)}.avatar--flirty .avatar-image-glow{background:radial-gradient(circle,rgba(232,140,165,1) 0%,transparent 70%);opacity:.25;box-shadow:0 0 40px #e88ca566}.avatar--concerned .avatar-image{border-color:#89ac;filter:brightness(.9) saturate(.85)}.avatar--concerned .avatar-image-glow{background:radial-gradient(circle,rgba(136,153,170,1) 0%,transparent 70%);opacity:.15;box-shadow:0 0 40px #89a6}.avatar--laughing .avatar-image{border-color:#c8a0ffcc;filter:brightness(1.15) saturate(1.15);animation:laughBounce .4s ease-in-out infinite}@keyframes laughBounce{0%,to{transform:scale(1.03) rotate(0)}25%{transform:scale(1.04) rotate(.5deg)}75%{transform:scale(1.04) rotate(-.5deg)}}.avatar--laughing .avatar-image-glow{background:radial-gradient(circle,rgba(200,160,255,1) 0%,transparent 70%);opacity:.3;box-shadow:0 0 40px #c8a0ff66}.avatar--talking .avatar-image{border-color:#c8a0ff99}.avatar--talking .avatar-image-glow{background:radial-gradient(circle,rgba(200,160,255,1) 0%,transparent 70%);animation:talkPulse .6s ease-in-out infinite;box-shadow:0 0 40px #c8a0ff4d}@keyframes talkPulse{0%,to{opacity:.15}50%{opacity:.25}}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.chat-bubble{max-width:85%;padding:10px 14px;border-radius:16px;font-size:16px;line-height:1.4;word-wrap:break-word}.chat-bubble.user{background:var(--bubble-user);border:1px solid var(--bubble-user-border);border-radius:16px 16px 4px;align-self:flex-end}.chat-bubble.assistant{background:var(--bubble-nova);border:1px solid var(--bubble-nova-border);border-radius:16px 16px 16px 4px;align-self:flex-start;white-space:pre-wrap}.chat-image{max-width:100%;max-height:200px;border-radius:8px;margin-bottom:6px;display:block;object-fit:cover}.chat-image-preview{padding:8px 16px;border-top:1px solid var(--glass-border);position:relative;display:flex;align-items:center}.chat-image-preview img{height:60px;border-radius:6px;object-fit:cover}.chat-image-preview-remove{position:absolute;top:4px;left:72px;background:#ff0000b3;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.chat-image-btn{background:#ffffff14;border:1px solid var(--glass-border);border-radius:8px;padding:8px 10px;font-size:16px;cursor:pointer;transition:background .2s;flex-shrink:0}.chat-image-btn:hover{background:#ffffff26}.chat-image-btn:disabled{opacity:.4;cursor:not-allowed}.chat-input-area{padding:12px 16px;border-top:1px solid var(--glass-border);display:flex;gap:8px;flex-shrink:0}.chat-input{flex:1;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:16px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-dim)}.chat-send-btn{background:var(--accent);border:none;border-radius:8px;padding:10px 16px;color:var(--bg-start);font-weight:600;cursor:pointer;transition:opacity .2s}.chat-send-btn:hover{opacity:.85}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-streaming{display:flex;align-items:center;gap:6px;padding:4px 10px;color:var(--text-dim);font-size:12px}.streaming-dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent);animation:dotPulse 1.2s ease-in-out infinite}.streaming-dots span:nth-child(2){animation-delay:.2s}.streaming-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.chat-timestamp{font-size:11px;color:var(--text-muted)}.chat-link{display:inline-block;background:#c8a0ff26;border:1px solid var(--accent);border-radius:6px;padding:4px 10px;color:var(--accent);text-decoration:none;font-size:12px;font-weight:600;margin:2px 0;transition:background .2s}.chat-link:hover{background:#c8a0ff4d}.mic-button{width:72px;height:72px;border-radius:50%;background:#c8a0ff1a;border:2px solid var(--accent);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .3s ease-in-out;margin-top:24px;touch-action:manipulation}.mic-button:hover{background:#c8a0ff33}.mic-button:active{transform:none}.mic-button.active{background:var(--accent);color:var(--bg-start);box-shadow:0 0 20px #c8a0ff80,0 0 40px #c8a0ff33;animation:micPulse 1.5s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 20px #c8a0ff80}50%{box-shadow:0 0 30px #c8a0ffb3,0 0 60px #c8a0ff4d}}.status-bar{position:fixed;bottom:16px;left:16px;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-dim);z-index:5}.status-dot{width:8px;height:8px;border-radius:50%;background:#555}.status-dot.connected{background:var(--accent);box-shadow:0 0 6px var(--accent)}.status-dot.error{background:#e74c3c}.status-emotion{text-transform:capitalize;color:var(--accent)}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--bg-start) 0%,var(--bg-mid) 30%,#0f3460 60%,var(--bg-end) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;padding:calc(24px + var(--safe-top)) 24px calc(24px + var(--safe-bottom))}.login-branding{display:flex;flex-direction:column;align-items:center;margin-bottom:40px}.login-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;object-position:center 15%;border:2px solid rgba(200,160,255,.5);box-shadow:0 0 32px #c8a0ff40,0 8px 32px #0006;margin-bottom:16px}.login-title{font-size:48px;font-weight:200;color:var(--accent);letter-spacing:10px;text-transform:uppercase;margin-bottom:4px;line-height:1}.login-tagline{font-size:13px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.login-card{width:100%;max-width:320px;background:#c8a0ff0f;border:1px solid rgba(200,160,255,.15);border-radius:24px;padding:32px 28px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 40px #0006,inset 0 1px #ffffff0f}.login-subtitle{color:var(--text-dim);font-size:14px;text-align:center;margin-bottom:20px;letter-spacing:.3px}.login-input{display:block;width:100%;margin:0 0 16px;background:#ffffff0f;border:1px solid rgba(200,160,255,.2);border-radius:14px;padding:16px 20px;color:var(--text);font-size:22px;text-align:center;letter-spacing:10px;outline:none;transition:border-color .25s,box-shadow .25s,background .25s;-webkit-appearance:none}.login-input:focus{border-color:var(--accent);background:#c8a0ff14;box-shadow:0 0 0 3px #c8a0ff1f,0 0 16px #c8a0ff1a}.login-input::placeholder{color:var(--text-muted);letter-spacing:3px;font-size:14px}.login-error{color:#ff6b6b;font-size:13px;text-align:center;margin-bottom:12px;min-height:20px}.login-btn{width:100%;background:linear-gradient(135deg,var(--accent) 0%,rgba(160,120,220,1) 100%);border:none;border-radius:14px;padding:16px 40px;color:#1a1a2e;font-size:16px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:opacity .2s,transform .1s;box-shadow:0 4px 20px #c8a0ff4d}.login-btn:active{transform:scale(.98)}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.particle-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:8px 0 calc(8px + var(--safe-bottom));background:#0a0a14d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);z-index:50}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;padding:4px 0;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent}.tab-icon{font-size:22px;line-height:1}.tab-label{display:none;font-size:10px;color:var(--text-muted);transition:color .2s}.tab-item.active .tab-label{color:var(--accent)}.tab-indicator{display:block;width:4px;height:4px;border-radius:50%;background:var(--accent);margin-top:2px}.screen-container{position:fixed;top:0;left:0;right:0;bottom:var(--tab-height);padding-top:calc(16px + var(--safe-top));overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:none;animation:fadeIn .25s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.home-screen{display:flex;flex-direction:column;align-items:center;padding:48px 24px 24px}.home-hero{text-align:center;margin-bottom:24px}.home-avatar-wrapper{margin-bottom:12px}.home-name{font-size:24px;font-weight:300;letter-spacing:1px;color:var(--text)}.home-status{font-size:12px;color:var(--text-muted);margin-top:4px;display:flex;align-items:center;justify-content:center;gap:6px}.home-status .status-dot{width:6px;height:6px;border-radius:50%;background:#666;display:inline-block}.home-status .status-dot.online{background:var(--accent);box-shadow:0 0 8px rgba(var(--accent-rgb),.5)}.home-actions{display:flex;gap:20px;margin-bottom:24px}.home-action-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.home-action-icon{width:52px;height:52px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:22px}.home-action-label{font-size:11px;color:var(--text-muted)}.home-card{width:100%;max-width:340px;background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:14px 16px;margin-bottom:12px}.home-card-label{font-size:11px;color:var(--text-muted);display:block;margin-bottom:6px}.home-card-text{font-size:14px;color:var(--text);line-height:1.4}.chat-screen{display:flex;flex-direction:column}.chat-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0}.chat-header-avatar{width:36px;height:36px;flex-shrink:0}.chat-header-name{font-size:15px;color:var(--text);font-weight:400}.chat-header-status{font-size:11px;color:var(--text-muted)}.chat-mic-btn{width:34px;height:34px;border-radius:50%;background:#ffffff14;border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;flex-shrink:0;transition:background .2s;-webkit-tap-highlight-color:transparent}.chat-mic-btn:hover{background:#ffffff26}.screen-header{padding:16px 20px 12px}.screen-header h2{font-size:28px;font-weight:300;color:var(--text)}.screen-empty{text-align:center;padding:48px 24px;color:var(--text-dim);font-size:14px}.screen-empty div{font-size:40px;margin-bottom:12px}.screen-empty-hint{font-size:12px;color:var(--text-muted);margin-top:8px}.task-group{margin-bottom:8px}.task-list-card{background:var(--glass);border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border)}.task-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--glass-border)}.task-item:last-child{border-bottom:none}.task-item.completed .task-title{text-decoration:line-through;opacity:.5}.task-checkbox{width:24px;height:24px;border-radius:50%;border:2px solid var(--accent);background:none;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.task-content{flex:1;min-width:0}.task-title{font-size:15px;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-due{font-size:11px;color:var(--text-muted);display:block;margin-top:2px}.task-delete{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:4px 8px;-webkit-tap-highlight-color:transparent;flex-shrink:0}.reminder-icon{font-size:18px;flex-shrink:0}.section-title{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:16px 20px 8px}.fab{position:fixed;bottom:calc(var(--tab-height) + 16px);right:16px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#1a1a2e;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 16px rgba(var(--accent-rgb),.3);z-index:40;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.task-add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:45;display:flex;align-items:flex-end}.task-add-sheet{width:100%;background:var(--bg-mid);border-top:1px solid var(--glass-border);border-radius:20px 20px 0 0;padding:8px 0 32px}.screen-loading{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:14px}.inline-add{display:flex;gap:8px;padding:12px 20px}.inline-input{flex:1;padding:10px 14px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text);font-size:15px;outline:none}.inline-input:focus{border-color:var(--accent)}.inline-input option{background:var(--bg-mid);color:var(--text)}.inline-submit{padding:10px 16px;border-radius:10px;background:var(--accent);color:#1a1a2e;border:none;font-size:14px;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--glass-border)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:15px;color:var(--text)}.toggle-switch{width:48px;height:28px;border-radius:14px;background:#ffffff1a;border:none;position:relative;cursor:pointer;transition:background .2s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.toggle-switch.on{background:var(--accent)}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-switch.on:after{transform:translate(20px)}.time-input{padding:6px 10px;border-radius:8px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text);font-size:14px;outline:none;width:90px}.time-input:focus{border-color:var(--accent)}.date-item{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--glass-border)}.date-item:last-of-type{border-bottom:none}.date-info{flex:1}.date-name{font-size:15px;color:var(--text)}.date-detail{font-size:12px;color:var(--text-muted);margin-top:2px}.mood-entry{padding:12px 20px;border-bottom:1px solid var(--glass-border)}.mood-entry:last-child{border-bottom:none}.mood-emoji{font-size:20px}.mood-text{font-size:14px;color:var(--text);margin-left:8px}.mood-time{font-size:11px;color:var(--text-muted);display:block;margin-top:4px}.settings-group{margin-bottom:8px}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--glass-border)}.settings-item:last-child{border-bottom:none}.settings-item-label{font-size:15px;color:var(--text)}.settings-item-value{font-size:14px;color:var(--text-dim);text-align:right;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-btn{padding:10px 20px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-border);color:var(--accent);font-size:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}.memory-back-btn{background:none;border:none;color:var(--accent);font-size:24px;cursor:pointer;padding:0 12px 0 0;line-height:1}.memory-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06)}.memory-item:last-child{border-bottom:none}.memory-fact{flex:1;color:var(--text);font-size:14px;cursor:pointer;min-height:20px}.memory-edit-input{flex:1;background:#ffffff14;border:1px solid var(--accent);border-radius:6px;color:var(--text);font-size:14px;padding:6px 8px;outline:none}.memory-meta{color:var(--text-muted);font-size:11px;white-space:nowrap}.memory-delete-btn{background:none;border:none;color:#ff6464b3;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.memory-error{background:#ff505026;color:#ff6b6b;text-align:center;padding:8px;border-radius:8px;margin:8px 0;font-size:13px}.grocery-action-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-size:18px;padding:6px 10px;cursor:pointer}.grocery-action-btn:active{background:#ffffff26}.grocery-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06)}.grocery-item:last-child{border-bottom:none}.grocery-item-name{flex:1;color:var(--text);font-size:14px}.grocery-item-name.checked{text-decoration:line-through;opacity:.5}.grocery-item-qty{color:var(--text-muted);font-size:12px;background:#ffffff0f;padding:2px 6px;border-radius:4px}.grocery-print{display:none}.face-verify-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--bg-start) 0%,var(--bg-mid) 30%,#0f3460 60%,var(--bg-end) 100%);display:flex;align-items:center;justify-content:center;z-index:100;padding:calc(24px + var(--safe-top)) 24px calc(24px + var(--safe-bottom))}.face-verify-content{display:flex;flex-direction:column;align-items:center;gap:24px}.face-pin-check{color:#64dc78b3;font-size:14px;letter-spacing:.5px}.face-viewfinder-wrap{position:relative}.face-ring{width:200px;height:200px;border-radius:50%;border:3px solid rgba(200,160,255,.4);overflow:hidden;position:relative;transition:border-color .4s}.face-ring.scanning{animation:face-pulse 2s ease-in-out infinite}.face-ring.success{border-color:#64dc78cc;box-shadow:0 0 30px #64dc784d}.face-ring.failed{border-color:#ff6b6bcc;box-shadow:0 0 30px #ff6b6b33}@keyframes face-pulse{0%,to{box-shadow:0 0 10px #c8a0ff33}50%{box-shadow:0 0 30px #c8a0ff66}}.face-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);border-radius:50%}.face-status{color:var(--text-dim);font-size:14px;letter-spacing:.3px;text-align:center}.face-dots{display:flex;gap:8px}.face-dot{width:8px;height:8px;border-radius:50%;background:#c8a0ff33;transition:background .3s}.face-dot.done{background:#c8a0ff99}.face-dot.success{background:#64dc78cc}.face-dot.failed{background:#ff6b6bb3}.face-enroll-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.face-enroll-card{width:100%;max-width:360px;background:#c8a0ff0f;border:1px solid rgba(200,160,255,.15);border-radius:24px;padding:28px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;align-items:center;gap:20px}.face-enroll-title{color:var(--accent);font-size:20px;font-weight:300;letter-spacing:1px}.face-enroll-instruction{color:var(--text-dim);font-size:14px;text-align:center;min-height:40px}.face-enroll-viewfinder{width:180px;height:180px;border-radius:50%;border:2px solid rgba(200,160,255,.3);overflow:hidden}.face-enroll-viewfinder video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);border-radius:50%}.face-enroll-progress{color:var(--text-muted);font-size:13px;letter-spacing:1px}.face-enroll-btn{width:100%;background:linear-gradient(135deg,var(--accent) 0%,rgba(160,120,220,1) 100%);border:none;border-radius:14px;padding:14px;color:#1a1a2e;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s}.face-enroll-btn:disabled{opacity:.35;cursor:not-allowed}.face-enroll-btn-secondary{width:100%;background:transparent;border:1px solid rgba(200,160,255,.2);border-radius:14px;padding:14px;color:var(--text-dim);font-size:14px;cursor:pointer}.face-enroll-error{color:#ff6b6b;font-size:13px;text-align:center;min-height:18px}@media print{.app>*:not(.grocery-screen){display:none!important}.tab-bar,.screen-header,.fab,.task-add-overlay,.grocery-action-btn,.grocery-screen>*:not(.grocery-print){display:none!important}.grocery-print{display:block!important;color:#000;background:#fff;padding:20px;font-family:-apple-system,system-ui,sans-serif}.grocery-print h1{font-size:20px;margin-bottom:16px;color:#000}.grocery-print h3{font-size:14px;margin:12px 0 4px;color:#333}.grocery-print ul{list-style:none;padding:0;margin:0}.grocery-print li{padding:3px 0;font-size:13px;color:#000}.grocery-print li:before{content:"□ ";font-size:12px}.particle-bg{display:none!important}body{background:#fff!important}}@media(min-width:768px){.app{max-width:480px;margin:0 auto;position:relative;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border)}.tab-bar,.screen-container{max-width:480px;left:50%;transform:translate(-50%)}.fab{right:calc(50% - 224px)}.task-add-overlay{max-width:480px;left:50%;transform:translate(-50%)}.login-screen{max-width:480px;margin:0 auto;left:50%;transform:translate(-50%);border-left:1px solid rgba(200,160,255,.1);border-right:1px solid rgba(200,160,255,.1)}.chat-bubble,.chat-input{font-size:15px}}@media(min-width:1024px){body{background:#0d0d1a}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--bg-start) 0%,var(--bg-mid) 30%,#0f3460 60%,var(--bg-end) 100%);z-index:-1}.app{max-width:480px;box-shadow:0 0 80px #c8a0ff14,0 0 1px #c8a0ff33;border-radius:20px 20px 0 0;overflow:hidden}.tab-bar{border-radius:0 0 20px 20px}}.hacking-card{cursor:pointer;transition:all .3s ease}.hacking-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.hacking-card-icon{font-size:20px}.hacking-card-title{flex:1;display:flex;flex-direction:column}.hacking-level{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hacking-streak{font-size:14px;font-weight:600}.hacking-module-info{margin-bottom:10px;cursor:pointer}.hacking-module-name{font-size:13px;color:#c8b4f0cc;display:block;margin-bottom:6px}.hacking-progress-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:4px}.hacking-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:3px;transition:width .5s ease}.hacking-progress-text{font-size:11px;color:#c8b4f080}.hacking-quick-stats{display:flex;justify-content:space-around;padding:8px 0;border-top:1px solid rgba(255,255,255,.06)}.hacking-stat{display:flex;flex-direction:column;align-items:center}.hacking-stat-value{font-size:16px;font-weight:700;color:var(--text-primary)}.hacking-stat-label{font-size:10px;color:#c8b4f080;text-transform:uppercase;letter-spacing:.5px}.hacking-challenge-banner{background:linear-gradient(135deg,#a855f733,#8b5cf61a);border:1px solid rgba(168,85,247,.3);border-radius:8px;padding:8px 12px;text-align:center;font-size:13px;color:var(--accent);font-weight:600;margin-top:8px}.hacking-expanded{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.06)}.hacking-curriculum-map{display:flex;flex-direction:column;gap:6px}.hacking-module-chip{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;font-size:12px;background:#ffffff0a}.hacking-module-chip.unlocked{background:#a855f71a;border:1px solid rgba(168,85,247,.2);cursor:pointer}.hacking-module-chip.completed{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);cursor:pointer}.hacking-module-chip.locked{opacity:.4}.hacking-module-num{width:20px;height:20px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.hacking-module-label{flex:1;color:#c8b4f0cc}.hacking-check{color:#22c55e;font-weight:700}.hacking-lock{font-size:12px}.hacking-bounty-summary{margin-top:10px;font-size:12px;color:#c8b4f099;text-align:center}
