.verify-email-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;background:#fffbeb;color:#92400e;font-size:.875rem;border-bottom:1px solid #fde68a}.verify-email-text{line-height:1.4}.verify-email-btn{background:#f59e0b;color:#fff;border:none;border-radius:6px;padding:4px 12px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s}.verify-email-btn:hover:not(:disabled){background:#d97706}.verify-email-btn:disabled{opacity:.6;cursor:not-allowed}.language-switcher{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:6px 32px 6px 12px;font-size:.875rem;color:#495057;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23495057' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:all .15s}.language-switcher:hover{border-color:#adb5bd;background-color:#fff}.language-switcher:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.theme-switcher{display:flex;gap:4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:3px}.theme-switcher-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 8px;background:transparent;border:none;border-radius:7px;color:var(--color-text-muted);font-size:.6875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.theme-switcher-btn:hover:not(.active){background:var(--color-surface-hover)}.theme-switcher-btn.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.theme-switcher-icon{font-size:.9375rem;line-height:1}.theme-switcher-label{font-size:.6875rem}.toast-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:1001;display:flex;flex-direction:column;gap:10px;max-width:calc(100vw - 40px);pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;font-size:.875rem;line-height:1.4;box-shadow:0 8px 24px #00000026;min-width:280px;max-width:480px;pointer-events:auto;animation:toast-slide-up .25s ease;background:#1a1a2e;color:#fff}.toast-success{background:#15803d}.toast-error{background:#b91c1c}.toast-info{background:#1e40af}.toast-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.toast-message{flex:1;min-width:0}.toast-close{flex-shrink:0;background:transparent;border:none;color:inherit;opacity:.7;font-size:.875rem;cursor:pointer;padding:2px 6px;border-radius:6px;transition:opacity .15s,background .15s}.toast-close:hover{opacity:1;background:#ffffff1a}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.toast-container{bottom:16px;left:16px;right:16px;transform:none;max-width:none}.toast{min-width:0;width:100%}}.feedback-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1100;animation:feedback-fade-in .2s ease}.feedback-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1101;background:#fff;border-radius:16px;box-shadow:0 16px 48px #0003;width:min(440px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;animation:feedback-modal-in .2s ease}.feedback-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #e9ecef}.feedback-modal-title{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a2e}.feedback-modal-close{background:transparent;border:none;font-size:1rem;color:#6c757d;cursor:pointer;padding:6px 10px;border-radius:8px;transition:background .15s}.feedback-modal-close:hover{background:#f8f9fa}.feedback-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:20px}.feedback-field{display:flex;flex-direction:column;gap:8px;position:relative}.feedback-label{font-size:.875rem;font-weight:500;color:#495057}.feedback-stars{display:flex;gap:4px}.feedback-star{background:transparent;border:none;font-size:1.75rem;color:#dee2e6;cursor:pointer;padding:4px 8px;border-radius:8px;transition:color .15s,transform .1s;line-height:1}.feedback-star:hover{transform:scale(1.1)}.feedback-star.active{color:#f59e0b}.feedback-textarea{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:8px;font-family:inherit;font-size:.9375rem;color:#1a1a2e;resize:vertical;min-height:80px;transition:border-color .15s}.feedback-textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.feedback-counter{font-size:.75rem;color:#adb5bd;align-self:flex-end}.feedback-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.feedback-btn-primary,.feedback-btn-secondary{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;min-height:40px}.feedback-btn-primary{background:#4f46e5;color:#fff;border:none}.feedback-btn-primary:hover:not(:disabled){background:#4338ca}.feedback-btn-primary:disabled{opacity:.5;cursor:not-allowed}.feedback-btn-secondary{background:transparent;color:#495057;border:1px solid #dee2e6}.feedback-btn-secondary:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd}@keyframes feedback-fade-in{0%{opacity:0}to{opacity:1}}@keyframes feedback-modal-in{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.sidebar-rail{position:fixed;top:0;left:0;bottom:0;width:56px;background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;cursor:pointer;transition:background .15s}.sidebar-rail:hover{background:var(--color-surface-hover)}@media (hover: none){.sidebar-rail{display:none}}.sidebar-brand-icon{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0;pointer-events:none}.sidebar-brand-icon-img,.sidebar-brand-icon-hamburger{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease}.sidebar-brand-icon-img{width:32px;height:32px;margin:auto;border-radius:6px;opacity:1}.sidebar-brand-icon-hamburger{font-size:1.375rem;color:var(--color-text);opacity:0}.sidebar-rail:hover .sidebar-brand-icon-img{opacity:0}.sidebar-rail:hover .sidebar-brand-icon-hamburger{opacity:1}.sidebar-rail-icon{width:40px;height:40px;padding:0;border:none;background:none;border-radius:10px;color:var(--color-text-muted);font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.sidebar-rail-icon:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-rail-icon.active{background:var(--color-brand-tint);color:var(--color-brand)}.sidebar-rail-divider{width:24px;height:1px;background:var(--color-border);margin:4px 0;flex-shrink:0}.sidebar-rail-apps{display:flex;flex-direction:column;align-items:center;gap:4px;overflow-y:auto;overflow-x:hidden;width:100%;flex:1;padding:0 4px 8px;scrollbar-width:thin}.sidebar-rail .sidebar-app-link{width:40px;height:40px;padding:0;border-radius:10px;justify-content:center}.sidebar-rail .sidebar-app-name{display:none}.sidebar-edge-tab-hotspot{position:fixed;top:0;left:0;width:20px;height:100%;z-index:20;pointer-events:auto;touch-action:pan-y;display:none}@media (hover: none){.sidebar-edge-tab-hotspot{display:block}}.sidebar-edge-tab-handle{position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:80px;background:var(--color-text-muted);border:none;border-top-right-radius:6px;border-bottom-right-radius:6px;opacity:.35;cursor:pointer;transition:opacity .15s ease;padding:0}.sidebar-edge-tab-handle:active,.sidebar-edge-tab-handle:focus-visible{opacity:.7}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:998;opacity:0;pointer-events:none;transition:opacity .25s ease}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar-panel{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:var(--color-surface);z-index:999;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .25s ease,background .2s;box-shadow:4px 0 24px #0000001f;overflow-y:auto}.sidebar-panel.open{transform:translate(0)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.sidebar-logo{display:inline-flex;align-items:center;padding:0;margin:0;background:none;border:none;cursor:pointer}.sidebar-logo img{height:28px;width:auto;display:block}.sidebar-logo:hover{opacity:.8}.sidebar-close{background:none;border:none;font-size:1rem;color:var(--color-text-muted);cursor:pointer;padding:8px 12px;border-radius:6px;transition:background .15s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.sidebar-close:hover{background:var(--color-surface-hover)}.sidebar-nav{padding:8px 0}.sidebar-nav-item{display:block;width:100%;padding:12px 20px;background:none;border:none;text-align:left;font-size:.9375rem;color:var(--color-text);cursor:pointer;transition:background .15s;min-height:44px}.sidebar-nav-item:hover{background:var(--color-surface-hover)}.sidebar-nav-item.active{background:var(--color-brand-tint);color:var(--color-brand);font-weight:500}.sidebar-apps{display:flex;flex-direction:column;gap:2px;margin-top:6px}.sidebar-app-link{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:none;border:none;border-radius:8px;text-align:left;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:all .15s;min-height:44px}.sidebar-app-link:hover{background:var(--color-surface-hover)}.sidebar-app-link.active{background:var(--color-brand-tint);color:var(--color-brand);font-weight:500}.sidebar-app-icon{font-size:1.25rem;line-height:1;flex-shrink:0}.sidebar-app-name{flex:1}.sidebar-section{padding:12px 20px;border-top:1px solid var(--color-border)}.sidebar-section-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.sidebar-footer{margin-top:auto;padding:16px 20px;border-top:1px solid var(--color-border)}.sidebar-user{display:flex;flex-direction:column;gap:12px}.sidebar-user-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.875rem;font-weight:600;color:var(--color-text)}.sidebar-sign-out{background:none;border:1px solid var(--color-border-strong);border-radius:8px;padding:8px;font-size:.8125rem;color:var(--color-text);cursor:pointer;transition:all .15s;min-height:36px}.sidebar-sign-out:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.sidebar-auth-buttons{display:flex;flex-direction:column;gap:8px}.sidebar-btn-primary{padding:10px;background:var(--color-brand);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:44px}.sidebar-btn-primary:hover{background:var(--color-brand-hover)}.sidebar-btn-secondary{padding:10px;background:none;color:var(--color-brand);border:1px solid var(--color-brand);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;min-height:44px}.sidebar-btn-secondary:hover{background:var(--color-brand-tint)}.sidebar-rail-avatar{width:40px;height:40px;padding:0;border:none;background:var(--color-bg-subtle);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:auto;flex-shrink:0;transition:background .15s}.sidebar-rail-avatar img{width:100%;height:100%;object-fit:cover;display:block}.sidebar-rail-avatar-initials{font-size:.875rem;font-weight:600;color:var(--color-text);-webkit-user-select:none;user-select:none}.sidebar-rail-avatar:hover{background:var(--color-surface-hover)}.sidebar-rail-avatar.guest{color:var(--color-text-muted)}.sidebar-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 0;background:none;border:none;text-align:left;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;cursor:pointer}.sidebar-section-toggle:hover{color:var(--color-text)}.sidebar-section-toggle-chevron{font-size:.75rem;transition:transform .15s ease}.sidebar-section-body{padding-top:8px}.sidebar-section-label-spaced{margin-top:12px}.sidebar-user-row{display:flex;align-items:center;gap:4px}.sidebar-user-main{display:flex;gap:10px;align-items:center;flex:1;min-width:0;padding:6px 8px;background:none;border:none;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s}.sidebar-user-main:hover{background:var(--color-surface-hover)}.sidebar-sign-out-icon{width:36px;height:36px;padding:0;background:none;border:none;border-radius:8px;color:var(--color-text-muted);font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.sidebar-sign-out-icon:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-bg-subtle);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;font-size:.875rem;font-weight:600;color:var(--color-text)}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.sidebar-user-plan{display:inline-block;align-self:flex-start;padding:1px 6px;margin-top:2px;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:4px}.sidebar-user-plan.plan-free{background:#e5e7eb;color:#4b5563}:root[data-theme=dark] .sidebar-user-plan.plan-free{background:#ffffff1f;color:#9ca3af}.sidebar-user-plan.plan-handyman{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.sidebar-user-plan.plan-hero{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.sidebar-context-switcher{margin-top:12px}.sidebar-context-toggle{display:flex;padding:3px;background:var(--color-bg-subtle);border-radius:8px;gap:2px;margin-top:6px}.sidebar-context-btn{flex:1;padding:6px 10px;background:transparent;color:var(--color-text-muted);border:none;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.sidebar-context-btn:hover{color:var(--color-text)}.sidebar-context-btn.active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;transition:background .2s,border-color .2s}.layout-header-left{display:flex;align-items:center;gap:16px}.layout-header-right{display:flex;align-items:center;gap:12px}.layout-logo{display:inline-flex;align-items:center;padding:0;background:none;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}.layout-logo img{height:32px;width:auto;display:block}.layout-logo:hover{opacity:.8}.back-btn{background:none;border:1px solid var(--color-border-strong);border-radius:8px;padding:6px 12px;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:all .15s}.back-btn:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.sign-in-btn{background:var(--color-brand);color:#fff;border:none;border-radius:8px;padding:6px 16px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:36px}.sign-in-btn:hover{background:var(--color-brand-hover)}.layout-content{flex:1;display:flex;flex-direction:column}@media (hover: hover) and (pointer: fine){.layout.with-sidebar{padding-left:56px}}.access-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:.6875rem;font-weight:600;line-height:1.2;border-radius:999px;border:none;cursor:default;-webkit-user-select:none;user-select:none;white-space:nowrap}.access-badge-icon{font-size:.75rem;line-height:1}.access-badge-corner{position:absolute;top:8px;right:8px;z-index:2}.access-badge-corner.access-badge-free{background:var(--color-bg-subtle);color:var(--color-text-muted);font-weight:500;opacity:.8}.access-badge-corner.access-badge-trial{background:#fef3c7;color:#92400e;cursor:pointer}.access-badge-corner.access-badge-paid{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;cursor:pointer;box-shadow:0 1px 3px #6366f14d}:root[data-theme=dark] .access-badge-corner.access-badge-trial{background:#fbbf2426;color:#fbbf24}:root[data-theme=dark] .access-badge-corner.access-badge-free{background:var(--color-bg-subtle);color:var(--color-text-muted)}.access-badge-floating{position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);right:12px;z-index:1000;padding:6px 12px;font-size:.75rem;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer}.access-badge-floating.access-badge-trial{background:#fef3c7f2;color:#92400e;box-shadow:0 2px 8px #00000026}.access-badge-floating.access-badge-paid{background:linear-gradient(135deg,#6366f1f2,#8b5cf6f2);color:#fff;box-shadow:0 2px 8px #6366f166}:root[data-theme=dark] .access-badge-floating.access-badge-trial{background:#fbbf2433;color:#fbbf24}.access-badge-floating:hover{opacity:.85}.access-badge.access-badge-urgent.access-badge-corner{background:#fecaca;color:#991b1b;animation:access-badge-pulse 2s ease-in-out infinite}.access-badge.access-badge-urgent.access-badge-floating{background:#fecacaf2;color:#991b1b}:root[data-theme=dark] .access-badge.access-badge-urgent.access-badge-corner,:root[data-theme=dark] .access-badge.access-badge-urgent.access-badge-floating{background:#f871712e;color:#fca5a5}@keyframes access-badge-pulse{0%,to{opacity:1}50%{opacity:.75}}.app-layout{position:relative;width:100vw;height:100vh;overflow:hidden}.app-layout-content{width:100%;height:100%}@media (hover: hover) and (pointer: fine){.app-layout.with-sidebar{padding-left:56px}}.app-card{background:var(--color-surface);border-radius:16px;padding:24px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;box-shadow:var(--shadow-md);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:16px;position:relative}.app-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.app-card:active{transform:translateY(0)}.app-card-icon{font-size:3rem;line-height:1}.app-card-info{flex:1}.app-card-name{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:6px}.app-card-description{font-size:.875rem;color:var(--color-text-muted);line-height:1.5}.app-card-category{display:inline-block;align-self:flex-start;font-size:.75rem;font-weight:500;color:var(--color-brand);background:var(--color-brand-tint);padding:4px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.03em}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px}.empty-state-icon{font-size:3rem;line-height:1;opacity:.5;margin-bottom:4px}.empty-state-title{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a2e}.empty-state-description{margin:0;font-size:.9375rem;color:#6c757d;max-width:420px;line-height:1.5}.empty-state-action{margin-top:12px}.catalog{max-width:800px;margin:0 auto;padding:40px 24px;width:100%}.catalog-header{text-align:center;margin-bottom:40px}.catalog-title{font-size:1.75rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.catalog-subtitle{font-size:1rem;color:var(--color-text-muted)}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}@media (max-width: 640px){.catalog{padding:24px 16px}.catalog-grid{grid-template-columns:1fr}}.spinner{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.spinner-ring{display:inline-block;border-radius:50%;border-style:solid;border-color:#4f46e526;border-top-color:#4f46e5;animation:spinner-rotate .8s linear infinite}.spinner-small .spinner-ring{width:16px;height:16px;border-width:2px}.spinner-medium .spinner-ring{width:32px;height:32px;border-width:3px}.spinner-large .spinner-ring{width:48px;height:48px;border-width:4px}.spinner-label{font-size:.875rem;color:#6c757d}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.app-runner{width:100%;height:100%}.app-runner-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1rem;color:var(--color-text-muted)}.app-runner-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:24px}.app-runner-btn-primary{padding:10px 20px;background:var(--color-brand);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:40px}.app-runner-btn-primary:hover{background:var(--color-brand-hover)}.miniapp-container{width:100%;height:100vh}.miniapp-container .app{height:100%}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;padding:24px;text-align:center}.error-boundary-icon{font-size:3rem;line-height:1;margin-bottom:8px}.error-boundary h2{margin:0;font-size:1.25rem;color:var(--color-text)}.error-boundary-message{margin:0;max-width:480px;font-size:.875rem;color:var(--color-text-muted);line-height:1.5}.error-boundary-actions{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap;justify-content:center}.error-boundary .error-boundary-primary{background:var(--color-brand);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:40px}.error-boundary .error-boundary-primary:hover{background:var(--color-brand-hover)}.error-boundary .error-boundary-reload{background:transparent;color:var(--color-text);border:1px solid var(--color-border-strong);border-radius:8px;padding:10px 20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;min-height:40px}.error-boundary .error-boundary-reload:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.auth-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:400px;box-shadow:0 2px 12px #00000014}.auth-title{font-size:1.5rem;font-weight:700;color:#1a1a2e;text-align:center;margin-bottom:24px}.auth-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.auth-success{background:#f0fdf4;color:#15803d;padding:12px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px;line-height:1.4}.auth-description{font-size:.875rem;color:#6c757d;line-height:1.5;margin-bottom:20px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:4px}.auth-field label{font-size:.875rem;font-weight:500;color:#495057}.auth-field input{padding:10px 12px;border:1px solid #dee2e6;border-radius:8px;font-size:.9375rem;transition:border-color .15s}.auth-field input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.auth-btn-block{width:100%;margin-top:16px}.auth-switch-compact{margin-top:12px}.auth-btn-primary{padding:12px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}.auth-btn-primary:hover{background:#4338ca}.auth-btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#adb5bd;font-size:.8125rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e9ecef}.auth-btn-social{width:100%;padding:10px;background:#fff;border:1px solid #dee2e6;border-radius:8px;font-size:.875rem;font-weight:500;color:#495057;cursor:pointer;transition:all .15s}.auth-btn-social:hover{background:#f8f9fa;border-color:#adb5bd}.auth-switch{text-align:center;margin-top:20px;font-size:.875rem;color:#6c757d}.auth-switch a{color:#4f46e5;text-decoration:none;font-weight:500}.auth-switch a:hover{text-decoration:underline}.family-section{padding:20px 0;border-top:1px solid var(--color-border)}.family-section-loading{display:flex;justify-content:center;align-items:center;min-height:80px}.family-block{margin-bottom:24px}.family-block:last-child{margin-bottom:0}.family-block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.family-block-title{margin:0;font-size:.9375rem;font-weight:600;color:var(--color-text)}.family-block-count{font-weight:500;color:var(--color-text-muted);margin-left:4px}.family-block-hint{margin-top:12px;font-size:.8125rem;color:var(--color-text-muted)}.family-members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}.family-member-card{position:relative;display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:10px;transition:all .15s}.family-member-card:hover{border-color:var(--color-border-strong)}.family-member-card-owner{background:linear-gradient(135deg,#6366f10f,#8b5cf60f);border-color:#6366f140}.family-member-card-owner .family-member-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.family-member-badge{display:inline-block;padding:1px 6px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;background:#6366f126;color:#6366f1}:root[data-theme=dark] .family-member-badge{background:#8b5cf633;color:#c4b5fd}.family-member-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.family-member-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.family-member-info{flex:1;min-width:0}.family-member-name{font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.family-member-joined{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.family-member-kick{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:50%;color:var(--color-text-muted);font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s}.family-member-card:hover .family-member-kick{opacity:1}.family-member-kick:hover{background:var(--color-danger-bg, rgba(239, 68, 68, .12));color:var(--color-danger-text, #dc2626)}.family-member-kick:disabled{opacity:.3;cursor:not-allowed}.family-empty-state{padding:16px;background:var(--color-bg-subtle);border-radius:10px;border:1px dashed var(--color-border)}.family-empty-state p{margin:0;font-size:.8125rem;color:var(--color-text-muted);line-height:1.5}.family-invites-list{display:flex;flex-direction:column;gap:8px}.family-invite-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:10px;flex-wrap:wrap}.family-invite-content{flex:1;min-width:200px;display:flex;flex-direction:column;gap:4px}.family-invite-link{font-family:inherit;font-size:.8125rem;color:var(--color-brand);word-break:break-all;overflow-wrap:anywhere;line-height:1.4}.family-invite-meta{font-size:.75rem;color:var(--color-text-muted)}.family-invite-actions{display:flex;gap:6px;flex-shrink:0}.family-invite-action-btn{padding:6px 12px;background:transparent;border:1px solid var(--color-border-strong);border-radius:6px;color:var(--color-text);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.family-invite-action-btn:hover{background:var(--color-surface-hover)}.family-invite-action-revoke{color:var(--color-text-muted)}.family-invite-action-revoke:hover{background:var(--color-danger-bg, rgba(239, 68, 68, .1));color:var(--color-danger-text, #dc2626);border-color:var(--color-danger-border, rgba(239, 68, 68, .3))}.family-invite-action-btn:disabled{opacity:.5;cursor:not-allowed}.family-btn-invite{padding:8px 14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px #6366f14d}.family-btn-invite:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 8px #6366f166}.family-btn-invite:disabled{opacity:.5;cursor:not-allowed}.family-btn-leave,.family-btn-upgrade{padding:10px 20px;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s}.family-btn-leave{background:var(--color-danger-bg, rgba(239, 68, 68, .1));color:var(--color-danger-text, #dc2626);border:1px solid var(--color-danger-border, rgba(239, 68, 68, .3))}.family-btn-leave:hover:not(:disabled){background:var(--color-danger, #dc2626);color:#fff}.family-btn-upgrade{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;flex-shrink:0}.family-btn-upgrade:hover{transform:translateY(-1px);box-shadow:0 3px 8px #f59e0b66}.family-upgrade-card{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#f59e0b14,#f9731614);border:1px solid rgba(245,158,11,.2);border-radius:12px;flex-wrap:wrap}.family-upgrade-icon{font-size:2.5rem;line-height:1;flex-shrink:0}.family-upgrade-text{flex:1;min-width:220px}.family-upgrade-title{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--color-text)}.family-upgrade-description{margin:0;font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.family-member-section{margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.editable-field-row{display:flex;align-items:center;width:100%;gap:8px;flex-wrap:wrap}.editable-field-row-editing{flex-wrap:nowrap}.editable-field-value{flex:1;min-width:0;font-weight:inherit;word-break:break-word}.editable-field-edit-btn{width:28px;height:28px;padding:0;background:none;border:none;border-radius:6px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0;opacity:0;transition:opacity .15s,background .15s}.editable-field-row:hover .editable-field-edit-btn,.editable-field-row:focus-within .editable-field-edit-btn{opacity:1}.editable-field-edit-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.editable-field-input{flex:1;min-width:0;padding:6px 8px;font-size:inherit;font-family:inherit;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:6px;outline:none}.editable-field-input:focus{border-color:var(--color-brand)}.editable-field-actions{display:flex;gap:4px;flex-shrink:0}.editable-field-btn{width:28px;height:28px;padding:0;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;line-height:1;transition:all .15s}.editable-field-btn:disabled{opacity:.5;cursor:not-allowed}.editable-field-btn-save{color:var(--color-success-text, #2f7d32)}.editable-field-btn-save:hover:not(:disabled){background:var(--color-success-bg, rgba(34, 197, 94, .12))}.editable-field-btn-cancel{color:var(--color-text-muted)}.editable-field-btn-cancel:hover:not(:disabled){background:var(--color-surface-hover)}.editable-field-error{flex-basis:100%;font-size:.8125rem;color:var(--color-danger-text, #dc2626);margin-top:4px}.account-page{flex:1;display:flex;justify-content:center;padding:32px 24px}.account-card{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:640px;box-shadow:0 2px 12px #0000000f}.account-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.account-title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0}.account-section{margin-bottom:28px}.account-section:last-of-type{margin-bottom:0}.account-section-title{font-size:.8125rem;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}.account-row{display:grid;grid-template-columns:140px 1fr;align-items:center;padding:10px 0;border-bottom:1px solid #f3f4f6;gap:16px}.account-row:last-child{border-bottom:none}.account-label{font-size:.875rem;color:#6c757d}.account-value{font-size:.9375rem;font-weight:500;color:#1a1a2e;text-align:left;word-break:break-word;min-width:0}.account-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:.8125rem;font-weight:600;border:1px solid transparent}.account-status-active{background:#dcfce7;color:#15803d;border-color:#86efac}.account-status-trial{background:#fef3c7;color:#92400e;border-color:#fde68a}.account-status-limited{background:#f3f4f6;color:#4b5563;border-color:#d1d5db}.account-status-expired{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.account-actions{margin-top:20px}.account-btn-primary{padding:10px 20px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:40px}.account-btn-primary:hover:not(:disabled){background:#4338ca}.account-btn-primary:disabled{opacity:.5;cursor:not-allowed}.account-footer{margin-top:28px;padding-top:20px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-start}.account-btn-secondary{padding:10px 20px;background:transparent;color:#495057;border:1px solid #dee2e6;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;min-height:40px}.account-btn-secondary:hover{background:#f8f9fa;border-color:#adb5bd}.account-loading{flex:1;display:flex;align-items:center;justify-content:center;min-height:300px}.billing-interval-toggle{display:flex;gap:8px;margin:16px 0 20px;padding:4px;background:var(--color-bg-subtle);border-radius:10px}.billing-interval-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 16px;background:transparent;border:none;border-radius:8px;color:var(--color-text-muted);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .15s}.billing-interval-btn.active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.billing-interval-savings{font-size:.75rem;color:var(--color-success-text, #2f7d32)}.billing-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:16px}.billing-plan{padding:20px;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:12px;display:flex;flex-direction:column;gap:10px}.billing-plan-hero{border-color:var(--color-brand);background:var(--color-brand-bg, rgba(79, 70, 229, .08))}.billing-plan-name{margin:0;font-size:1.125rem;font-weight:700;color:var(--color-text)}.billing-plan-price{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-text)}.billing-plan-interval{font-size:.875rem;font-weight:400;color:var(--color-text-muted);margin-left:4px}.billing-plan-description{margin:0;font-size:.875rem;color:var(--color-text-muted);line-height:1.4;flex:1}.billing-plan-cta{margin-top:auto;width:100%}.account-activating{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 16px;color:var(--color-text-muted);text-align:center}.account-activating p{margin:0;font-size:.9375rem}.welcome-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh}.welcome-card{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;max-width:360px;width:100%}.welcome-logo{width:100%;max-width:280px;height:auto;display:block}.welcome-status{margin:0;font-size:.9375rem;color:var(--color-text-muted);line-height:1.5}.welcome-error{margin:0;padding:12px 16px;background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border);border-radius:10px;font-size:.875rem;line-height:1.5}.welcome-btn-primary{padding:12px 28px;background:var(--color-brand);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.welcome-btn-primary:hover{background:var(--color-brand-hover)}.welcome-link{color:var(--color-text-muted);text-decoration:none;font-size:.8125rem;padding:8px 12px}.welcome-link:hover{color:var(--color-text);text-decoration:underline}.portal-app{min-height:100vh;display:flex;flex-direction:column}:root{--color-brand: #4f46e5;--color-brand-hover: #4338ca;--color-brand-tint: #eef2ff;--color-bg: #f8f9fa;--color-surface: #ffffff;--color-surface-hover: #f8f9fa;--color-surface-raised: #ffffff;--color-text: #1a1a2e;--color-text-muted: #6c757d;--color-text-subtle: #adb5bd;--color-border: #e9ecef;--color-border-strong: #dee2e6;--color-border-hover: #adb5bd;--color-success-bg: #dcfce7;--color-success-text: #15803d;--color-success-border: #86efac;--color-warn-bg: #fef3c7;--color-warn-text: #92400e;--color-warn-border: #fde68a;--color-danger-bg: #fee2e2;--color-danger-text: #b91c1c;--color-danger-border: #fecaca;--color-info-bg: #dbeafe;--color-info-text: #1e40af;--color-info-border: #93c5fd;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .2);--color-toast-neutral-bg: #1a1a2e;--color-toast-neutral-text: #ffffff;--color-toast-success-bg: #15803d;--color-toast-error-bg: #b91c1c;--color-toast-info-bg: #1e40af}:root[data-theme=dark]{--color-bg: #0f0f1a;--color-surface: #1a1a2e;--color-surface-hover: #22223b;--color-surface-raised: #22223b;--color-text: #f5f5f7;--color-text-muted: #a8a8b3;--color-text-subtle: #72727d;--color-border: #2a2a3e;--color-border-strong: #3a3a4e;--color-border-hover: #555566;--color-brand-tint: #1e1b4b;--color-success-bg: #14532d;--color-success-text: #86efac;--color-success-border: #166534;--color-warn-bg: #451a03;--color-warn-text: #fcd34d;--color-warn-border: #78350f;--color-danger-bg: #450a0a;--color-danger-text: #fca5a5;--color-danger-border: #7f1d1d;--color-info-bg: #172554;--color-info-text: #93c5fd;--color-info-border: #1e40af;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6)}body{background:var(--color-bg);color:var(--color-text)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background .2s,color .2s}#root{min-height:100vh;display:flex;flex-direction:column}
