.user-menu{position:relative;margin-left:var(--spacing-xs)}.user-avatar-button{background:none;border:none;padding:0;border-radius:50%;cursor:pointer;transition:transform .2s var(--ease)}.user-avatar-button:hover{transform:translateY(-1px)}.user-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:500;font-size:.95rem;color:var(--paper);background:var(--ink);border:1px solid var(--ink);transition:var(--transition)}[data-theme=dark] .user-avatar{background:var(--accent);border-color:var(--accent);color:var(--on-inverse)}.user-avatar-button:hover .user-avatar{background:var(--accent);border-color:var(--accent);color:var(--paper)}.user-menu-dropdown{position:absolute;top:calc(100% + var(--spacing-sm));right:0;min-width:260px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);overflow:hidden;z-index:1000;animation:cokitab-fade-up .22s var(--ease-out) both}.user-menu-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--surface-2);border-bottom:1px solid var(--border)}.user-avatar-large{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:500;font-size:1.2rem;background:var(--accent);color:var(--paper);flex-shrink:0}.user-menu-info{flex:1;min-width:0}.user-menu-name{font-family:var(--font-display);font-size:1.05rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-email{font-size:.8125rem;color:var(--text-mute);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.user-menu-divider{height:1px;background:var(--border);margin:0}.user-menu-item{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:.85rem 1.1rem;background:none;border:none;text-align:left;font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--text);cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease)}.user-menu-item:hover{background:var(--surface-2);color:var(--accent)}.user-menu-item.danger{color:var(--rust)}.user-menu-item.danger:hover{background:#a33a2a14;color:var(--rust)}.menu-icon{font-size:1rem;width:20px;text-align:center;opacity:.75}@media (max-width: 860px){.user-menu{display:none}}.header-search{position:relative;width:100%}.header-search:before{content:"";position:absolute;top:50%;left:.95rem;transform:translateY(-50%);width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236e6256' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.2-3.2'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.8;pointer-events:none}[data-theme=dark] .header-search:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a2957f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.2-3.2'/%3E%3C/svg%3E")}.header-search-input{width:100%;padding:.55rem 1rem .55rem 2.35rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text);font-family:var(--font-body);font-size:.9375rem;transition:var(--transition)}.header-search-input::placeholder{color:var(--text-mute);font-style:italic}.header-search-input:focus{outline:none;border-color:var(--accent);background:var(--bg);box-shadow:0 0 0 4px var(--accent-wash)}.notif-trigger{position:relative}.notif-bell-wrap{position:relative;display:grid;place-items:center}.notif-badge{position:absolute;top:-5px;right:-6px;min-width:16px;height:16px;padding:0 3px;background:var(--accent);color:var(--paper);border-radius:var(--radius-full);font-size:.625rem;font-weight:700;line-height:16px;text-align:center;letter-spacing:0;border:1.5px solid var(--bg);pointer-events:none}.notif-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:180;opacity:0;pointer-events:none;transition:opacity .28s var(--ease)}.notif-backdrop.open{opacity:1;pointer-events:auto}.notif-panel{position:fixed;left:0;right:0;bottom:0;max-height:72vh;background:var(--surface);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:181;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .34s var(--ease-out);padding-bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0px));box-shadow:0 -12px 40px -10px #0000002e}.notif-panel.open{transform:translateY(0)}.notif-panel:before{content:"";display:block;width:36px;height:4px;background:var(--border-strong);border-radius:var(--radius-full);margin:.75rem auto 0;flex-shrink:0}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem .6rem;border-bottom:1px solid var(--border);flex-shrink:0}.notif-panel-title{font-family:var(--font-display);font-size:1.125rem;font-variation-settings:"opsz" 36,"SOFT" 50,"wght" 500;color:var(--text);margin:0;letter-spacing:-.01em}.notif-close{display:grid;place-items:center;width:32px;height:32px;border:none;background:var(--surface-2);border-radius:var(--radius-full);color:var(--text-mute);cursor:pointer;transition:var(--transition)}.notif-close:hover{background:var(--surface-3);color:var(--text)}.notif-panel-body{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:3rem 2rem;text-align:center;color:var(--text-faint)}.notif-empty svg{opacity:.35}.notif-empty p{font-family:var(--font-display);font-style:italic;font-size:1rem;color:var(--text-mute);margin:0}.notif-empty span{font-size:.8125rem;color:var(--text-faint);max-width:28ch}.notif-list{list-style:none;padding:.4rem 0}.notif-item{width:100%;display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;transition:background .18s var(--ease);border-bottom:1px solid var(--border)}.notif-item:last-child{border-bottom:none}.notif-item:hover,.notif-item:active{background:var(--surface-2)}.notif-avatar{width:36px;height:36px;min-width:36px;border-radius:50%;color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:.8125rem;font-weight:500;font-style:italic;box-shadow:inset 0 -2px 4px #00000026;flex-shrink:0}.notif-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.notif-item-header{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap}.notif-user{font-size:.875rem;font-weight:600;color:var(--text)}.notif-reading{font-size:.75rem;color:var(--accent);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:18ch}.notif-reading:before{content:"em ";color:var(--text-faint);font-style:italic;font-weight:400}.notif-content{font-size:.8125rem;color:var(--text-soft);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0}.notif-time{font-size:.6875rem;color:var(--text-faint);white-space:nowrap;flex-shrink:0;padding-top:1px}.install-banner{position:fixed;left:1rem;right:1rem;bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0px) + .75rem);z-index:85;display:flex;align-items:center;gap:.75rem;padding:.75rem .85rem;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:install-slide-up .38s var(--ease-out) both}@keyframes install-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}.install-banner-icon img{border-radius:var(--radius);display:block}.install-banner-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.install-banner-title{font-size:.9375rem;font-weight:600;color:var(--text);line-height:1.2}.install-banner-sub{font-size:.75rem;color:var(--text-mute);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.install-banner-cta{flex-shrink:0;padding:.45rem 1rem;background:var(--accent);color:var(--paper);border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .18s var(--ease);white-space:nowrap}.install-banner-cta:hover{background:var(--accent-hot)}.install-banner-close{display:grid;place-items:center;width:28px;height:28px;border:none;background:var(--surface-2);border-radius:50%;color:var(--text-faint);cursor:pointer;flex-shrink:0;transition:var(--transition)}.install-banner-close:hover{color:var(--text);background:var(--surface-3)}@media (min-width: 861px){.install-banner{display:none}}.ios-guide-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;animation:cokitab-fade .22s var(--ease) both}.ios-guide{position:fixed;left:0;right:0;bottom:0;z-index:201;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:0 1.5rem calc(2rem + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:center;text-align:center;gap:.6rem;box-shadow:0 -8px 32px -8px #0003;animation:install-slide-up .36s var(--ease-out) both}.ios-guide-handle{width:36px;height:4px;background:var(--border-strong);border-radius:var(--radius-full);margin:.75rem auto .5rem;flex-shrink:0}.ios-guide-close{position:absolute;top:1rem;right:1rem;display:grid;place-items:center;width:30px;height:30px;border:none;background:var(--surface-2);border-radius:50%;color:var(--text-mute);cursor:pointer;transition:var(--transition)}.ios-guide-close:hover{color:var(--text)}.ios-guide-icon{border-radius:var(--radius-md);margin-top:.25rem}.ios-guide-title{font-family:var(--font-display);font-size:1.375rem;font-variation-settings:"opsz" 48,"SOFT" 60,"wght" 500;color:var(--text);letter-spacing:-.015em;margin:0}.ios-guide-sub{font-size:.875rem;color:var(--text-mute);max-width:30ch;margin:0;line-height:1.5}.ios-guide-steps{list-style:none;width:100%;display:flex;flex-direction:column;gap:0;margin:.5rem 0 0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.ios-guide-steps li{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border-bottom:1px solid var(--border);text-align:left;font-size:.875rem;color:var(--text-soft);line-height:1.4}.ios-guide-steps li:last-child{border-bottom:none}.ios-guide-steps li strong{color:var(--text);font-weight:600}.ios-step-num{display:grid;place-items:center;width:24px;height:24px;min-width:24px;background:var(--accent);color:var(--paper);border-radius:50%;font-size:.75rem;font-weight:700;line-height:1}.ios-step-icon{margin-left:auto;color:var(--accent);flex-shrink:0;display:grid;place-items:center}.ios-guide-done{width:100%;padding:.85rem;background:var(--accent);color:var(--paper);border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s var(--ease);margin-top:.5rem}.ios-guide-done:hover{background:var(--accent-hot)}.layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;overflow-x:hidden;overscroll-behavior-y:contain}.site-header{position:sticky;top:0;z-index:100;background:color-mix(in oklab,var(--bg) 82%,transparent);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--border)}.site-header-inner{max-width:var(--container);margin:0 auto;padding:0 clamp(1rem,3vw,2rem);height:var(--header-h);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--spacing-lg)}.brand{display:inline-flex;align-items:center;gap:.625rem;color:var(--text);text-decoration:none;transition:var(--transition)}.brand:hover{color:var(--accent)}.logo-mark{color:var(--accent);flex-shrink:0}.brand-text{display:flex;flex-direction:column;line-height:1}.brand-name{font-family:var(--font-display);font-size:1.375rem;font-weight:500;font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 80;letter-spacing:-.01em;color:var(--text)}.brand-tag{font-family:var(--font-body);font-size:.625rem;text-transform:uppercase;letter-spacing:.22em;color:var(--text-mute);margin-top:.25rem}.site-header-search{min-width:0;max-width:440px;justify-self:center;width:100%}.site-nav{display:flex;align-items:center;gap:var(--spacing-xs);justify-self:end}.nav-link{position:relative;padding:.55rem .875rem;font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--text-soft);text-decoration:none;border-radius:var(--radius);transition:var(--transition)}.nav-link:hover{color:var(--text);background:var(--surface-2)}.nav-link.is-active{color:var(--text)}.nav-link.is-active:after{content:"";position:absolute;left:.875rem;right:.875rem;bottom:2px;height:2px;background:var(--accent);border-radius:1px}.nav-cta{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1.05rem;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--paper);background:var(--ink);border:1px solid var(--ink);border-radius:var(--radius-full);text-decoration:none;transition:var(--transition);margin-left:var(--spacing-xs)}[data-theme=dark] .nav-cta{background:var(--accent);border-color:var(--accent);color:var(--on-inverse)}.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:var(--paper);transform:translateY(-1px);box-shadow:var(--shadow)}.nav-cta>span{font-size:1.05em;line-height:1;margin-right:.05rem}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;color:var(--text-soft);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);margin-left:var(--spacing-xs)}.theme-toggle:hover{color:var(--accent);border-color:var(--accent);transform:rotate(-6deg)}.site-main{flex:1;width:100%;max-width:var(--container);margin:0 auto;padding:clamp(1.5rem,4vw,3rem) clamp(1rem,3vw,2rem) clamp(2rem,5vw,4rem);animation:cokitab-fade .42s var(--ease-out) both}.site-footer{border-top:1px solid var(--border);padding:var(--spacing-2xl) var(--spacing-lg);margin-top:auto}.site-footer-inner{max-width:var(--container-narrow);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);text-align:center}.site-footer-copy{font-family:var(--font-body);color:var(--text-mute);font-size:.9375rem;display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.site-footer-copy .display{font-size:1.125rem;color:var(--text)}.site-footer-dot{color:var(--text-faint)}.site-footer-meta{font-size:.75rem;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase}.mobile-bottom-nav{display:none}@media (max-width: 860px){.site-header-inner{grid-template-columns:auto auto;height:auto;padding-top:.75rem;padding-bottom:.75rem;gap:var(--spacing-sm)}.site-header-search{grid-column:1 / -1;max-width:100%;justify-self:stretch;order:3}.brand-tag,.site-nav .nav-link,.site-nav .nav-cta{display:none}.site-main{padding-bottom:calc(var(--mobile-nav-h) + var(--spacing-xl))}.site-footer{padding-bottom:calc(var(--mobile-nav-h) + var(--spacing-lg))}.mobile-bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:0;right:0;width:100vw;bottom:0;height:var(--mobile-nav-h);padding:0 .25rem;background:color-mix(in oklab,var(--bg) 92%,transparent);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-top:1px solid var(--border);z-index:90;padding-bottom:env(safe-area-inset-bottom,0);overscroll-behavior:none;touch-action:pan-x pinch-zoom}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:none;color:var(--text-mute);font-family:var(--font-body);font-size:.6875rem;font-weight:500;text-decoration:none;transition:color .18s var(--ease);position:relative;padding:.25rem .15rem}.bottom-nav-item svg{stroke-width:1.6}.bottom-nav-item.is-active{color:var(--accent)}.bottom-nav-item.is-active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--accent);border-radius:0 0 2px 2px}.bottom-nav-create{color:var(--accent)}.bottom-nav-plus{display:grid;place-items:center;width:34px;height:34px;background:var(--accent);color:var(--paper);border-radius:50%;font-size:1.2rem;line-height:1;box-shadow:0 4px 10px -2px var(--accent-wash),0 2px 4px #1a141033;margin-bottom:-4px}.bottom-nav-create.is-active:before{display:none}.site-header{position:sticky}}@media (max-width: 420px){.brand-name{font-size:1.25rem}.bottom-nav-item span{font-size:.625rem}}.error-boundary{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.error-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:500px;text-align:center}.error-content h2{color:#dc3545;margin-bottom:1rem}.error-content p{color:#666;margin-bottom:1.5rem}.error-details{margin:1.5rem 0;text-align:left}.error-details summary{cursor:pointer;color:#007bff;margin-bottom:.5rem}.error-details pre{background:#f5f5f5;padding:1rem;border-radius:4px;overflow-x:auto;font-size:.875rem;color:#333}.reload-button{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.reload-button:hover{background-color:#0056b3}.toast{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:.9rem 1.15rem;min-width:280px;max-width:460px;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-left-width:4px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-family:var(--font-body);font-size:.9375rem;animation:toast-slide-in .28s var(--ease-out) both}@keyframes toast-slide-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.toast-success{border-left-color:var(--sage)}.toast-error{border-left-color:var(--rust)}.toast-info{border-left-color:var(--accent)}.toast-warning{border-left-color:var(--clay)}.toast-message{flex:1;font-weight:500;line-height:1.4}.toast-close{display:grid;place-items:center;width:28px;height:28px;background:transparent;border:none;color:var(--text-mute);font-size:1.25rem;line-height:1;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.toast-close:hover{background:var(--surface-2);color:var(--text)}.toast-container{position:fixed;top:80px;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.75rem}@media (max-width: 768px){.toast-container{right:.5rem;left:.5rem;top:70px}.toast-container .toast{min-width:auto;max-width:100%}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);min-height:320px;padding:var(--spacing-2xl)}.spinner{width:44px;height:44px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:cokitab-spin .9s linear infinite;position:relative}.spinner:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:1px dashed var(--border);animation:cokitab-spin 4s linear infinite reverse;opacity:.5}@keyframes cokitab-spin{to{transform:rotate(360deg)}}.loading-container p{font-family:var(--font-display);font-style:italic;font-variation-settings:"opsz" 72,"SOFT" 60,"wght" 400;color:var(--text-mute);font-size:1rem;animation:cokitab-fade 1.4s ease-in-out infinite alternate}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-shimmer{background:linear-gradient(90deg,var(--surface-3) 25%,var(--surface-2) 50%,var(--surface-3) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s linear infinite}.skeleton-shimmer--inverse{background:linear-gradient(90deg,#ffffff12 25%,#ffffff24,#ffffff12 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s linear infinite}.skeleton-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.skeleton-card-cover{width:100%;aspect-ratio:2 / 3}.skeleton-card-body{padding:.6rem;display:flex;flex-direction:column;gap:5px}.skeleton-card-badges{display:flex;gap:4px;margin-top:2px}.btn{--btn-fg: var(--paper);--btn-bg: var(--ink);--btn-border: var(--ink);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-fg);font-family:var(--font-body);font-weight:600;font-size:.9375rem;letter-spacing:.01em;border-radius:var(--radius-full);cursor:pointer;transition:transform .18s var(--ease),background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease);text-decoration:none;white-space:nowrap;line-height:1}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{--btn-bg: var(--ink);--btn-fg: var(--paper);--btn-border: var(--ink)}[data-theme=dark] .btn-primary{--btn-bg: var(--accent);--btn-fg: var(--on-inverse);--btn-border: var(--accent)}.btn-primary:hover:not(:disabled){--btn-bg: var(--accent);--btn-border: var(--accent);--btn-fg: var(--paper);box-shadow:0 10px 22px -10px var(--accent-wash),0 4px 10px -6px #1a141038}[data-theme=dark] .btn-primary:hover:not(:disabled){--btn-bg: var(--accent-hot);--btn-border: var(--accent-hot);--btn-fg: var(--on-inverse)}.btn-secondary{--btn-bg: var(--surface-2);--btn-fg: var(--text);--btn-border: var(--border-strong)}.btn-secondary:hover:not(:disabled){--btn-bg: var(--surface-3);--btn-border: var(--text-mute)}.btn-outline{--btn-bg: transparent;--btn-fg: var(--text);--btn-border: var(--border-strong)}.btn-outline:hover:not(:disabled){--btn-bg: var(--surface-2);--btn-fg: var(--accent);--btn-border: var(--accent)}.btn-danger{--btn-bg: var(--rust);--btn-fg: var(--paper);--btn-border: var(--rust)}.btn-danger:hover:not(:disabled){--btn-bg: #8a2d1e;--btn-border: #8a2d1e;box-shadow:0 10px 22px -10px #a33a2a66}.btn-small{padding:.5rem 1rem;font-size:.8125rem}.btn-medium{padding:.75rem 1.35rem;font-size:.9375rem}.btn-large{padding:.95rem 1.75rem;font-size:1rem;letter-spacing:.02em}@media (max-width: 640px){.btn-large{padding:.85rem 1.5rem;font-size:.9375rem}}.qps-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;animation:qps-fade-in .18s var(--ease) both}@keyframes qps-fade-in{0%{opacity:0}to{opacity:1}}.qps-sheet{width:100%;max-width:480px;margin:0 auto;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1rem 1.5rem 2.5rem;padding-bottom:max(2.5rem,calc(env(safe-area-inset-bottom) + 1.5rem));box-shadow:0 -8px 40px #0000002e;animation:qps-slide-up .24s var(--ease-out) both}@keyframes qps-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.qps-handle{width:40px;height:4px;border-radius:2px;background:var(--border-strong);margin:0 auto 1.25rem}.qps-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.qps-eyebrow{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin:0 0 .2rem}.qps-title{font-family:var(--font-display);font-size:1.25rem;font-variation-settings:"opsz" 36,"SOFT" 50,"wght" 500;color:var(--text);margin:0;line-height:1.2}.qps-close{flex-shrink:0;display:grid;place-items:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-mute);cursor:pointer;transition:var(--transition)}.qps-close:hover{color:var(--text);border-color:var(--border-strong)}.qps-form{display:flex;flex-direction:column;gap:1.25rem}.qps-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.qps-field{display:flex;flex-direction:column;gap:.4rem}.qps-field label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute)}.qps-field input{width:100%;padding:.65rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:1.125rem;font-weight:500;text-align:center;transition:var(--transition);-moz-appearance:textfield}.qps-field input::-webkit-outer-spin-button,.qps-field input::-webkit-inner-spin-button{-webkit-appearance:none}.qps-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}.qps-error{font-size:.6875rem;color:var(--error, #c0392b)}.qps-submit{width:100%;padding:.875rem;background:var(--accent);color:var(--paper);border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.qps-submit:hover:not(:disabled){background:var(--accent-hot)}.qps-submit:disabled{opacity:.6;cursor:not-allowed}.dashboard-page{width:100%;animation:cokitab-fade-up .48s var(--ease-out) both}.dashboard-header{position:relative;display:grid;grid-template-columns:1fr auto;align-items:end;gap:var(--spacing-2xl);padding:clamp(1.5rem,4vw,2.75rem) 0 clamp(1.5rem,3vw,2.25rem);margin-bottom:var(--spacing-xl);border-bottom:1px solid var(--border)}.dashboard-header:before{content:"";position:absolute;left:0;top:0;width:48px;height:3px;background:var(--accent)}.dashboard-header-text{display:flex;flex-direction:column;gap:.75rem;max-width:58ch}.dashboard-header h1{font-family:var(--font-display);font-size:clamp(2.25rem,4.5vw + .5rem,3.75rem);font-variation-settings:"opsz" 144,"SOFT" 50,"wght" 400;line-height:1.05;letter-spacing:-.025em;color:var(--text);background:none;-webkit-text-fill-color:currentColor}.dashboard-name{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100,"wght" 400}.dashboard-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-md);padding-bottom:.4rem}.dashboard-header-stats{display:flex;gap:var(--spacing-xl)}.dashboard-stat{display:flex;flex-direction:column;gap:.2rem;text-align:right}.dashboard-stat-value{font-family:var(--font-display);font-style:italic;font-size:2.75rem;font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400;color:var(--text);line-height:1}.dashboard-stat-label{display:flex;align-items:center;gap:3px;font-size:.6875rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute)}.new-reading-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--ink);color:var(--paper);border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:.8125rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}.new-reading-btn:hover{background:var(--accent);transform:translateY(-1px)}[data-theme=dark] .new-reading-btn{background:var(--surface-3);color:var(--text)}[data-theme=dark] .new-reading-btn:hover{background:var(--accent);color:var(--paper)}.filter-tabs{display:flex;gap:.4rem;margin-bottom:var(--spacing-xl);padding:.3rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;width:fit-content;max-width:100%}.filter-tabs::-webkit-scrollbar{display:none}.tab{position:relative;padding:.55rem 1.1rem;border:none;background:transparent;color:var(--text-soft);font-family:var(--font-body);font-weight:500;font-size:.875rem;cursor:pointer;border-radius:var(--radius-full);transition:var(--transition);white-space:nowrap}.tab:hover{color:var(--text)}.tab.active{background:var(--ink);color:var(--paper)}[data-theme=dark] .tab.active{background:var(--accent);color:var(--on-inverse)}.tab:after{display:none}.empty-state h2{font-size:clamp(1.5rem,3vw,2rem);font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400;font-style:italic;color:var(--text);margin:0}.empty-state p{color:var(--text-mute);max-width:52ch;margin:0;font-size:1rem;line-height:1.6}.empty-state-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center;margin-top:var(--spacing-sm)}.readings-inbox{display:flex;flex-direction:column}@keyframes thread-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:none}}.thread-item{display:flex;align-items:center;gap:1rem;padding:.85rem .6rem;border-bottom:1px solid var(--border);cursor:pointer;position:relative;transition:background .18s var(--ease),border-color .18s var(--ease),padding .18s var(--ease),border-radius .18s var(--ease);animation:thread-in .34s var(--ease-out) both;animation-delay:calc(var(--thread-index, 0) * 38ms)}.thread-item:first-child{border-top:1px solid var(--border)}.thread-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--accent);border-radius:0 3px 3px 0;transition:height .38s var(--ease-out)}.thread-item:hover{background:var(--surface-2);border-bottom-color:transparent;border-radius:var(--radius-md);padding-left:1rem;padding-right:.6rem}.thread-item:hover:before{height:56%}.thread-item:hover+.thread-item{border-top:1px solid transparent}.thread-item--planned{opacity:.72}.thread-item--planned:before{background:var(--text-faint)}.thread-cover{width:50px;flex-shrink:0;aspect-ratio:2 / 3;border-radius:5px;overflow:hidden;background:var(--surface-3);position:relative;box-shadow:var(--shadow);transition:box-shadow .2s var(--ease)}.thread-item:hover .thread-cover{box-shadow:var(--shadow-md)}.thread-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s var(--ease-out)}.thread-item:hover .thread-cover img{transform:scale(1.06)}.thread-cover-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--text-faint);background:linear-gradient(155deg,var(--surface-2),var(--surface-3))}.thread-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.18rem}.thread-head{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem}.thread-name{font-family:var(--font-display);font-size:.9875rem;font-variation-settings:"opsz" 36,"SOFT" 40,"wght" 500;color:var(--text);line-height:1.25;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .18s var(--ease);flex:1;min-width:0}.thread-item:hover .thread-name{color:var(--accent)}.thread-timestamp{font-size:.6875rem;color:var(--text-faint);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.thread-sub{margin:0;font-size:.8rem;color:var(--text-mute);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.thread-sub em{font-family:var(--font-display);font-variation-settings:"opsz" 32,"SOFT" 60;font-style:italic}.thread-sub-author{font-style:normal;color:var(--text-faint)}.thread-status{display:flex;flex-direction:column;gap:.22rem;margin-top:.12rem}.thread-bar{height:2px;background:var(--surface-3);border-radius:var(--radius-full);overflow:hidden}.thread-bar-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .6s var(--ease-out)}.thread-preview-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.thread-preview{font-size:.75rem;color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-preview--idle{color:var(--text-faint);font-style:italic}.thread-chips{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.thread-chip{display:inline-flex;align-items:center;gap:3px;font-size:.625rem;color:var(--text-faint);white-space:nowrap}.thread-actions{display:flex;flex-direction:column;gap:.3rem;flex-shrink:0;opacity:0;transition:opacity .16s var(--ease)}.thread-item:hover .thread-actions{opacity:1}.thread-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-mute);cursor:pointer;transition:var(--transition)}.thread-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash);transform:scale(1.08)}.thread-btn--chat:hover{border-color:var(--sage);color:var(--sage);background:#5f7a5f1a}.thread-btn--progress:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}@media (max-width: 768px){.dashboard-header{grid-template-columns:1fr;gap:var(--spacing-lg);padding:var(--spacing-lg) 0 var(--spacing-lg)}.dashboard-header-right{flex-direction:row;align-items:flex-end;justify-content:space-between}.dashboard-header-stats{justify-content:flex-start;gap:var(--spacing-lg)}.dashboard-stat{text-align:left}.dashboard-stat-value{font-size:2rem}.filter-tabs{width:100%;border-radius:var(--radius)}.thread-item{padding:.8rem .4rem}.thread-actions{opacity:1;flex-direction:row}}@media (max-width: 440px){.dashboard-header h1{font-size:2.25rem}.thread-cover{width:44px}.new-reading-btn span{display:none}.new-reading-btn{width:36px;height:36px;padding:0;justify-content:center;border-radius:50%}}.reading-card-wrapper{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform .26s var(--ease),border-color .26s var(--ease),box-shadow .26s var(--ease);isolation:isolate}.reading-card-wrapper:after{content:"";position:absolute;left:1.1rem;right:1.1rem;bottom:.75rem;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .36s var(--ease-out)}.reading-card-wrapper:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-3px)}.reading-card-wrapper:hover:after{transform:scaleX(1)}.reading-card{display:flex;flex-direction:column}.cover-container{position:relative;overflow:hidden;background:var(--surface-2)}.reading-cover{width:100%;aspect-ratio:2 / 3;object-fit:cover;display:block;transition:transform .6s var(--ease-out)}.reading-card-wrapper:hover .reading-cover{transform:scale(1.04)}.reading-cover-placeholder{width:100%;aspect-ratio:2 / 3;background:linear-gradient(165deg,var(--surface-2) 0%,var(--surface-3) 100%);display:grid;place-items:center;position:relative;overflow:hidden}.reading-cover-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(180deg,transparent,var(--accent-wash) 100%),repeating-linear-gradient(45deg,transparent 0 24px,rgba(180,66,26,.04) 24px 48px)}.book-icon{position:relative;font-size:2.75rem;opacity:.6;filter:grayscale(.3)}.card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:flex-end;gap:.5rem;padding:.6rem;background:linear-gradient(180deg,transparent 45%,rgba(26,20,16,.72) 100%);opacity:0;transition:opacity .26s var(--ease);pointer-events:none}.reading-card-wrapper:hover .card-overlay{opacity:1;pointer-events:auto}.overlay-button{width:38px;height:38px;border-radius:50%;border:1.5px solid rgba(255,255,255,.55);background:#ffffff2e;backdrop-filter:blur(10px) saturate(1.4);-webkit-backdrop-filter:blur(10px) saturate(1.4);color:#fff;font-size:1rem;cursor:pointer;display:grid;place-items:center;transition:var(--transition);text-shadow:0 1px 3px rgba(0,0,0,.4)}.overlay-button:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.05)}.reading-info{padding:.85rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.3rem}.reading-title{font-family:var(--font-display);font-size:1.0625rem;font-weight:500;font-variation-settings:"opsz" 48,"SOFT" 40;color:var(--text);line-height:1.25;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .22s var(--ease)}.reading-card-wrapper:hover .reading-title{color:var(--accent)}.reading-subtitle{font-family:var(--font-display);font-style:italic;font-size:.8125rem;color:var(--text-mute);line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.reading-author{font-size:.8125rem;color:var(--text-soft);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;font-weight:500}.reading-author:before{content:"por ";color:var(--text-faint);font-style:italic}.meta-compact{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--border)}.meta-badge{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:.6875rem;color:var(--text-soft);font-weight:500;line-height:1.2;white-space:nowrap}.meta-badge--activity{color:var(--accent);background:var(--accent-wash)}.meta-icon-small{font-size:.75rem;opacity:.7}.progress-inline{display:flex;align-items:center;gap:.5rem;margin-top:.6rem}.progress-bar-small{flex:1;height:3px;background:var(--surface-3);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill-small{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .42s var(--ease)}.progress-percent{font-family:var(--font-display);font-style:italic;font-size:.75rem;font-weight:500;color:var(--accent);min-width:32px;text-align:right}.reading-row{display:flex;gap:1rem;padding:.85rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .22s var(--ease),box-shadow .22s var(--ease),background .22s var(--ease);align-items:flex-start}.reading-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow);background:var(--surface-2)}.reading-row-cover{width:52px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:2 / 3;background:var(--surface-2);display:grid;place-items:center}.reading-row-cover img{width:100%;height:100%;object-fit:cover;display:block}.reading-row-cover-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--text-faint);background:linear-gradient(165deg,var(--surface-2),var(--surface-3))}.reading-row-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.45rem}.reading-row-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.reading-row-title{font-family:var(--font-display);font-size:1rem;font-variation-settings:"opsz" 36,"SOFT" 40,"wght" 500;color:var(--text);line-height:1.25;letter-spacing:-.01em;transition:color .2s var(--ease)}.reading-row:hover .reading-row-title{color:var(--accent)}.reading-row-subtitle{font-family:var(--font-display);font-style:italic;font-size:.75rem;color:var(--text-mute);margin-top:1px}.reading-row-author{font-size:.75rem;color:var(--text-soft);margin-top:1px}.reading-row-actions{display:flex;gap:.3rem;flex-shrink:0;opacity:0;transition:opacity .18s var(--ease)}.reading-row:hover .reading-row-actions{opacity:1}@media (max-width: 768px){.reading-row-actions{opacity:1}}.reading-row-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-mute);cursor:pointer;transition:var(--transition)}.reading-row-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}.reading-row-progress{display:flex;align-items:center;gap:.5rem}.reading-row-progress-bar{flex:1;height:3px;background:var(--surface-3);border-radius:var(--radius-full);overflow:hidden}.reading-row-progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .42s var(--ease)}.reading-row-progress-pct{font-family:var(--font-display);font-style:italic;font-size:.6875rem;color:var(--accent);min-width:28px;text-align:right}.reading-row-meta{display:flex;flex-wrap:wrap;gap:.6rem}.reading-row-meta-item{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--text-faint)}@media (max-width: 768px){.reading-info{padding:.7rem .85rem .95rem}.reading-title{font-size:.9375rem}.reading-subtitle,.reading-author{font-size:.75rem}.meta-badge{font-size:.625rem}.card-overlay{opacity:1;background:linear-gradient(180deg,transparent 60%,rgba(26,20,16,.55) 100%);pointer-events:auto}.overlay-button{width:34px;height:34px;font-size:.875rem}}@media (max-width: 480px){.reading-info{padding:.5rem .6rem .7rem;gap:.2rem}.reading-title{font-size:.8125rem;-webkit-line-clamp:3}.reading-subtitle,.reading-author{font-size:.6875rem}.meta-compact{margin-top:.3rem;padding-top:.3rem;gap:.2rem}.meta-badge{font-size:.5625rem;padding:2px 5px}.overlay-button{width:28px;height:28px}}.login-cta-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a14108c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:900;padding:1rem;animation:backdropIn .18s var(--ease)}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.login-cta-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 2rem 1.75rem;max-width:360px;width:100%;position:relative;text-align:center;box-shadow:var(--shadow-lg);animation:modalIn .22s var(--ease-out)}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}.login-cta-close{position:absolute;top:.875rem;right:.875rem;width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-mute);cursor:pointer;display:grid;place-items:center;transition:var(--transition)}.login-cta-close:hover{border-color:var(--border-strong);color:var(--text)}.login-cta-mark{font-size:2.25rem;margin-bottom:.75rem;line-height:1}.login-cta-title{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--text);margin:0 0 .5rem;letter-spacing:-.02em}.login-cta-message{font-size:.9rem;color:var(--text-soft);margin:0 0 1.5rem;line-height:1.5}.login-cta-actions{display:flex;gap:.6rem}.login-cta-btn{flex:1;padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);border:1px solid transparent}.login-cta-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.login-cta-btn--primary:hover{filter:brightness(1.08)}.login-cta-btn--secondary{background:var(--surface-2);color:var(--text-soft);border-color:var(--border)}.login-cta-btn--secondary:hover{border-color:var(--border-strong);color:var(--text)}.discover-page{width:100%;animation:cokitab-fade-up .48s var(--ease-out) both}.discover-hero{position:relative;display:flex;flex-direction:column;gap:var(--spacing-md);padding:clamp(1.5rem,4vw,3rem) 0 clamp(1.5rem,3vw,2.25rem);margin-bottom:var(--spacing-xl);border-bottom:1px solid var(--border);max-width:820px}.discover-hero:before{content:"";position:absolute;left:0;top:0;width:48px;height:3px;background:var(--accent)}.discover-hero h1{font-family:var(--font-display);font-size:clamp(2.25rem,5vw + .5rem,4rem);font-variation-settings:"opsz" 144,"SOFT" 50,"wght" 400;line-height:1.02;letter-spacing:-.028em;color:var(--text)}.discover-hero-accent{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100,"wght" 400}.discover-subtitle{font-family:var(--font-display);font-style:italic;font-variation-settings:"opsz" 48,"SOFT" 60;font-size:1.0625rem;color:var(--text-mute);line-height:1.55;max-width:58ch}.discover-guest-cta{display:flex;align-items:center;gap:var(--spacing-md);padding:.75rem 1.25rem;background:var(--accent-wash);border:1px solid rgba(180,66,26,.18);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl)}[data-theme=dark] .discover-guest-cta{border-color:#e97b4a33}.discover-guest-mark{font-family:var(--font-display);font-size:1.125rem;color:var(--accent);font-style:italic;flex-shrink:0;line-height:1}.discover-guest-cta-actions{display:flex;gap:.5rem;margin-left:auto}.discover-guest-btn{display:inline-flex;align-items:center;padding:.45rem 1rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;text-decoration:none;border:1.5px solid var(--border-strong);color:var(--text-soft);background:var(--surface);transition:var(--transition)}.discover-guest-btn:hover{border-color:var(--accent);color:var(--accent)}.discover-guest-btn--primary{background:var(--accent);border-color:var(--accent);color:var(--paper)}.discover-guest-btn--primary:hover{background:var(--accent-hot);border-color:var(--accent-hot);color:var(--paper)}.filters-section{margin-bottom:var(--spacing-xl)}.filters-row{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.filter-buttons{display:flex;gap:.4rem;padding:.3rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:100%}.filter-buttons::-webkit-scrollbar{display:none}.filter-btn{padding:.5rem 1rem;border:none;background:transparent;color:var(--text-soft);font-family:var(--font-body);font-size:.8125rem;font-weight:500;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);white-space:nowrap}.filter-btn:hover{color:var(--text)}.filter-btn.active{background:var(--ink);color:var(--paper)}[data-theme=dark] .filter-btn.active{background:var(--accent);color:var(--on-inverse)}.sort-controls{display:flex;align-items:center;gap:.5rem}.sort-label{font-size:.6875rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute)}.sort-select{padding:.45rem .85rem;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--surface);color:var(--text);font-family:var(--font-body);font-size:.8125rem;cursor:pointer;transition:var(--transition)}.sort-select:hover{border-color:var(--text-mute)}.sort-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}.sort-order-btn{width:34px;height:34px;border:1px solid var(--border);border-radius:50%;background:var(--surface);color:var(--text);cursor:pointer;transition:var(--transition);display:grid;place-items:center;font-size:.9375rem}.sort-order-btn:hover{border-color:var(--accent);color:var(--accent)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md);padding:clamp(2rem,5vw,4rem) var(--spacing-xl);background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);max-width:680px;margin:0 auto}.empty-state-mark{font-family:var(--font-display);font-size:2.5rem;color:var(--accent);font-style:italic;line-height:1}.empty-state h2{font-style:italic;color:var(--text);margin:0;font-size:clamp(1.5rem,3vw,2rem);font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400}.empty-state p{color:var(--text-mute);max-width:52ch;margin:0}.empty-state-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.readings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(160px,42vw),1fr));gap:clamp(.75rem,2vw,1.5rem);animation:cokitab-fade .42s var(--ease-out) both}.load-more-section{display:flex;justify-content:center;padding:var(--spacing-2xl) 0 var(--spacing-md)}@media (max-width: 768px){.filters-row{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.sort-controls{justify-content:flex-end;flex-wrap:wrap}.readings-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}}@media (max-width: 480px){.readings-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.discover-hero h1{font-size:2.25rem}}.reading-details-page{width:100%;max-width:var(--container);margin:0 auto;animation:cokitab-fade-up .52s var(--ease-out) both}.back-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:1.1rem;cursor:pointer;transition:var(--transition);margin-bottom:var(--spacing-lg)}.back-button:hover{border-color:var(--accent);color:var(--accent);transform:translate(-2px)}.reading-layout-new{display:grid;grid-template-columns:300px 1fr 320px;gap:clamp(1.5rem,3vw,3rem);align-items:start}.reading-promo-card{position:sticky;top:calc(var(--header-h) + var(--spacing-lg));display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--surface-inverse);color:var(--on-inverse);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;isolation:isolate}.reading-promo-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(380px 240px at 80% -10%,rgba(233,123,74,.24),transparent 70%),radial-gradient(400px 260px at -10% 110%,rgba(214,178,107,.18),transparent 70%);pointer-events:none;z-index:0}.reading-promo-card>*{position:relative;z-index:1}.promo-image-container,.promo-image-placeholder{width:100%;aspect-ratio:2 / 3;border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 40px -12px #0000008c,0 6px 14px -6px #00000059}.promo-image{width:100%;height:100%;object-fit:cover}.promo-image-placeholder{display:grid;place-items:center;background:linear-gradient(165deg,#2b2218,#1a140f)}.book-icon-large{opacity:.45;color:var(--on-inverse)}.promo-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.promo-title{font-family:var(--font-display);font-size:1.5rem;font-variation-settings:"opsz" 72,"SOFT" 60,"wght" 500;color:var(--on-inverse);line-height:1.2;letter-spacing:-.015em;margin:0}.promo-subtitle{font-family:var(--font-display);font-style:italic;font-size:.9375rem;color:#f3ece0b8;margin:0}.promo-author{font-size:.875rem;color:#f3ece094;margin:0}.promo-author:before{content:"por ";font-style:italic;opacity:.7}.promo-info-box{display:flex;flex-direction:column;gap:.5rem;padding:.85rem 1rem;background:#f3ece00f;border:1px solid rgba(243,236,224,.12);border-radius:var(--radius)}.promo-info-item{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem;gap:var(--spacing-sm)}.promo-info-label{color:#f3ece099;text-transform:uppercase;letter-spacing:.12em;font-size:.6875rem;font-weight:600}.promo-info-value{color:var(--on-inverse);font-weight:500}.promo-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:.25rem}.promo-chat-button{width:100%;background:var(--paper);color:var(--ink);border-color:var(--paper)}.promo-chat-button:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:var(--paper)}.promo-edit-button{width:100%;background:transparent;border:1px solid rgba(243,236,224,.3);color:var(--on-inverse)}.promo-edit-button:hover:not(:disabled){background:#f3ece01a;border-color:#f3ece08c;color:var(--on-inverse)}.reading-main-content{display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2.5rem);min-width:0}.main-title-section{padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border)}.main-title-section:before{content:"";display:block;width:48px;height:3px;background:var(--accent);margin-bottom:var(--spacing-md)}.main-title{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.25rem);font-variation-settings:"opsz" 144,"SOFT" 60,"wght" 400;line-height:1.05;letter-spacing:-.025em;color:var(--text);margin:0 0 var(--spacing-sm) 0}.main-subtitle{font-family:var(--font-display);font-style:italic;font-size:1.25rem;font-variation-settings:"opsz" 72,"SOFT" 70;color:var(--text-mute);margin:0 0 var(--spacing-lg) 0}.main-meta{display:flex;flex-wrap:wrap;gap:.5rem}.meta-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.8125rem;color:var(--text-soft);font-weight:500}.meta-icon{opacity:.7}.content-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.section-title{font-family:var(--font-display);font-size:1.5rem;font-variation-settings:"opsz" 72,"SOFT" 50,"wght" 500;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-md)}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.section-text{font-size:1.0625rem;line-height:1.75;color:var(--text-soft);max-width:68ch;margin:0;font-feature-settings:"liga","kern"}.section-text:first-letter{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 40;font-size:3rem;font-weight:500;float:left;line-height:.9;padding:.35rem .5rem 0 0;color:var(--accent)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md) var(--spacing-xl)}.info-item{display:flex;flex-direction:column;gap:.25rem;padding:var(--spacing-md) 0;border-top:1px solid var(--border)}.info-label{font-size:.6875rem;color:var(--text-mute);font-weight:600;text-transform:uppercase;letter-spacing:.14em}.info-value{font-family:var(--font-display);font-size:1.125rem;font-variation-settings:"opsz" 36,"SOFT" 40,"wght" 500;color:var(--text)}.status-badge-large{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.7rem 1.1rem;background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--text-mute);border-radius:var(--radius);font-size:.9375rem;font-weight:500;color:var(--text);width:fit-content}.status-badge-large.active{border-left-color:var(--accent);background:var(--accent-wash);color:var(--text)}.status-icon{flex-shrink:0;opacity:.85}.reading-sidebar{display:flex;flex-direction:column;gap:var(--spacing-lg);position:sticky;top:calc(var(--header-h) + var(--spacing-lg));align-self:start}.sidebar-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.sidebar-section-title{font-family:var(--font-display);font-size:1.0625rem;font-variation-settings:"opsz" 36,"SOFT" 40,"wght" 500;color:var(--text);margin:0;display:flex;align-items:center;gap:.45rem}.sidebar-section-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-count{display:inline-grid;place-items:center;min-width:26px;height:22px;padding:0 .45rem;background:var(--accent);color:var(--paper);border-radius:var(--radius-full);font-family:var(--font-body);font-size:.6875rem;font-weight:700;letter-spacing:.02em}.collapse-toggle{background:none;border:none;color:var(--text-mute);font-size:.75rem;cursor:pointer;padding:.15rem;display:grid;place-items:center;width:22px;height:22px;transition:var(--transition)}.collapse-toggle:hover{color:var(--accent)}.sidebar-section.collapsed{gap:0}.participants-list-new{display:flex;flex-direction:column;gap:.25rem}.participant-item-new{display:flex;align-items:center;gap:.65rem;padding:.5rem;border-radius:var(--radius-sm);transition:var(--transition)}.participant-item-new:hover{background:var(--surface-2)}.participant-item-clickable{cursor:pointer}.participant-item-clickable:hover .participant-name-new{color:var(--accent)}.participant-avatar-new{width:34px;height:34px;min-width:34px;border-radius:50%;background:var(--surface-3);color:var(--text);display:grid;place-items:center;font-family:var(--font-display);font-weight:500;font-size:.8125rem;border:1px solid var(--border)}.participant-info-new{flex:1;min-width:0;display:flex;align-items:center;gap:.4rem}.participant-name-new{font-size:.875rem;font-weight:500;color:var(--text);text-transform:capitalize;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.participant-badge-new{padding:2px 7px;background:var(--accent);color:var(--paper);border-radius:var(--radius-full);font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.participants-empty{text-align:center;padding:var(--spacing-md);color:var(--text-mute);font-size:.875rem;font-style:italic}.milestones-list{display:flex;flex-direction:column;gap:.6rem}.milestone-item{display:flex;flex-direction:column;gap:.2rem;padding:.75rem .85rem;background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm)}.milestone-date{font-size:.6875rem;color:var(--text-mute);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.milestone-title{font-family:var(--font-display);font-size:.9375rem;font-weight:500;color:var(--text);line-height:1.3}.milestone-chapters{font-size:.75rem;color:var(--text-mute);font-style:italic}.view-all-button{width:100%;margin-top:.25rem}.quick-actions-list{display:flex;flex-direction:column;gap:.4rem}.quick-action-button{width:100%;justify-content:flex-start;padding-left:1rem}.error-state{text-align:center;padding:var(--spacing-2xl);background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-mute)}.error-state p{margin-bottom:var(--spacing-lg);font-family:var(--font-display);font-style:italic;font-size:1.25rem}@media (max-width: 1200px){.reading-layout-new{grid-template-columns:260px 1fr 280px}}@media (max-width: 1024px){.reading-layout-new{grid-template-columns:240px 1fr}.reading-sidebar{grid-column:1 / -1;position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-lg)}}@media (max-width: 768px){.reading-layout-new{grid-template-columns:1fr}.reading-promo-card{flex-direction:row;align-items:flex-start;gap:1rem;padding:1rem;position:static;max-width:none;margin:0}.promo-image-container,.promo-image-placeholder{width:88px;flex-shrink:0}.promo-content{flex:1;min-width:0;gap:.45rem}.promo-title{font-size:1rem;line-height:1.25}.promo-subtitle,.promo-author{font-size:.8125rem}.promo-info-box{display:none}.promo-actions{flex-direction:row;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.promo-chat-button,.promo-edit-button{width:auto;flex:1;min-width:72px}.main-title{font-size:2rem}.section-text:first-letter{font-size:2.25rem}.reading-sidebar{grid-template-columns:1fr}}:root{--ink: #1a1410;--ink-soft: #3b322a;--ink-mute: #6e6256;--ink-faint: #9a8f80;--paper: #faf6ef;--paper-2: #f3ece0;--paper-3: #ebe2d1;--paper-4: #ded3be;--rule: rgba(26, 20, 16, .12);--rule-strong: rgba(26, 20, 16, .22);--accent: #b4421a;--accent-hot: #d65a2c;--accent-soft: #efd4c4;--accent-wash: rgba(180, 66, 26, .08);--gold: #a8842b;--sage: #5f7a5f;--clay: #a64b2a;--rust: #a33a2a;--bg: var(--paper);--surface: var(--paper);--surface-2: var(--paper-2);--surface-3: var(--paper-3);--surface-inverse: #14110d;--on-inverse: #f3ece0;--text: var(--ink);--text-soft: var(--ink-soft);--text-mute: var(--ink-mute);--text-faint: var(--ink-faint);--border: var(--rule);--border-strong: var(--rule-strong);--primary: var(--accent);--primary-dark: #8e3114;--primary-light: var(--accent-hot);--secondary: var(--gold);--bg-primary: var(--surface);--bg-secondary: var(--surface-2);--bg-tertiary: var(--surface-3);--text-primary: var(--text);--text-secondary: var(--text-soft);--text-tertiary: var(--text-mute);--border-light: rgba(26, 20, 16, .07);--success: var(--sage);--error: var(--rust);--warning: var(--clay);--info: #3c5a7a;--shadow-sm: 0 1px 2px rgba(26, 20, 16, .06);--shadow: 0 2px 6px rgba(26, 20, 16, .08), 0 1px 2px rgba(26, 20, 16, .05);--shadow-md: 0 8px 18px -6px rgba(26, 20, 16, .12), 0 3px 8px -4px rgba(26, 20, 16, .08);--shadow-lg: 0 18px 38px -12px rgba(26, 20, 16, .18), 0 6px 14px -8px rgba(26, 20, 16, .1);--shadow-xl: 0 28px 60px -20px rgba(26, 20, 16, .28), 0 10px 20px -10px rgba(26, 20, 16, .14);--spacing-2xs: .125rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4.5rem;--radius-sm: 4px;--radius: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 22px;--radius-full: 999px;--ease: cubic-bezier(.22, .61, .36, 1);--ease-in: cubic-bezier(.55, 0, .68, .53);--ease-out: cubic-bezier(.16, 1, .3, 1);--transition: all .2s var(--ease);--transition-slow: all .42s var(--ease-out);--font-display: "Fraunces", "Iowan Old Style", "Georgia", serif;--font-body: "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--container: 1280px;--container-narrow: 880px;--header-h: 72px;--mobile-nav-h: 64px;color-scheme:light}[data-theme=dark]{--ink: #f3ece0;--ink-soft: #d9cdb9;--ink-mute: #a2957f;--ink-faint: #6f6451;--paper: #14110d;--paper-2: #1d1812;--paper-3: #271f16;--paper-4: #362a1c;--rule: rgba(243, 236, 224, .09);--rule-strong: rgba(243, 236, 224, .18);--accent: #e97b4a;--accent-hot: #f59368;--accent-soft: #3a241a;--accent-wash: rgba(233, 123, 74, .12);--gold: #d6b26b;--sage: #8daa85;--clay: #d6814e;--rust: #d6624a;--bg: var(--paper);--surface: var(--paper-2);--surface-2: var(--paper-3);--surface-3: var(--paper-4);--surface-inverse: #f3ece0;--on-inverse: #14110d;--text: var(--ink);--text-soft: var(--ink-soft);--text-mute: var(--ink-mute);--text-faint: var(--ink-faint);--border: var(--rule);--border-strong: var(--rule-strong);--primary: var(--accent);--primary-dark: #c2653a;--primary-light: var(--accent-hot);--bg-primary: var(--surface);--bg-secondary: var(--surface-2);--bg-tertiary: var(--surface-3);--text-primary: var(--text);--text-secondary: var(--text-soft);--text-tertiary: var(--text-mute);--border-light: rgba(243, 236, 224, .06);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 2px 6px rgba(0, 0, 0, .45), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 8px 18px -6px rgba(0, 0, 0, .55), 0 3px 8px -4px rgba(0, 0, 0, .35);--shadow-lg: 0 18px 38px -12px rgba(0, 0, 0, .7), 0 6px 14px -8px rgba(0, 0, 0, .45);--shadow-xl: 0 28px 60px -20px rgba(0, 0, 0, .85), 0 10px 20px -10px rgba(0, 0, 0, .55);color-scheme:dark}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body,#root{min-height:100vh;min-height:100dvh}html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;overflow-x:clip;overscroll-behavior:none}body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","cv11";overflow-x:clip;background-image:radial-gradient(1200px 600px at 85% -10%,var(--accent-wash),transparent 60%),radial-gradient(900px 500px at -5% 110%,rgba(168,132,43,.06),transparent 60%);background-attachment:fixed;transition:background-color .32s var(--ease),color .32s var(--ease)}[data-theme=dark] body{background-image:radial-gradient(1200px 600px at 85% -10%,var(--accent-wash),transparent 60%),radial-gradient(900px 500px at -5% 110%,rgba(214,178,107,.05),transparent 60%)}img,svg{display:block;max-width:100%}button{font-family:inherit;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none}input,textarea,select{font-family:inherit;color:inherit}a{color:var(--accent);text-decoration:none;transition:var(--transition);touch-action:manipulation}a:hover{color:var(--accent-hot)}::selection{background:var(--accent);color:var(--paper)}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:500;color:var(--text);letter-spacing:-.015em;line-height:1.15;font-variation-settings:"opsz" 48,"SOFT" 50}h1{font-size:clamp(2rem,4vw + 1rem,3.25rem);font-variation-settings:"opsz" 144,"SOFT" 60;letter-spacing:-.025em}h2{font-size:clamp(1.5rem,2vw + 1rem,2.125rem);font-variation-settings:"opsz" 72,"SOFT" 50}h3{font-size:1.375rem;font-variation-settings:"opsz" 36,"SOFT" 40}p{color:var(--text-soft)}small{font-size:.8125rem;color:var(--text-mute)}.display{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400;font-style:italic}.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.6875rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute)}.eyebrow:before{content:"";width:24px;height:1px;background:currentColor;opacity:.5}.ornament{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--gold);font-family:var(--font-display);font-size:.875rem;font-style:italic}.ornament:before,.ornament:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-strong),transparent)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border:2px solid var(--bg);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}button:focus-visible,a:focus-visible{outline-offset:3px}@keyframes cokitab-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes cokitab-fade{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes cokitab-slide-right{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.login-page,.register-page{position:relative;display:grid;place-items:center;min-height:calc(100vh - var(--header-h));padding:var(--spacing-2xl) var(--spacing-lg);background:radial-gradient(600px 400px at 20% 20%,var(--accent-wash),transparent 70%),radial-gradient(500px 400px at 80% 80%,rgba(168,132,43,.08),transparent 70%)}.login-page:before,.register-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:80px 80px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 45%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 70% 60% at 50% 45%,black 0%,transparent 100%);opacity:.4}[data-theme=dark] .login-page:before,[data-theme=dark] .register-page:before{opacity:.22}.login-container,.register-container{position:relative;background:var(--surface);padding:clamp(1.75rem,5vw,3rem);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:460px;animation:cokitab-fade-up .6s var(--ease-out) both}.login-container:before,.register-container:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:64px;height:3px;background:var(--accent);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.login-container h1,.register-container h1{margin-bottom:var(--spacing-xl);text-align:center;font-family:var(--font-display);font-size:clamp(2rem,4vw,2.75rem);font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400;font-style:italic;color:var(--text);background:none;-webkit-text-fill-color:currentColor}.login-container form,.register-container form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:0}.form-group label{font-family:var(--font-body);font-size:.6875rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.875rem 1rem;border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1rem;font-family:var(--font-body);transition:var(--transition)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-faint)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-wash)}.login-container button[type=submit],.register-container button[type=submit]{width:100%;padding:.95rem 1rem;margin-top:var(--spacing-sm);border:1px solid var(--ink);border-radius:var(--radius);font-family:var(--font-body);font-size:.9375rem;font-weight:600;letter-spacing:.02em;color:var(--paper);background:var(--ink);cursor:pointer;transition:var(--transition)}[data-theme=dark] .login-container button[type=submit],[data-theme=dark] .register-container button[type=submit]{background:var(--accent);border-color:var(--accent);color:var(--on-inverse)}.login-container button[type=submit]:hover:not(:disabled),.register-container button[type=submit]:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:var(--paper);transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-container button[type=submit]:disabled,.register-container button[type=submit]:disabled{opacity:.55;cursor:not-allowed}.login-container button.secondary,.register-container button.secondary{width:100%;padding:.85rem 1rem;margin-top:.5rem;border:1px solid var(--border-strong);border-radius:var(--radius);background:transparent;color:var(--text-soft);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:var(--transition)}.login-container button.secondary:hover:not(:disabled),.register-container button.secondary:hover:not(:disabled){color:var(--accent);border-color:var(--accent);background:var(--accent-wash)}.login-container button.secondary:disabled,.register-container button.secondary:disabled{opacity:.55;cursor:not-allowed}.login-container .help-text,.register-container .help-text{margin:0 0 var(--spacing-lg);font-family:var(--font-display);font-style:italic;font-variation-settings:"opsz" 48,"SOFT" 60;font-size:.9375rem;line-height:1.55;color:var(--text-mute)}.login-container .help-text strong,.register-container .help-text strong{color:var(--text);font-style:normal;font-family:var(--font-body);font-weight:600;letter-spacing:-.005em;word-break:break-all}.field-error{display:block;color:var(--rust);font-size:.8125rem;margin-top:var(--spacing-2xs);font-weight:500}.error-message{background:var(--accent-wash);color:var(--rust);padding:var(--spacing-md);border-radius:var(--radius);border-left:3px solid var(--rust);font-size:.875rem;font-weight:500}.success-message{background:#5f7a5f1a;color:var(--sage);padding:var(--spacing-md);border-radius:var(--radius);border-left:3px solid var(--sage);font-size:.875rem;font-weight:500}.register-link,.login-link{text-align:center;margin-top:var(--spacing-xl);color:var(--text-mute);font-size:.9375rem}.register-link a,.login-link a{color:var(--accent);font-weight:600;border-bottom:1px solid transparent}.register-link a:hover,.login-link a:hover{border-bottom-color:currentColor}.profile-page{max-width:880px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-lg);animation:cokitab-fade-up .52s var(--ease-out) both}.profile-container{background:var(--surface);padding:clamp(1.5rem,4vw,3rem);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.profile-container h1{margin-bottom:var(--spacing-2xl);font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 80,"wght" 400;font-style:italic;font-size:clamp(2rem,4vw,2.75rem);color:var(--text)}.profile-section{margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border)}.profile-section:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}.profile-section h2{margin-bottom:var(--spacing-lg);font-family:var(--font-display);font-size:1.5rem;font-weight:500;color:var(--text)}.profile-section form{display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-section button[type=submit]{align-self:flex-start;padding:.75rem 1.5rem;border:1px solid var(--ink);border-radius:var(--radius);background:var(--ink);color:var(--paper);font-family:var(--font-body);font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition)}[data-theme=dark] .profile-section button[type=submit]{background:var(--accent);border-color:var(--accent);color:var(--on-inverse)}.profile-section button[type=submit]:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:var(--paper);transform:translateY(-1px)}.profile-section button[type=submit]:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 768px){body{font-size:15px;background-attachment:scroll}input:not([type=radio]):not([type=checkbox]):not([type=range]):not([type=file]),textarea,select{font-size:1rem!important}.login-page,.register-page{padding:var(--spacing-xl) var(--spacing-md)}.profile-page{padding:var(--spacing-lg) var(--spacing-md) calc(var(--mobile-nav-h) + var(--spacing-lg))}}
