.login-portal{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background-color:var(--color-background)}.login-portal--loading{flex-direction:column;gap:1rem}.login-portal__spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:login-portal-spin .8s linear infinite}.login-portal__loading-text{color:var(--color-text-secondary);font-size:.95rem}.login-portal__card{width:100%;max-width:420px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.75rem 1.5rem 1.5rem;box-shadow:0 8px 32px var(--color-shadow)}.login-portal__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.login-portal__brand{display:flex;align-items:center;gap:.65rem;min-width:0}.login-portal__logo{flex-shrink:0;border-radius:9px}.login-portal__title{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin:0}.login-portal__theme-toggle{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:8px;background:var(--color-background);color:var(--color-text);cursor:pointer;transition:border-color .2s,color .2s}.login-portal__theme-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.login-portal__subtitle{color:var(--color-text-secondary);font-size:.95rem;margin:0 0 1.25rem}.login-portal__banner{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem;line-height:1.5}.login-portal__banner strong{display:block;margin-bottom:.25rem}.login-portal__banner--error{background-color:rgba(var(--color-error-rgb),.12);border:1px solid rgba(var(--color-error-rgb),.35);color:var(--color-text)}.login-portal__tabs{display:flex;gap:.5rem;margin-bottom:1.25rem}.login-portal__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem .5rem;font-size:.875rem;font-weight:500;border:1px solid var(--color-border);border-radius:8px;background:var(--color-background);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.login-portal__tab--active{border-color:var(--color-primary);color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08)}.login-portal__tab:hover:not(.login-portal__tab--active){border-color:var(--color-text-secondary);color:var(--color-text)}.login-portal__back{display:block;margin-bottom:1rem;padding:0;border:none;background:none;color:var(--color-primary);font-size:.875rem;cursor:pointer;text-align:left}.login-portal__back:hover{text-decoration:underline}.login-portal__form{display:flex;flex-direction:column;gap:.35rem}.login-portal__label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);margin-top:.5rem}.login-portal__label:first-of-type{margin-top:0}.login-portal__input-wrap{position:relative;width:100%;display:flex;align-items:center}.login-portal__input{width:100%;padding:.65rem .75rem;font-size:1rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-background);color:var(--color-text)}.login-portal__input--with-toggle{padding-right:2.75rem}.login-portal__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.2)}.login-portal__input:disabled{opacity:.6;cursor:not-allowed}.login-portal__password-toggle{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:color .2s,background-color .2s}.login-portal__password-toggle:hover:not(:disabled){color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.08)}.login-portal__password-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-portal__password-toggle:disabled{opacity:.5;cursor:not-allowed}.login-portal__form-error{color:var(--color-error);font-size:.875rem;margin-top:.5rem}.login-portal__form-info{color:var(--color-success);font-size:.875rem;margin-top:.5rem}.login-portal__submit{margin-top:1rem;width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:8px;cursor:pointer;transition:background .2s,opacity .2s}.login-portal__submit:hover:not(:disabled){background:var(--color-primary-dark)}.login-portal__submit:disabled{opacity:.55;cursor:not-allowed}.login-portal__link-btn{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;margin-top:1rem;padding:.5rem;border:none;background:none;color:var(--color-primary);font-size:.875rem;cursor:pointer}.login-portal__link-btn:hover{text-decoration:underline}@keyframes login-portal-spin{to{transform:rotate(360deg)}}.icon-tooltip-bubble{position:fixed;z-index:100000;padding:.4rem .65rem;font-size:.75rem;font-weight:500;line-height:1.3;color:#fff;background:#0f172af5;border-radius:8px;box-shadow:0 4px 14px #0003;pointer-events:none;max-width:min(260px,100vw - 20px);text-align:center;word-wrap:break-word}.icon-tooltip-bubble--nowrap{white-space:nowrap}.icon-tooltip-bubble--side{text-align:left}.icon-tooltip-bubble--wide{max-width:min(320px,100vw - 24px);text-align:left}.icon-tooltip-bubble--rich{font-weight:400;line-height:1.45}.icon-tooltip-bubble--rich p{margin:0 0 .45rem}.icon-tooltip-bubble--rich p:last-child{margin-bottom:0}.icon-tooltip-bubble--rich strong{font-weight:600}.icon-tooltip-bubble--rich em{font-style:italic}.sidebar{position:fixed;left:0;top:0;width:min(340px,88vw);height:100vh;height:100dvh;background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:100;overflow:hidden;transform:translate(-100%);transition:transform .3s ease,width .3s ease;box-shadow:10px 0 26px #00000026}@media(min-width:768px){.sidebar{width:300px;transform:translate(0);box-shadow:none}}.sidebar--open{transform:translate(0)}@media(min-width:768px){.sidebar--collapsed{width:60px}.sidebar--collapsed .sidebar__header{justify-content:center;padding-left:.5rem;padding-right:.5rem}.sidebar--collapsed .sidebar__header-actions{width:100%;justify-content:center}}.sidebar__mobile-toggle{position:fixed;top:calc(.9rem + env(safe-area-inset-top,0px));left:1rem;z-index:99;background-color:var(--color-primary);color:#fff;border:none;width:48px;aspect-ratio:1/1;padding:0;border-radius:8px;font-size:1.25rem;cursor:pointer;box-shadow:0 4px 12px var(--color-shadow);display:inline-flex;align-items:center;justify-content:center}@media(min-width:768px){.sidebar__mobile-toggle{display:none}}.sidebar__mobile-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__overlay{position:fixed;inset:0;background-color:#00000080;z-index:99;display:block}@media(min-width:768px){.sidebar__overlay{display:none}}.sidebar__header-actions{display:flex;align-items:center;gap:.5rem}.sidebar__collapse-toggle{background:none;border:none;font-size:1rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:none}@media(min-width:768px){.sidebar__collapse-toggle{display:flex;align-items:center;justify-content:center}}.sidebar__collapse-toggle:hover{background-color:var(--color-background);color:var(--color-text)}.sidebar__collapse-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__collapsed-content{display:flex;flex-direction:column;flex:1;min-height:0;padding:.75rem .5rem;gap:0}.sidebar__collapsed-scroll{flex:1;min-height:0;width:100%;display:flex;flex-direction:column;align-items:center;gap:0;overflow-x:hidden;overflow-y:auto}.sidebar__collapsed-scroll::-webkit-scrollbar{width:8px;height:8px}.sidebar__collapsed-scroll::-webkit-scrollbar-track{background:var(--color-background);border-radius:4px}.sidebar__collapsed-scroll::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background .2s}.sidebar__collapsed-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.sidebar__collapsed-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid var(--color-border)}.sidebar__collapsed-group:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.sidebar__collapsed-group--footer{flex-shrink:0;width:100%;padding-top:.5rem;border-top:1px solid var(--color-border);border-bottom:none;margin-bottom:0;padding-bottom:0}.sidebar__collapsed-btn{width:44px;height:44px;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:8px;font-size:1.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:var(--color-text)}.sidebar__collapsed-btn:hover{background-color:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary);transform:scale(1.05)}.sidebar__collapsed-btn:active{transform:scale(.95)}.sidebar__collapsed-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__collapsed-btn--active{background-color:rgba(var(--color-primary-rgb),.15);border-color:var(--color-primary);color:var(--color-primary)}.sidebar__collapsed-btn--scanning svg{animation:sidebar-spin 1s linear infinite}.sidebar__close-mobile{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;display:block}@media(min-width:768px){.sidebar__close-mobile{display:none}}.sidebar__close-mobile:hover{background-color:var(--color-background);color:var(--color-text)}.sidebar__close-mobile:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-border);position:sticky;top:0;background-color:var(--color-surface);z-index:10}.sidebar__brand{display:flex;align-items:center;gap:.55rem;min-width:0}.sidebar__brand-mark{flex-shrink:0;border-radius:8px}.sidebar__logo{font-size:1.2rem;font-weight:700;color:var(--color-primary);margin:0;line-height:1.15}.sidebar__theme-toggle{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center;color:var(--color-text)}.sidebar__theme-toggle:hover{background-color:var(--color-background)}.sidebar__theme-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__middle{display:flex;flex-direction:column;flex:1;min-height:0;overflow-x:hidden;overflow-y:auto}.sidebar__middle::-webkit-scrollbar{width:8px;height:8px}.sidebar__middle::-webkit-scrollbar-track{background:var(--color-background);border-radius:4px}.sidebar__middle::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background .2s}.sidebar__middle::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.sidebar__nav-blocks{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;border-bottom:1px solid var(--color-border)}.sidebar__section{display:flex;flex-direction:column;gap:.5rem}.sidebar__section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin:0;padding:0 .125rem}.sidebar__section-actions{display:flex;flex-direction:column;gap:.5rem}.sidebar__profile-select{width:100%;margin-bottom:.5rem;padding:.62rem 2.15rem .62rem .75rem;border-radius:8px;border:1px solid var(--color-border);background-color:var(--color-surface);background-image:linear-gradient(45deg,transparent 50%,var(--color-text-secondary) 50%),linear-gradient(135deg,var(--color-text-secondary) 50%,transparent 50%);background-position:calc(100% - 14px) calc(50% - 2px),calc(100% - 9px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;color:var(--color-text);font-size:.875rem;font-weight:500;line-height:1.2;-webkit-appearance:none;appearance:none;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.sidebar__profile-select:hover:not(:disabled){border-color:var(--color-primary);background-color:var(--color-background)}.sidebar__profile-select:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.2);background-color:var(--color-background)}.sidebar__profile-select:disabled{cursor:not-allowed;opacity:.72}.sidebar__profile-hint{margin:.6rem 0 0;font-size:.8rem;color:var(--color-text-secondary);line-height:1.4}.sidebar__btn{width:100%;padding:.65rem 1rem;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:flex-start;gap:.5rem;border:none}.sidebar__btn svg{flex-shrink:0}.sidebar__btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__btn--primary{background-color:var(--color-primary);color:#fff}.sidebar__btn--primary:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px var(--color-shadow)}.sidebar__btn--primary:active{transform:translateY(0)}.sidebar__btn--secondary{background-color:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border)}.sidebar__btn--secondary:hover{background-color:var(--color-background);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:0 2px 8px var(--color-shadow)}.sidebar__btn--secondary:active{transform:translateY(0)}.sidebar__nav-btn{width:100%;padding:.65rem 1rem;background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s,color .15s;display:flex;align-items:center;gap:.5rem;text-align:left}.sidebar__nav-btn svg{flex-shrink:0;color:var(--color-text-secondary)}.sidebar__nav-btn:hover{background-color:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.sidebar__nav-btn:hover svg{color:var(--color-primary)}.sidebar__nav-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__nav-btn--active{background-color:rgba(var(--color-primary-rgb),.12);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.sidebar__nav-btn--active svg{color:var(--color-primary)}.sidebar__nav-btn--scanning svg{animation:sidebar-spin 1s linear infinite}.sidebar__nav-btn-label{flex:1;min-width:0}.sidebar__blogs-row{display:flex;align-items:stretch;gap:.4rem;width:100%}.sidebar__blogs-main.sidebar__nav-btn{flex:1;min-width:0;width:auto}.sidebar__blogs-add{flex-shrink:0;width:2.35rem;aspect-ratio:1/1;align-self:center;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-primary);cursor:pointer;transition:background-color .15s ease,border-color .15s ease,transform .15s ease}.sidebar__blogs-add:hover{background:rgba(var(--color-primary-rgb),.1);border-color:var(--color-primary);color:var(--color-primary)}.sidebar__blogs-add:active{transform:scale(.96)}.sidebar__blogs-add:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__nav-btn-right{margin-left:auto;flex-shrink:0;font-size:.8125rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text-secondary)}.sidebar__scan-indicator{margin-left:auto;flex-shrink:0;display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:700;color:var(--color-primary);letter-spacing:.01em}.sidebar__scan-indicator:before{content:"";width:.55rem;height:.55rem;border-radius:999px;background:currentColor;animation:sidebar-pulse 1.1s ease-in-out infinite}.sidebar__footer{flex-shrink:0;padding:.55rem 1rem .65rem;display:flex;flex-direction:column;gap:.35rem}@media(max-width:767px){.sidebar__footer{display:none}}.sidebar__footer .sidebar__sign-out-btn,.sidebar__footer .sidebar__settings-btn{padding:.45rem .65rem;font-size:.8125rem;border-radius:7px;gap:.4rem}.sidebar__footer .sidebar__sign-out-btn svg,.sidebar__footer .sidebar__settings-btn svg{width:16px;height:16px}.sidebar__sign-out-btn{width:100%;padding:.75rem 1rem;background-color:var(--color-background);color:var(--color-error);border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.sidebar__sign-out-btn:hover{background-color:rgba(var(--color-error-rgb),.08);border-color:var(--color-error)}.sidebar__sign-out-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__settings-btn{width:100%;padding:.75rem 1rem;background-color:var(--color-background);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.sidebar__settings-btn:hover{background-color:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary)}.sidebar__settings-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar__settings-btn--active{border-color:var(--color-primary);background-color:var(--color-surface);color:var(--color-primary)}@keyframes sidebar-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes sidebar-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.7)}}.mobile-tab-bar{position:fixed;left:0;right:0;bottom:0;z-index:120;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.25rem;min-height:var(--mobile-tab-bar-height, 66px);padding:.4rem .65rem calc(.45rem + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(var(--color-primary-rgb),.14);background:color-mix(in oklab,var(--color-surface) 88%,transparent);-webkit-backdrop-filter:var(--frosted-backdrop-filter);backdrop-filter:var(--frosted-backdrop-filter);box-shadow:0 -10px 30px #00000014}.mobile-tab-bar__item{border:none;border-radius:12px;background:transparent;color:var(--color-text-secondary);min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;font-size:.7rem;font-weight:600;line-height:1.1;cursor:pointer;transition:color .2s ease,background-color .2s ease,transform .2s ease}.mobile-tab-bar__item:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.mobile-tab-bar__item:active{transform:translateY(1px)}.mobile-tab-bar__item--active{color:var(--color-primary);background:rgba(var(--color-primary-rgb),.12)}@media(min-width:768px){.mobile-tab-bar{display:none}}.delete-modal{position:relative;background-color:var(--color-surface);border-radius:16px;max-width:400px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #0006;outline:none;overflow:hidden;animation:slideUp .3s ease-out}.delete-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:2px solid var(--color-border);background:linear-gradient(to bottom,var(--color-background),var(--color-surface));flex-shrink:0}.delete-modal__header h2{margin:0;font-size:1.5rem;color:var(--color-text);font-weight:700;letter-spacing:-.02em}.delete-modal__close{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-modal__close:hover{background-color:var(--color-background);color:var(--color-text)}.delete-modal__close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.delete-modal__content{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem 2rem;min-height:0}.delete-modal__message{margin:0 0 .75rem;color:var(--color-text);font-size:1rem;line-height:1.6}.delete-modal__message strong{color:var(--color-primary);font-weight:600}.delete-modal__warning{margin:0;color:var(--color-error);font-size:.875rem;font-weight:500}.delete-modal__actions{display:flex;gap:1rem;justify-content:flex-end;padding:1.25rem 2rem;border-top:2px solid var(--color-border);background:linear-gradient(to top,var(--color-background),var(--color-surface));flex-shrink:0}.delete-modal__btn{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.delete-modal__btn:disabled{opacity:.6;cursor:not-allowed}.delete-modal__btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.delete-modal__btn--secondary{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.delete-modal__btn--secondary:disabled{opacity:.6;cursor:not-allowed}.delete-modal__btn--secondary:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.delete-modal__btn--secondary{background-color:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border)}.delete-modal__btn--secondary:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-text-secondary)}.delete-modal__btn--danger{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.delete-modal__btn--danger:disabled{opacity:.6;cursor:not-allowed}.delete-modal__btn--danger:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.delete-modal__btn--danger{background-color:var(--color-error);color:#fff;box-shadow:0 2px 8px #dc354533}.delete-modal__btn--danger:hover:not(:disabled){background-color:#c82333;transform:translateY(-2px);box-shadow:0 6px 16px #dc35454d}.delete-modal__btn--danger:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #dc354533}@media(max-width:639px){.delete-modal__header{padding:1rem 1.25rem}.delete-modal__header h2{font-size:1.25rem}.delete-modal__content{padding:1rem 1.25rem}.delete-modal__actions{flex-direction:column-reverse;align-items:stretch;padding:1rem 1.25rem;gap:.75rem}.delete-modal__btn{width:100%;justify-content:center}}.ios-notify-center{position:fixed;top:16px;right:16px;width:min(360px,100vw - 24px);z-index:3200;display:flex;flex-direction:column;gap:10px}.ios-notify{border-radius:14px;border:1px solid color-mix(in srgb,var(--color-border) 75%,transparent);background:color-mix(in srgb,var(--color-surface) 70%,transparent);box-shadow:0 10px 24px #00000026;-webkit-backdrop-filter:var(--frosted-backdrop-filter);backdrop-filter:var(--frosted-backdrop-filter);display:flex;align-items:center;justify-content:space-between;overflow:hidden;border-left-width:4px}.ios-notify__body{all:unset;cursor:pointer;display:flex;align-items:flex-start;gap:10px;padding:10px 12px;flex:1}.ios-notify__copy{display:flex;flex-direction:column;gap:2px}.ios-notify__copy strong{font-size:.88rem;color:var(--color-text);line-height:1.2}.ios-notify__copy span{font-size:.8rem;color:var(--color-text-muted);line-height:1.2}.ios-notify__close{all:unset;cursor:pointer;padding:8px 10px;color:var(--color-text-muted)}.ios-notify--success svg{color:var(--color-success, #27ae60)}.ios-notify--info svg{color:var(--color-primary)}.ios-notify--error svg{color:var(--color-error, #c0392b)}.ios-notify--success{background:color-mix(in srgb,var(--color-success, #27ae60) 12%,var(--color-surface) 88%)}.ios-notify--info{background:color-mix(in srgb,var(--color-primary) 12%,var(--color-surface) 88%)}.ios-notify--error{background:color-mix(in srgb,var(--color-error, #c0392b) 12%,var(--color-surface) 88%)}.firestore-sync-badge{position:fixed;right:1rem;bottom:1rem;z-index:121;padding:.4rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;border:1px solid rgba(255,255,255,.22);background:#111827d9;color:#f9fafb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);max-width:min(100vw - 2rem,280px)}@media(max-width:767.98px){.firestore-sync-badge{bottom:calc(1rem + var(--mobile-tab-bar-height, 66px) + env(safe-area-inset-bottom,0px))}}.feedback-modal{position:relative;background-color:var(--color-surface);border-radius:16px;max-width:480px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #0006;outline:none;overflow:hidden}.feedback-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.feedback-modal__header h2{margin:0;font-size:1.25rem;color:var(--color-text);font-weight:700}.feedback-modal__close{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:8px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center}.feedback-modal__close:hover{background-color:var(--color-background);color:var(--color-text)}.feedback-modal__close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.feedback-modal__form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.feedback-modal__lede{margin:0;font-size:.875rem;line-height:1.5;color:var(--color-text-secondary)}.feedback-modal__field{display:flex;flex-direction:column;gap:.35rem}.feedback-modal__field label{font-size:.8125rem;font-weight:600;color:var(--color-text)}.feedback-modal__field select{padding:.5rem .65rem;border-radius:10px;border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text);font-size:.875rem}.feedback-modal__textarea{width:100%;resize:vertical;min-height:140px;padding:.65rem .75rem;border-radius:10px;border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text);font:inherit;font-size:.9rem;line-height:1.45}.feedback-modal__textarea:focus{outline:2px solid rgba(var(--color-primary-rgb),.45);outline-offset:1px}.feedback-modal__actions{display:flex;justify-content:flex-end;gap:.65rem;margin-top:.25rem}.feedback-modal__btn{padding:.5rem 1rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;border:1px solid transparent}.feedback-modal__btn--secondary{background:transparent;border-color:var(--color-border);color:var(--color-text)}.feedback-modal__btn--secondary:hover{background:var(--color-background)}.feedback-modal__btn--primary{background:var(--color-primary);color:var(--color-primary-contrast, #fff)}.feedback-modal__btn--primary:disabled{opacity:.55;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;-webkit-backdrop-filter:var(--frosted-backdrop-filter);backdrop-filter:var(--frosted-backdrop-filter);display:flex;align-items:center;justify-content:center;z-index:1000;padding:max(.75rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));animation:fadeIn .2s ease-out;overflow-y:auto}@supports (overscroll-behavior: contain){.modal-overlay{overscroll-behavior:contain}}.modal-overlay--elevated{z-index:2000}.modal-ai-rainbow-wrap{position:relative;z-index:0;display:inline-block;max-width:100%;vertical-align:top}.modal-ai-rainbow-wrap .ReactModal__Content{position:relative;z-index:1}.modal-ai-rainbow-glow{pointer-events:none;position:absolute;inset:-14px;z-index:0;border-radius:calc(clamp(14px,1.35rem,24px) + 14px);opacity:0;transform-origin:center center;animation:modalAiRainbowIntroShell .48s cubic-bezier(.34,1.45,.64,1) forwards}.modal-ai-rainbow-glow__burst{position:absolute;inset:-10px;z-index:0;border-radius:inherit;background:conic-gradient(from 200deg,#ff00d4,#ff6a00,#ffea00,#00ff9d,#00cfff 220deg,#a855ff,#ff00d4 360deg);filter:blur(22px) saturate(1.65);opacity:.92;animation:modalAiRainbowSpin 3.1s linear infinite reverse;box-shadow:0 0 18px 6px #ff50b48c,0 0 36px 14px #00d2ff66,0 0 56px 22px #ffdc3c4d,0 0 80px 32px #a05aff38}.modal-ai-rainbow-glow__ring{position:absolute;inset:0;z-index:1;border-radius:inherit;box-sizing:border-box;padding:4px;background:conic-gradient(from 220deg,#ff00d4,#ff6a00,#ffea00 100deg,#00ff9d 155deg,#00cfff 205deg,#a855ff 275deg,#ff00d4 360deg);filter:saturate(1.5);animation:modalAiRainbowSpin 2.65s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;box-shadow:0 0 0 1px #ffffff1f,0 0 14px 3px #ff78c873,0 0 28px 10px #50c8ff59,0 0 48px 18px #ffc85033}.modal-ai-rainbow-glow--exit{animation:modalAiRainbowOutroShell .52s ease-in forwards}.modal-ai-rainbow-glow--exit .modal-ai-rainbow-glow__burst{animation:modalAiRainbowSpin 3.1s linear infinite reverse,modalAiRainbowBurstFade .52s ease-in forwards}.modal-ai-rainbow-glow--exit .modal-ai-rainbow-glow__ring{animation:modalAiRainbowSpin 2.65s linear infinite,modalAiRainbowRingFade .52s ease-in forwards}@keyframes modalAiRainbowIntroShell{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes modalAiRainbowOutroShell{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes modalAiRainbowSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes modalAiRainbowBurstFade{to{opacity:0;filter:blur(32px) saturate(.35)}}@keyframes modalAiRainbowRingFade{to{opacity:0;filter:saturate(.35)}}@media(prefers-reduced-motion:reduce){.modal-ai-rainbow-glow{animation:modalAiRainbowIntroShellReduced .22s ease-out forwards}.modal-ai-rainbow-glow__burst,.modal-ai-rainbow-glow__ring{animation:none}.modal-ai-rainbow-glow--exit{animation:modalAiRainbowOutroShellReduced .22s ease-in forwards}.modal-ai-rainbow-glow--exit .modal-ai-rainbow-glow__burst{animation:modalAiRainbowBurstFade .22s ease-in forwards}.modal-ai-rainbow-glow--exit .modal-ai-rainbow-glow__ring{animation:modalAiRainbowRingFade .22s ease-in forwards}@keyframes modalAiRainbowIntroShellReduced{0%{opacity:0}to{opacity:.9}}@keyframes modalAiRainbowOutroShellReduced{0%{opacity:.9}to{opacity:0}}}:root[data-theme=light]{--color-primary: #007BFF;--color-primary-dark: #0056b3;--color-primary-rgb: 0, 123, 255;--color-secondary: #6C757D;--color-background: #F8F9FA;--color-surface: #FFFFFF;--color-surface-rgb: 255, 255, 255;--color-text: #212529;--color-text-secondary: #6C757D;--color-border: #DEE2E6;--color-success: #28A745;--color-success-rgb: 40, 167, 69;--color-warning: #FFC107;--color-error: #DC3545;--color-error-rgb: 220, 53, 69;--color-shadow: rgba(0, 0, 0, .1);--mobile-tab-bar-height: 66px}:root[data-theme=dark]{--color-primary: #4A9EFF;--color-primary-dark: #2E7CD6;--color-primary-rgb: 74, 158, 255;--color-secondary: #9CA3AF;--color-background: #121212;--color-surface: #1E1E1E;--color-surface-rgb: 30, 30, 30;--color-text: #E5E5E5;--color-text-secondary: #9CA3AF;--color-border: #333333;--color-success: #4CAF50;--color-success-rgb: 76, 175, 80;--color-warning: #FF9800;--color-error: #F44336;--color-error-rgb: 244, 67, 54;--color-shadow: rgba(0, 0, 0, .3);--mobile-tab-bar-height: 66px}:root{--frosted-backdrop-filter: saturate(180%) blur(20px)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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;background-color:var(--color-background);color:var(--color-text);line-height:1.6}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.app{display:flex;height:100vh;height:100dvh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;margin-left:0;transition:margin-left .3s ease}.main-content>*{flex:1;min-height:0;min-width:0;display:flex;flex-direction:column}@media(min-width:768px){.main-content{margin-left:300px}.main-content--sidebar-collapsed{margin-left:60px}}@media(max-width:767px){.main-content{padding-top:calc(1.5rem + env(safe-area-inset-top,0px) + 48px);padding-bottom:calc(var(--mobile-tab-bar-height) + env(safe-area-inset-bottom,0px))}}.main-route-transition{flex:1;min-height:0;min-width:0;display:flex;flex-direction:column}.welcome-screen{box-sizing:border-box;flex:1;min-height:0;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow-x:hidden;overflow-y:auto;padding:1.5rem 1.25rem 2.25rem;text-align:center;gap:1rem}.welcome-screen h1{font-size:clamp(1.5rem,5vw,2.5rem);margin-bottom:.2rem;color:var(--color-primary);line-height:1.2}.welcome-screen p{font-size:clamp(.95rem,2.7vw,1.2rem);color:var(--color-text-secondary);max-width:36rem}.welcome-screen__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}.welcome-screen__action{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:10px;padding:.55rem .9rem;font-weight:600;cursor:pointer}.welcome-screen__action--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.welcome-screen__showcase{margin-top:.5rem;width:min(1080px,100%);display:grid;gap:.75rem;grid-template-columns:repeat(3,minmax(0,1fr))}@media(max-width:900px){.welcome-screen__showcase{grid-template-columns:1fr;max-width:640px}}.welcome-screen__checklist{width:min(640px,100%);text-align:left;border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);padding:.75rem .85rem .85rem}.welcome-screen__checklist-header{display:flex;align-items:center;justify-content:space-between;gap:.65rem;margin-bottom:.55rem}.welcome-screen__checklist-header h2{margin:0;font-size:.92rem;color:var(--color-text);display:inline-flex;align-items:center;gap:.4rem}.welcome-screen__checklist-header span{font-size:.75rem;color:var(--color-text-secondary);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em}.welcome-screen__checklist-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.welcome-screen__checklist-item{border:1px solid var(--color-border);border-radius:9px;padding:.45rem .5rem .45rem .45rem;display:flex;align-items:center;justify-content:space-between;gap:.55rem;background:rgba(var(--color-primary-rgb),.03)}.welcome-screen__checklist-item.is-complete{border-color:rgba(var(--color-success-rgb),.35);background:rgba(var(--color-success-rgb),.08)}.welcome-screen__checklist-main{display:flex;align-items:flex-start;gap:.45rem;min-width:0;flex:1}.welcome-screen__checklist-status{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;margin-top:.06rem;color:var(--color-text-secondary)}.welcome-screen__checklist-item.is-complete .welcome-screen__checklist-status{color:var(--color-success)}.welcome-screen__checklist-topic{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:8px;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);margin-top:0}.welcome-screen__checklist-item.is-complete .welcome-screen__checklist-topic{background:rgba(var(--color-success-rgb),.15);color:var(--color-success)}.welcome-screen__checklist-copy{min-width:0;flex:1}.welcome-screen__checklist-title{margin:0;font-size:.84rem;color:var(--color-text);font-weight:700;line-height:1.25}.welcome-screen__checklist-description{margin:.12rem 0 0;font-size:.74rem;line-height:1.35;color:var(--color-text-secondary);max-width:none}.welcome-screen__checklist-action{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:7px;padding:.32rem .55rem;font-size:.72rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;align-self:center}.welcome-screen__checklist-action:hover{border-color:var(--color-primary);color:var(--color-primary)}.welcome-screen__card{text-align:left;border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);padding:.85rem .95rem}.welcome-screen__card h2{margin:0;font-size:.92rem;color:var(--color-text);display:flex;align-items:center;gap:.45rem}.welcome-screen__card p{margin-top:.4rem;font-size:.82rem;line-height:1.45;color:var(--color-text-secondary);max-width:none}.welcome-screen__card-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:8px;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary)}@media(max-width:767px){.welcome-screen__checklist-item{flex-wrap:wrap;align-items:flex-start}.welcome-screen__checklist-action{width:100%;text-align:center;margin-top:.15rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-contrast:more){*:focus-visible{outline-width:3px}}.fade-in{animation:fadeIn .3s ease-out}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background-color:var(--color-background)}.error-boundary__content{max-width:600px;text-align:center;padding:2rem;background-color:var(--color-surface);border-radius:8px;box-shadow:0 4px 6px var(--color-shadow)}.error-boundary__title{font-size:2rem;margin-bottom:1rem;color:var(--color-error)}.error-boundary__message{font-size:1.1rem;margin-bottom:2rem;color:var(--color-text-secondary)}.error-boundary__details{margin:1.5rem 0;text-align:left;background-color:var(--color-background);padding:1rem;border-radius:4px;border:1px solid var(--color-border)}.error-boundary__details summary{cursor:pointer;font-weight:600;margin-bottom:.5rem;color:var(--color-text)}.error-boundary__stack{font-size:.85rem;color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-all;overflow-x:auto}.error-boundary__icon{font-size:4rem;margin-bottom:1rem;animation:shake .5s ease-in-out}.error-boundary__id{font-size:.85rem;color:var(--color-text-secondary);margin:.5rem 0;font-family:monospace}.error-boundary__actions{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap;justify-content:center}.error-boundary__button{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.error-boundary__button:disabled{opacity:.6;cursor:not-allowed}.error-boundary__button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.error-boundary__button{padding:.75rem 1.5rem;font-size:1rem;border-radius:4px;font-weight:500}.error-boundary__button--primary{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.error-boundary__button--primary:disabled{opacity:.6;cursor:not-allowed}.error-boundary__button--primary:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.error-boundary__button--primary{background-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #00000026}.error-boundary__button--primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px #0003}.error-boundary__button--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #00000026}.error-boundary__button--secondary{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.error-boundary__button--secondary:disabled{opacity:.6;cursor:not-allowed}.error-boundary__button--secondary:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.error-boundary__button--secondary{background-color:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border)}.error-boundary__button--secondary:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-text-secondary)}.error-boundary__button--secondary{background-color:var(--color-bg-secondary, var(--color-surface))}.error-boundary__button--secondary:hover{background-color:var(--color-bg-tertiary, var(--color-background))}.error-boundary__button:active{transform:translateY(0)}.error-boundary__details-content{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.error-boundary__detail-section{display:flex;flex-direction:column;gap:.5rem}.error-boundary__detail-section strong{color:var(--color-text);font-weight:600}
