@import"https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-sans);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{color-scheme:light;--color-canvas: #f4efe6;--color-canvas-accent: #e6dccb;--color-surface: #ffffff;--color-surface-muted: #f7f2ea;--color-surface-hover: #f1e7da;--color-ink: #1b1d1f;--color-muted: #5f6772;--color-accent: #d8783a;--color-accent-deep: #a5521f;--color-slate: #233544;--color-line: rgba(27, 29, 31, .1);--color-solid: #233544;--color-solid-ink: #fef6ef;--color-surface-glass: rgba(255, 255, 255, .86);--color-surface-ghost: rgba(255, 255, 255, .7);--color-surface-ghost-strong: rgba(255, 255, 255, .6);--color-border-soft: rgba(35, 53, 68, .08);--color-border-faint: rgba(35, 53, 68, .12);--color-border: rgba(35, 53, 68, .16);--color-border-strong: rgba(35, 53, 68, .2);--color-fill-soft: rgba(35, 53, 68, .06);--color-fill: rgba(35, 53, 68, .12);--color-fill-strong: rgba(35, 53, 68, .18);--color-glow-accent: rgba(216, 120, 58, .18);--color-glow-depth: rgba(35, 53, 68, .12);--gradient-timer-card: linear-gradient(140deg, #fff6ef, #f6efe5);--shadow-elevated: 0 18px 40px rgba(35, 53, 68, .12);--shadow-toast: 0 14px 30px rgba(35, 53, 68, .2);--shadow-modal: 0 20px 50px rgba(15, 18, 21, .3);--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--space-3xl: 3rem;--stack-gap: 24px;--font-sans: "Manrope", "Space Grotesk", sans-serif;--font-display: "Space Grotesk", "Manrope", sans-serif;--text-xs: .75rem;--text-sm: .8125rem;--text-md: .875rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.375rem;--text-3xl: 2.125rem;--line-tight: 1.15;--line-normal: 1.5}:root[data-theme=dark]{color-scheme:dark;--color-canvas: #0c1014;--color-canvas-accent: #141a20;--color-surface: #1a1f26;--color-surface-muted: #151a21;--color-surface-hover: #202732;--color-ink: #f3efe7;--color-muted: #a4afbb;--color-accent: #e79a58;--color-accent-deep: #c77438;--color-slate: #d6dee8;--color-line: rgba(243, 239, 231, .08);--color-solid: #0f141a;--color-solid-ink: #f7f1e8;--color-surface-glass: rgba(16, 20, 25, .92);--color-surface-ghost: rgba(26, 32, 39, .75);--color-surface-ghost-strong: rgba(26, 32, 39, .62);--color-border-soft: rgba(243, 239, 231, .08);--color-border-faint: rgba(243, 239, 231, .12);--color-border: rgba(243, 239, 231, .16);--color-border-strong: rgba(243, 239, 231, .24);--color-fill-soft: rgba(243, 239, 231, .08);--color-fill: rgba(243, 239, 231, .12);--color-fill-strong: rgba(243, 239, 231, .18);--color-glow-accent: rgba(216, 120, 58, .14);--color-glow-depth: rgba(8, 12, 18, .7);--gradient-timer-card: linear-gradient(140deg, #1a2129, #232a33);--shadow-elevated: 0 18px 40px rgba(0, 0, 0, .45);--shadow-toast: 0 14px 30px rgba(0, 0, 0, .5);--shadow-modal: 0 20px 50px rgba(0, 0, 0, .55)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark;--color-canvas: #0c1014;--color-canvas-accent: #141a20;--color-surface: #1a1f26;--color-surface-muted: #151a21;--color-surface-hover: #202732;--color-ink: #f3efe7;--color-muted: #a4afbb;--color-accent: #e79a58;--color-accent-deep: #c77438;--color-slate: #d6dee8;--color-line: rgba(243, 239, 231, .08);--color-solid: #0f141a;--color-solid-ink: #f7f1e8;--color-surface-glass: rgba(16, 20, 25, .92);--color-surface-ghost: rgba(26, 32, 39, .75);--color-surface-ghost-strong: rgba(26, 32, 39, .62);--color-border-soft: rgba(243, 239, 231, .08);--color-border-faint: rgba(243, 239, 231, .12);--color-border: rgba(243, 239, 231, .16);--color-border-strong: rgba(243, 239, 231, .24);--color-fill-soft: rgba(243, 239, 231, .08);--color-fill: rgba(243, 239, 231, .12);--color-fill-strong: rgba(243, 239, 231, .18);--color-glow-accent: rgba(216, 120, 58, .14);--color-glow-depth: rgba(8, 12, 18, .7);--gradient-timer-card: linear-gradient(140deg, #1a2129, #232a33);--shadow-elevated: 0 18px 40px rgba(0, 0, 0, .45);--shadow-toast: 0 14px 30px rgba(0, 0, 0, .5);--shadow-modal: 0 20px 50px rgba(0, 0, 0, .55)}}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);line-height:var(--line-normal);color:var(--color-ink);background:radial-gradient(circle at top left,var(--color-glow-accent),transparent 40%),radial-gradient(circle at 20% 20%,var(--color-glow-depth),transparent 45%),linear-gradient(140deg,var(--color-canvas),var(--color-canvas-accent))}html{scroll-behavior:smooth;overflow-x:hidden}body{overflow-x:hidden}a{color:inherit;text-decoration:none}.static{position:static}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.app-shell{--sidebar-width: 240px;--sidebar-width-collapsed: 72px;position:relative;padding-left:var(--sidebar-width);min-height:100vh;height:100vh;overflow:hidden;transition:padding-left .22s ease}.app-shell.sidebar-collapsed{padding-left:var(--sidebar-width-collapsed)}.app-shell.sidebar-expanded{padding-left:var(--sidebar-width)}.app-shell.sidebar-mobile{padding-left:0}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:20;height:100vh;padding:24px 16px;background:var(--color-surface-glass);border-right:1px solid var(--color-line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:flex;flex-direction:column;gap:20px;min-height:0;overflow:hidden;width:var(--sidebar-width-collapsed);transition:padding .22s ease,box-shadow .22s ease,transform .22s ease}.sidebar.collapsed{width:var(--sidebar-width-collapsed);padding:20px 10px}.sidebar:not(.collapsed),.sidebar.preview{width:var(--sidebar-width);padding:24px 16px;z-index:30;box-shadow:12px 0 32px #23354429}.sidebar.preview{animation:sidebarSlideIn .18s ease}@keyframes sidebarSlideIn{0%{transform:translate(calc(-1 * var(--sidebar-width-collapsed)))}to{transform:translate(0)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.sidebar:not(.collapsed) .sidebar-header,.sidebar.preview .sidebar-header{min-height:44px}.sidebar-brand{display:flex;align-items:center;gap:12px}.brand-button{border:none;background:transparent;padding:0;cursor:pointer;text-align:left}.sidebar.collapsed:not(.preview) .sidebar-header{flex-direction:column;gap:12px}.sidebar.collapsed:not(.preview) .sidebar-brand{justify-content:center}.brand{display:flex;gap:12px;align-items:center;min-width:0}.brand-text{min-width:0}.sidebar-brand-text{display:flex;flex-direction:column;line-height:1.2;max-width:140px}.sidebar.collapsed:not(.preview) .brand-text{display:none}.app-shell.sidebar-collapsed .sidebar:not(.preview).collapsed .sidebar-brand-text{display:none}.brand-mark{width:44px;height:44px;border-radius:14px;overflow:hidden;display:grid;place-items:center;flex-shrink:0}.brand-mark-logo{display:block;width:28px;height:28px;flex-shrink:0;-o-object-fit:cover;object-fit:cover}.sidebar-brand img{width:28px;height:28px;flex-shrink:0}.brand-title{font-family:var(--font-display);font-size:18px;font-weight:600}.brand-subtitle{color:var(--color-muted);font-size:13px}.sidebar-toggle{width:36px;height:36px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface-ghost);color:var(--color-slate);cursor:pointer;font-size:18px;flex-shrink:0}.sidebar-toggle:hover{background:var(--color-surface)}.sidebar.collapsed:not(.preview) .sidebar-toggle{width:44px;align-self:center}.nav{display:flex;flex-direction:column;gap:10px}.nav-wrap{flex:1;min-height:0;overflow:auto;padding-right:4px}.nav-section{display:grid;gap:8px}.nav-section-title{text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--color-muted);margin-top:8px}.nav-item{position:relative;display:grid;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:var(--color-slate);font-weight:600;background:transparent;transition:.2s ease;border:1px solid transparent}.nav-item-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.sidebar-icon{display:flex;align-items:center;justify-content:center;transition:transform .18s ease,color .18s ease}.nav-item:hover .sidebar-icon,.nav-item.active .sidebar-icon{transform:translateY(-1px)}.nav-item-label{white-space:nowrap}.sidebar.collapsed .nav-item-label{transition:opacity .18s ease,transform .18s ease}.sidebar.collapsed:not(.preview) .nav-section-title{display:none}.sidebar.collapsed:not(.preview) .nav-item-label{opacity:0;transform:translate(-6px);width:0;pointer-events:none;position:absolute}.sidebar.collapsed:not(.preview) .nav-item{grid-template-columns:1fr;justify-items:center;padding:12px 10px}.sidebar.preview .nav-item-label{opacity:1;transform:translate(0);position:static}.nav-item:hover{background:#d8783a1f;border-color:#d8783a33}.nav-item.active{background:var(--color-solid);color:var(--color-solid-ink);border-color:transparent}.content{height:100vh;overflow:auto;width:100%;padding:34px 38px calc(48px + env(safe-area-inset-bottom));min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:28px}.topbar h1{margin:6px 0 0;font-family:var(--font-display);font-size:var(--text-3xl)}.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--color-muted)}.topbar-actions{display:flex;gap:12px}.mobile-menu-trigger{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;margin-bottom:10px;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface-ghost);color:var(--color-slate);font-size:22px;cursor:pointer}.mobile-menu-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60}.mobile-menu-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#0c101452}.mobile-menu-sheet{position:absolute;top:0;right:0;bottom:0;left:0;animation:fadeUp .18s ease}.sidebar.mobile{position:fixed;top:0;right:0;bottom:0;left:0;width:auto;height:auto;padding:18px 16px;border-right:none;gap:18px;background:radial-gradient(circle at top,rgba(216,120,58,.14),transparent 42%),var(--color-surface)}.sidebar.mobile .sidebar-header{grid-template-columns:minmax(0,1fr)}.sidebar.mobile .nav-wrap{padding-right:0}.sidebar.mobile .nav{gap:8px}.sidebar.mobile .nav-item{padding:10px 12px;font-size:14px}.primary-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:999px;padding:10px 18px;font-weight:600;font-family:inherit;cursor:pointer}.primary-button,.ghost-button,.danger-button,.tab-button{min-height:40px}.primary-button:disabled,.ghost-button:disabled{opacity:.6;cursor:not-allowed}.danger-button:disabled{opacity:.6;cursor:not-allowed}.primary-button{background:var(--color-accent);color:#fff;box-shadow:0 12px 24px #d8783a4d}.ghost-button{background:var(--color-surface-ghost);color:var(--color-slate);border:1px solid var(--color-border-faint)}.page,.page-grid{display:grid;gap:24px}.settings-layout{grid-template-columns:1fr}.panel{background:var(--color-surface);border-radius:24px;padding:24px 28px;box-shadow:var(--shadow-elevated);border:1px solid var(--color-border-soft);min-width:0;overflow-wrap:anywhere;animation:floatIn .5s ease both}.panel-stack{display:grid;grid-auto-rows:min-content;gap:var(--stack-gap)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:18px}.panel h2{margin:0 0 6px;font-size:var(--text-2xl);font-family:var(--font-display)}.muted{margin:0;color:var(--color-muted)}.badge{background:#d8783a29;color:var(--color-accent-deep);padding:6px 12px;border-radius:999px;font-weight:600;font-size:12px}.badge.blue{background:#3f70ff29;color:var(--color-slate)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.card{padding:18px;border-radius:18px;background:var(--color-surface-muted);border:1px solid var(--color-border-soft);display:grid;gap:6px;animation:fadeUp .6s ease both;animation-delay:var(--delay, 0s)}.book-card{gap:14px}.book-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.status-pill{font-size:11px;padding:6px 10px}.status-pill.status-active{background:#2e7d5426;color:#1f5c3a}.status-pill.status-archived{background:#6d75842e;color:#3b4252}.book-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.book-stat{background:var(--color-surface);border-radius:14px;padding:10px 12px;border:1px solid var(--color-border-soft);display:grid;gap:6px}.book-stat-wide{grid-column:span 2}.book-progress-row{display:grid;gap:8px}.book-progress-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.book-progress-label,.book-progress-percent{font-size:13px;font-weight:700;color:var(--color-muted)}.book-progress-track,.book-progress-bar{height:6px;border-radius:4px}.book-stat-label{font-size:12px;color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em}.book-stat-value{font-size:18px;font-weight:600;color:var(--color-slate)}.book-parts-section{display:grid;gap:12px;padding-top:8px;border-top:1px solid var(--color-border)}.book-parts-header h3{margin:0;font-size:16px;color:var(--color-slate)}.book-parts-list{display:grid;gap:8px}.book-part-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--color-border-soft);border-radius:12px;background:var(--color-surface-soft)}.book-part-row-main{min-width:0;flex:1}.book-part-title{font-size:14px;font-weight:600;color:var(--color-slate)}.book-part-meta{margin-top:2px;font-size:12px;color:var(--color-muted)}.book-part-delete{width:34px;height:34px;color:var(--color-muted)}.book-part-delete:hover,.book-part-delete:focus-visible{color:var(--color-slate)}.book-part-confirm{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.book-part-confirm span{font-size:12px;font-weight:600;color:var(--color-muted)}.card-title{font-weight:600;overflow-wrap:anywhere}.card-meta{font-size:13px;color:var(--color-muted)}.card-detail{margin:6px 0 0;font-size:14px;color:var(--color-slate)}.list{display:grid;gap:12px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:16px;background:var(--color-surface-muted);border:1px solid var(--color-border-soft);overflow-wrap:anywhere}.list-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.algorithm-groups-page .list-actions>.ghost-button,.algorithm-group-detail-page .list-row>.ghost-button{white-space:nowrap;flex-shrink:0;padding:0 12px}.icon-button{width:38px;height:38px;border-radius:12px;border:1px solid var(--color-border-soft);background:var(--color-surface);color:var(--color-slate);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease}.icon-button:hover{background:var(--color-surface-hover)}.icon-button.danger{color:#dd4c39}.icon-button.danger:hover{background:#ff6b6b1a;border-color:#dd4c3938}.code-snippet{background:var(--color-surface-muted);border-radius:16px;border:1px solid var(--color-border-soft);padding:12px 14px;display:grid;gap:12px}.code-snippet-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.code-snippet pre{margin:0}.list-title{font-weight:600;overflow-wrap:anywhere}.list-meta{font-size:13px;color:var(--color-muted);margin-top:4px}.reading-session-page{position:relative;gap:18px}.reading-session-setup-row{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,.6fr);gap:12px;align-items:end}.reading-session-inline-field{display:grid;gap:8px}.reading-session-inline-label{font-size:12px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.reading-session-book-picker{display:grid;gap:8px;max-width:320px}.reading-session-panel{padding-left:0;padding-right:0}.reading-session-main{max-width:820px;margin:0 auto;padding:0}.reading-session-book-select{width:min(320px,100%)}.reading-session-session-header{display:grid;gap:8px}.session-meta-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.reading-session-header-chip{display:inline-flex;align-items:center;gap:8px;min-width:0;min-height:42px}.reading-session-header-chip-label{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--color-slate);white-space:nowrap}.reading-session-header-select{width:220px;min-width:220px;height:42px}.reading-session-part-inline{display:inline-flex;align-items:center;gap:8px;min-height:42px}.reading-session-part-delete-shell{display:inline-flex;align-items:center;min-height:42px}.reading-session-part-delete{width:34px;height:34px;border-radius:10px;color:var(--color-muted);border-color:var(--color-border-soft)}.reading-session-part-delete:hover,.reading-session-part-delete:focus-visible{color:var(--color-slate);border-color:var(--color-border-strong);background:var(--color-surface-hover)}.reading-session-inline-confirm{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:4px 8px;border-radius:12px;border:1px solid var(--color-border-soft);background:var(--color-surface-soft);flex-wrap:wrap}.reading-session-inline-confirm span{font-size:12px;font-weight:600;color:var(--color-muted);white-space:nowrap}.reading-session-inline-confirm .ghost-button,.reading-session-inline-confirm .danger-button{height:30px;padding:4px 10px;font-size:12px}.reading-session-part-inline input{width:220px;min-width:220px;height:42px}.session-tabs{display:flex;gap:8px;margin-top:16px;margin-bottom:12px}.session-tabs button{height:34px;padding:6px 12px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-slate);font-weight:600;cursor:pointer}.session-tabs button.active{background:var(--color-surface-hover);border-color:#d8783a3d}.reading-session-capture{display:grid;gap:16px;max-width:720px;margin-top:10px}.reading-session-section-heading{display:inline-flex;align-items:center;gap:8px;margin-top:14px;margin-bottom:2px;font-size:14px;font-weight:600;color:var(--color-slate)}.reading-session-capture-field{position:relative}.reading-session-capture-field textarea{min-height:116px;padding-top:18px;padding-right:156px;padding-bottom:34px;resize:vertical}.note-input-hint{position:absolute;right:12px;bottom:8px;font-size:12px;color:var(--color-muted);opacity:.8;pointer-events:none}.capture-type-select{position:absolute;top:8px;right:12px;width:auto;min-width:140px;min-height:30px;padding:4px 28px 4px 10px;border-color:transparent;background:transparent;color:var(--color-muted);font-size:12px;font-weight:600;box-shadow:none}.capture-type-select:focus{border-color:var(--color-border);background:#ffffffe0}.reading-session-notes{display:grid;gap:16px;max-width:720px}.reading-session-note-group{display:grid;gap:10px}.reading-session-note-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.reading-session-note-group-header h3{margin:0;font-size:16px}.reading-session-note-list-shell{position:relative}.reading-session-note-list-shell:after{content:"";position:absolute;left:0;right:4px;bottom:0;height:22px;pointer-events:none;background:linear-gradient(to bottom,#fffbf500,#fffbf5f5)}.reading-session-note-list{display:grid;gap:8px;max-height:240px;overflow-y:auto;padding-right:4px}.reading-session-note-item{display:flex;align-items:center;gap:10px;min-height:40px;padding:6px 10px;border:1px solid var(--color-border);border-radius:10px;background:transparent}.reading-session-note-item:hover{background:var(--color-surface)}.reading-session-note-item.editing{align-items:stretch;min-height:0;padding:8px 10px}.reading-session-note-edit-row{display:flex;align-items:flex-start;gap:8px;width:100%}.reading-session-note-item-main{min-width:0;flex:1}.reading-session-note-item-main textarea{min-height:56px;margin:0}.reading-session-note-preview{flex:1;min-width:0;font-size:14px;line-height:1.3;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;opacity:.92}.reading-session-note-actions{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0}.reading-session-note-type{width:110px;min-width:110px;min-height:32px;font-size:12px;line-height:1;padding-top:0;padding-bottom:0}.session-actions{display:flex;gap:10px;margin-top:8px;padding-bottom:12px;border-bottom:1px solid var(--color-border);align-items:center}.session-action-group{display:inline-flex;align-items:center;gap:8px}.session-actions .ghost-button,.session-actions .primary-button{white-space:nowrap;height:36px;padding:6px 14px;font-size:14px}.reading-session-restore-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.reading-session-restore-actions{display:inline-flex;align-items:center;gap:8px}.reading-session-restore-banner .ghost-button{white-space:nowrap}.reading-session-restore-close{width:34px;height:34px}.context-help-link{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:999px;border:1px solid rgba(216,120,58,.3);background:#d8783a1a;color:var(--color-accent-deep);font-size:12px;font-weight:700;line-height:1;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.context-tooltip{position:relative;display:inline-flex}.context-tooltip-bubble{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);width:220px;padding:10px 12px;border-radius:12px;border:1px solid var(--color-border-soft);background:var(--color-slate);color:var(--color-solid-ink);font-size:12px;font-weight:500;line-height:1.5;white-space:pre-line;box-shadow:var(--shadow-elevated);opacity:0;pointer-events:none;visibility:hidden;z-index:8}.context-tooltip:hover .context-tooltip-bubble,.context-tooltip:focus-within .context-tooltip-bubble{opacity:1;visibility:visible}.settings-section-card{gap:16px}.settings-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.settings-actions{justify-content:flex-start}.context-help-link:hover,.context-help-link:focus-visible{transform:translateY(-1px);border-color:#d8783a6b;background:#d8783a29;box-shadow:0 0 0 3px #d8783a2e;outline:none}.reading-session-code-block{margin-top:4px;max-width:720px}.reading-session-success-actions{justify-content:flex-start}.floating-timer{position:fixed;z-index:30;width:220px;height:280px;padding:16px 16px 18px;border-radius:24px;border:1px solid var(--color-border);background:radial-gradient(circle at top,rgba(216,120,58,.16),transparent 48%),var(--color-surface-glass);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-elevated);display:flex;flex-direction:column;gap:10px;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;cursor:grab}.floating-timer.collapsed{width:164px;height:auto;min-height:120px;gap:8px;padding:16px;border-radius:18px}.floating-timer.dragging{cursor:grabbing;box-shadow:0 24px 52px #23354438}.floating-timer-header{position:relative;display:flex;justify-content:center;align-items:center;min-height:28px;width:100%}.floating-timer-grip{width:100%;text-align:center;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-muted);padding:0 32px}.floating-timer.collapsed .floating-timer-grip{font-size:18px;letter-spacing:0;text-transform:none;color:var(--color-slate)}.floating-timer-menu-shell{position:absolute;top:2px;right:2px;display:inline-flex;flex-shrink:0;z-index:4}.timer-menu-trigger{position:absolute;top:0;right:0;width:32px;height:32px;background:transparent;border:none;color:var(--color-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:color .18s ease}.timer-menu-trigger:hover,.timer-menu-trigger:focus-visible{color:var(--color-slate);outline:none}.floating-timer-menu-popover{position:absolute;top:calc(100% + 12px);right:0;width:220px;padding:6px;border-radius:14px;border:1px solid var(--color-border-soft);background:var(--color-surface);box-shadow:var(--shadow-elevated);display:grid;gap:4px;z-index:12}.floating-timer-menu-popover button{width:100%;border:none;border-radius:10px;background:transparent;padding:10px 12px;text-align:left;font-size:13px;color:var(--color-slate);cursor:pointer}.floating-timer-menu-popover button:hover,.floating-timer-menu-popover button:focus-visible{background:var(--color-surface-hover);outline:none}.floating-timer-face{position:relative;width:100%;display:grid;place-items:center}.floating-timer-content{display:flex;flex-direction:column;align-items:center;flex:1;min-height:0;justify-content:center;padding-top:2px;padding-bottom:8px}.floating-timer-ring{display:flex;justify-content:center;align-items:center;overflow:visible}.floating-timer-ring-track,.floating-timer-ring-progress{fill:none}.floating-timer-ring-track{stroke:#2335441f}.floating-timer-ring-progress{stroke:var(--color-accent);stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;filter:drop-shadow(0 0 12px rgba(216,120,58,.35));transition:stroke-dashoffset .3s linear}.floating-timer-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;align-content:center;justify-items:center;gap:6px;padding:36px;text-align:center}.floating-timer-time{font-family:var(--font-display);font-size:34px;font-weight:700;line-height:.95}.floating-timer-mode{margin-top:6px;font-size:15px;font-weight:700;color:var(--color-slate)}.floating-timer-session{font-size:12px;color:var(--color-muted)}.floating-timer-cycle{margin-top:8px;margin-bottom:26px;text-align:center;font-size:14px;font-weight:700;color:var(--color-muted)}.floating-timer-collapsed-meta{display:flex;justify-content:center;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.floating-timer-controls{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:16px;margin-top:14px;width:100%}.floating-timer-confirm{display:flex;flex-direction:column;gap:10px;margin-top:auto;align-items:center}.floating-timer-confirm-text{font-size:12px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.floating-timer-confirm-actions{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.floating-timer-confirm-button{min-width:72px;height:36px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-ghost);color:var(--color-slate);font-size:12px;font-weight:700;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.floating-timer-confirm-button:hover{transform:translateY(-1px);background:var(--color-surface);border-color:var(--color-border-strong)}.floating-timer-confirm-button.danger{background:var(--color-danger-soft);color:var(--color-danger);border-color:color-mix(in srgb,var(--color-danger) 24%,transparent)}.floating-timer-confirm-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.floating-timer.collapsed .floating-timer-content,.floating-timer-collapsed .floating-timer-content{justify-content:center;align-items:center}.floating-timer.collapsed .floating-timer-ring,.floating-timer-collapsed .floating-timer-ring,.floating-timer.collapsed .floating-timer-cycle,.floating-timer-collapsed .floating-timer-cycle{display:none}.floating-timer-control{width:48px;height:48px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-ghost);color:var(--color-slate);font-size:20px;line-height:1;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.floating-timer-control:hover{transform:translateY(-1px);background:var(--color-surface);border-color:var(--color-border-strong)}.floating-timer-control.primary{background:var(--color-solid);color:var(--color-solid-ink);border-color:transparent}.floating-timer-control.play-button{width:64px;height:64px}.floating-timer-control.compact{font-size:18px}.floating-timer.collapsed .floating-timer-controls{gap:10px}.floating-timer.collapsed .floating-timer-control{width:42px;height:42px}.floating-timer.collapsed .floating-timer-control.play-button{width:54px;height:54px}.floating-timer-control:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.progress-track{height:8px;border-radius:999px;background:var(--color-fill);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-accent),#f0b783);border-radius:999px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.import-type-tabs{display:flex;flex-wrap:wrap;gap:12px}.import-target-row{display:flex;gap:12px}.import-field{flex:1;min-width:0;display:grid;gap:8px}.import-section-label{font-size:13px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.import-dropzone{position:relative;border:1px dashed var(--color-border-strong);border-radius:12px;padding:36px;text-align:center;opacity:.8;background:var(--color-surface-muted);cursor:pointer;transition:opacity .18s ease,border-color .18s ease,background .18s ease}.import-dropzone:hover,.import-dropzone.active{opacity:1;border-color:var(--color-accent);background:#d8783a0f}.import-dropzone-title{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--color-slate)}.import-dropzone-hint{margin:0;color:var(--color-muted)}.import-file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;pointer-events:none}.import-textarea{min-height:120px;resize:vertical;overflow:hidden}.import-meta-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.import-example-block{padding:0}.import-example{margin:0;padding:16px;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:13px;white-space:pre-wrap;overflow-wrap:anywhere}.import-submit-row{display:flex;justify-content:center;margin-top:20px}.form-block{display:grid;gap:8px}.form-block.full{grid-column:1 / -1}.checkbox{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--color-ink);font-weight:500}.checkbox input{width:18px;min-width:18px;height:18px;min-height:18px;margin:0}label{font-weight:600;color:var(--color-slate);font-size:13px}input,textarea,select{width:100%;border-radius:12px;border:1px solid var(--color-border-strong);padding:10px 12px;font-family:inherit;color:var(--color-ink);background:var(--color-surface);min-height:40px}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:96px}.password-visibility-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--color-accent-deep);font-weight:600;font-size:12px;cursor:pointer;padding:4px 6px;border-radius:8px}.password-visibility-toggle:hover{background:#d8783a1a}.password-visibility-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.auth-field-warning{margin:0;font-size:12px;color:#9a5b1f}.form-actions{margin-top:16px;display:flex;gap:12px;justify-content:flex-end}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.tab-button{padding:8px 14px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface-ghost-strong);font-weight:600;color:var(--color-slate);cursor:pointer}.tab-button.active{background:var(--color-solid);color:var(--color-solid-ink);border-color:transparent}.tab-button.filled{box-shadow:0 0 0 2px #d8783a2e}.tab-button.active.filled{box-shadow:none}.tab-panel{margin-top:16px}.form-inline{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;align-items:end;margin-bottom:18px}.alert{margin:12px 0;padding:12px 16px;border-radius:14px;font-weight:600}.alert.error{background:#dd4c391f;color:#8b2c1f;border:1px solid rgba(221,76,57,.2)}.alert.success{background:#2e7d5426;color:#1f5c3a;border:1px solid rgba(46,125,84,.2)}.alert.info{background:#d8783a1f;color:var(--color-slate);border:1px solid rgba(216,120,58,.2)}.empty-state{padding:16px;border-radius:16px;background:var(--color-surface-ghost-strong);border:1px dashed var(--color-border-strong);color:var(--color-muted);display:grid;gap:8px}.inline-link{color:var(--color-accent-deep);font-weight:600}.pill-row{display:flex;gap:12px;flex-wrap:wrap}.pill{background:var(--color-fill);color:var(--color-slate);padding:8px 12px;border-radius:999px;font-weight:600;font-size:13px}.review-grid{display:grid;gap:16px;margin-top:12px}.review-card{background:var(--color-surface-muted);border-radius:18px;padding:18px;border:1px solid var(--color-border-soft);display:grid;gap:12px}.review-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.review-layout{display:grid;grid-template-columns:minmax(260px,1fr) minmax(360px,2fr);gap:24px}.review-layout.compact,.review-layout.focus{grid-template-columns:1fr}.review-list-item.active{border-color:#d8783a59;box-shadow:0 12px 22px #d8783a1f}.algorithm-list-item{border-color:#3f70ff38;background:#3f70ff14}.review-list-shell{display:grid;gap:10px}.review-list-toolbar{display:flex;justify-content:flex-end;gap:12px;align-items:center;flex-wrap:wrap}.review-pager{display:inline-flex;align-items:center;gap:8px}.review-pager-label{min-width:52px;text-align:center;font-size:13px;color:var(--color-muted)}.review-list-stack{display:grid;gap:8px}.review-row-item{display:grid;grid-template-columns:minmax(160px,1fr) 140px 120px auto;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--color-border-soft);background:var(--color-surface-muted);overflow-wrap:anywhere;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.review-row-item:hover{background:var(--color-surface-hover)}.review-row-item.active{border-color:#d8783a59;box-shadow:0 12px 22px #d8783a1f}.review-row-item.algorithm{border-color:#3f70ff38;background:#3f70ff14}.review-col-title{min-width:0;font-weight:600}.review-col-part{min-width:0;opacity:.75;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.review-col-date{font-weight:500;white-space:nowrap}.review-start-button{height:32px;min-height:32px;padding:0 14px;font-size:14px;white-space:nowrap}.review-detail{display:grid;gap:16px}.summary-card{background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft);display:grid;gap:8px}.overdue-review-block{display:grid;gap:10px;border-color:#dd4c392e;background:#dd4c3914}.reviews-page .panel-stack{gap:12px}.reviews-page .panel-header{margin-bottom:12px}.summary-text{color:var(--color-slate);line-height:var(--line-normal);overflow-wrap:anywhere}.markdown-content{color:inherit;line-height:var(--line-normal)}.markdown-content h1{margin:0 0 20px;font-family:var(--font-display);color:var(--color-slate)}.markdown-content h2,.markdown-content h3{scroll-margin-top:96px;font-family:var(--font-display);color:var(--color-slate);margin:20px 0 10px}.markdown-content h2{font-size:clamp(1.2rem,2vw,1.5rem)}.markdown-content h3{font-size:var(--text-md);font-weight:600}.markdown-content p{margin:0 0 8px}.markdown-content ul,.markdown-content ol{margin:8px 0;padding-left:20px}.markdown-content li{margin:4px 0}.markdown-content code{font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;background:var(--color-surface-ghost);border-radius:6px;padding:2px 6px;font-size:.85em}.markdown-content pre{background:var(--color-surface-ghost);border:1px solid var(--color-border-faint);border-radius:12px;padding:12px;overflow:auto}.markdown-content pre code{background:transparent;padding:0;display:block}.markdown-content img{display:block;width:100%;max-width:100%;margin:16px 0 32px;border-radius:10px;border:1px solid var(--color-border-faint);box-shadow:var(--shadow-elevated)}.markdown-content hr{margin:18px 0;border:none;border-top:1px solid var(--color-border-faint)}.guidebooks-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.guidebook-card{display:grid;gap:12px}.guidebook-card h3{margin:0;font-family:var(--font-display);color:var(--color-slate)}.guidebook-card-category{text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--color-muted)}.guidebook-viewer-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.guide-tabs{display:flex;flex-wrap:wrap;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--color-border-faint)}.guide-tab{padding:8px 14px 10px;border-radius:6px 6px 0 0;color:var(--color-muted);font-weight:600;text-decoration:none;border-bottom:2px solid transparent;transition:color .18s ease,border-color .18s ease,background .18s ease}.guide-tab:hover,.guide-tab:focus-visible{color:var(--color-slate);background:var(--color-surface-ghost);outline:none}.guide-tab.active{color:var(--color-slate);border-bottom-color:var(--color-accent)}.guidebook-subnav{display:flex;flex-wrap:wrap;gap:10px}.guidebook-subnav-link{padding:6px 12px;border-radius:999px;color:var(--color-muted);text-decoration:none;background:var(--color-surface-ghost);border:1px solid transparent;transition:color .18s ease,border-color .18s ease,background .18s ease}.guidebook-subnav-link:hover,.guidebook-subnav-link:focus-visible{color:var(--color-slate);border-color:var(--color-border-faint);outline:none}.guidebook-subnav-link.active{color:var(--color-slate);border-color:#d8783a42;background:#d8783a14}.guidebook-content{width:100%;max-width:820px;margin:0 auto}.notes-grid,.questions-block{display:grid;gap:12px}.questions-title,.feedback-title{font-weight:600;color:var(--color-slate)}.question-card{padding:14px;border-radius:16px;background:var(--color-surface-ghost);border:1px solid var(--color-border-faint);display:grid;gap:8px}.question-text{font-weight:600}.feedback-block{background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft);display:grid;gap:12px}.success-block{margin-top:16px;padding:16px;border-radius:18px;background:#2e7d541f;border:1px solid rgba(46,125,84,.2);display:grid;gap:8px}.success-title{font-weight:600}.success-detail{color:var(--color-muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121573;display:grid;place-items:center;z-index:20;padding:24px}.modal{width:min(760px,100%);max-height:min(90vh,calc(100dvh - 48px));background:var(--color-surface);border-radius:24px;padding:24px;box-shadow:var(--shadow-modal);display:grid;grid-template-rows:auto minmax(0,1fr);gap:16px;overflow:hidden}.create-group-modal,.create-book-modal{width:min(520px,100%)}.confirm-modal{width:min(460px,100%)}.review-modal{width:min(880px,100%)}.toast{position:fixed;right:28px;bottom:28px;background:var(--color-solid);color:var(--color-solid-ink);padding:12px 18px;border-radius:999px;font-weight:600;box-shadow:var(--shadow-toast);z-index:30}.modal-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex:0 0 auto}.modal-body{display:grid;gap:16px;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.form-stack{display:flex;flex-direction:column;gap:14px;margin-top:16px}.form-stack .modal-actions{margin-top:12px}.modal-actions .danger-button{margin-right:auto}.prompt-area{width:100%;border-radius:16px;border:1px solid var(--color-border-strong);padding:14px;font-family:var(--font-sans)}.prompt-grid{display:grid;gap:16px}.prompt-block{display:grid;gap:12px}.prompt-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.prompt-title{font-weight:600;color:var(--color-slate)}.code-area{font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;line-height:1.4;-moz-tab-size:4;-o-tab-size:4;tab-size:4}.danger-button{border:1px solid rgba(221,76,57,.3);background:#dd4c391f;color:#8b2c1f;border-radius:999px;padding:10px 18px;font-weight:600;cursor:pointer}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.summary-block{background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft)}.training-panel{display:grid;gap:12px}.training-mode-tabs{display:flex;gap:8px;flex-wrap:wrap}.training-mode-tabs .ghost-button.active{background:var(--color-fill);border-color:var(--color-border)}.code-input{width:100%;border-radius:14px;border:1px solid var(--color-border-soft);background:var(--color-surface);padding:12px;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;line-height:1.4;-moz-tab-size:4;-o-tab-size:4;tab-size:4}.typing-metrics{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--color-slate)}.typing-shadow{position:relative;border-radius:14px;border:1px solid var(--color-border-soft);background:var(--color-surface);overflow:hidden;min-height:220px}.typing-layer{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;padding:12px;white-space:pre-wrap;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;line-height:1.4;-moz-tab-size:4;-o-tab-size:4;tab-size:4;overflow:hidden;pointer-events:none}.typing-reference{color:#23354459;z-index:1}.typing-overlay{z-index:2}.typing-overlay span.correct{color:var(--color-slate)}.typing-overlay span.wrong{color:#b23b2a;background:#dd4c3933}.typing-overlay span.pending{color:#23354433}.typing-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none;background:transparent;color:transparent;caret-color:var(--color-accent-deep);padding:12px;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;line-height:1.4;-moz-tab-size:4;-o-tab-size:4;tab-size:4;resize:none;z-index:3}.typing-input:focus{outline:none}.diff-table{display:grid;gap:8px}.diff-header-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.diff-header{font-weight:600;color:var(--color-slate)}.diff-body{display:grid;gap:6px}.diff-line{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:6px 8px;border-radius:12px;background:var(--color-surface);border:1px solid var(--color-border-faint)}.diff-line.changed{background:#d8783a1a;border-color:#d8783a40}.diff-line.extra{background:#2e7d541a;border-color:#2e7d5440}.diff-line.missing{background:#dd4c391a;border-color:#dd4c3940}.diff-cell{display:grid;grid-template-columns:32px 1fr;gap:8px;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:13px;white-space:pre-wrap}.diff-line-number{color:var(--color-muted);text-align:right}.diff-line-text{color:var(--color-slate);white-space:pre-wrap}.algorithm-card{display:grid;gap:12px}.algorithm-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.algorithm-meta{font-size:13px;color:var(--color-muted)}.group-form{margin-top:8px}.summary-title{text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:var(--color-muted)}.summary-value{font-weight:600;margin-top:8px}.summary-list{margin:12px 0 0;padding-left:18px;color:var(--color-slate)}.summary-muted{margin-top:8px;color:var(--color-muted)}.stats-controls{display:flex;gap:10px}.stats-scroller{display:flex;gap:16px;overflow-x:auto;padding-bottom:6px;min-width:0;width:100%;max-width:100%;scroll-snap-type:x mandatory}.stats-card{flex:0 0 280px;background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft);display:grid;gap:12px;scroll-snap-align:start}.stats-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.stats-title{font-weight:600}.stats-meta{font-size:12px;color:var(--color-muted)}.stats-summary{font-size:13px;color:var(--color-slate);min-height:42px}.stats-actions{display:flex;justify-content:flex-end}.review-stats-inline{display:flex;flex-wrap:wrap;align-items:center;gap:10px;color:var(--color-muted);font-size:14px;font-weight:600}.review-stats-inline>span:not(:last-child):after{content:"•";margin-left:10px;color:var(--color-border-strong)}.review-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.review-stats-card{background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft);display:grid;gap:12px}.review-progress-track,.review-progress-bar{height:4px}.review-stats-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.schedule-list{display:grid;gap:12px}.schedule-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px;border-radius:16px;background:var(--color-surface-ghost);border:1px solid var(--color-border-faint)}.schedule-actions{display:flex;align-items:center;gap:10px}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.about-card{background:var(--color-surface-muted);border-radius:18px;padding:16px;border:1px solid var(--color-border-soft)}.about-back-link{align-self:flex-start;border:none;background:transparent;color:var(--color-accent-deep);font:inherit;font-weight:700;padding:0;cursor:pointer}.about-back-link:hover{color:var(--color-accent)}.about-back-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:8px}.about-label{text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--color-muted)}.about-value{margin-top:8px;font-weight:600;color:var(--color-slate)}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-panel{width:min(560px,100%)}.auth-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.auth-panel h1{margin:0 0 10px;font-family:var(--font-display)}.auth-back-link{font-size:.82rem;font-weight:600;color:var(--color-accent-deep)}.auth-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.auth-checkbox{margin-top:-4px}.auth-note{margin-top:14px}.cookie-banner{position:fixed;left:50%;bottom:16px;transform:translate(-50%);width:min(680px,calc(100vw - 24px));display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:14px;border:1px solid var(--color-border-strong);background:var(--color-surface);box-shadow:var(--shadow-elevated);z-index:60}.cookie-banner-text{overflow-wrap:anywhere}.cookie-banner-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.error-banner{width:100%}.error-banner-header{display:flex;gap:10px;align-items:baseline;justify-content:space-between}.error-banner-header small{font-size:.75rem;opacity:.84}.error-banner-list{margin:10px 0 0;padding-left:18px;display:grid;gap:4px;font-weight:500}.admin-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:14px}.admin-table-wrap{overflow:auto;border:1px solid var(--color-border-soft);border-radius:14px}.admin-table{width:100%;border-collapse:collapse;min-width:920px}.admin-table th,.admin-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--color-border-soft);vertical-align:middle}.admin-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;color:var(--color-muted);background:var(--color-surface-muted)}.admin-table tr:last-child td{border-bottom:none}.admin-empty{color:var(--color-muted);text-align:center}.admin-skeleton{height:28px;border-radius:8px;background:linear-gradient(90deg,var(--color-surface-muted) 0%,var(--color-surface) 50%,var(--color-surface-muted) 100%);background-size:240% 100%;animation:pulseSlide 1.2s ease infinite}.admin-user-list{display:grid;gap:12px}.admin-user-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:start;padding:16px;border-radius:18px;background:var(--color-surface-muted);border:1px solid var(--color-border-soft);transition:background-color .18s ease,border-color .18s ease}.admin-user-row:hover{background:var(--color-surface-hover);border-color:#d8783a2e}.admin-user-main{min-width:0;display:grid;gap:12px}.admin-user-header{min-width:0}.admin-user-primary{display:grid;gap:8px;min-width:0}.admin-user-email{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;color:var(--color-slate)}.admin-user-badges{display:flex;flex-wrap:wrap;gap:8px}.admin-user-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 14px;margin:0}.admin-user-meta-item{min-width:0;display:grid;gap:2px}.admin-user-meta-item-wide{grid-column:span 3}.admin-user-meta-item dt{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted)}.admin-user-meta-item dd{margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-slate)}.admin-user-actions{display:flex;align-items:flex-start;gap:8px;flex:0 0 auto}.admin-icon-button{width:36px;min-width:36px;min-height:36px;padding:0;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-slate);display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;cursor:pointer}.admin-icon-button:hover:not(:disabled){border-color:#d8783a52;background:#d8783a14}.admin-icon-button:disabled{opacity:.6;cursor:not-allowed}.admin-icon-button-danger{color:#8b2c1f;border-color:#dd4c393d;background:#dd4c391a}.admin-icon-button-danger:hover:not(:disabled){border-color:#dd4c3957;background:#dd4c3924}.admin-user-menu-wrap{position:relative}.admin-user-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:168px;padding:6px;border-radius:14px;background:var(--color-surface);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-elevated);display:grid;gap:4px;z-index:5}.admin-user-menu-item{width:100%;border:none;border-radius:10px;background:transparent;color:var(--color-slate);padding:10px 12px;text-align:left;font:inherit;font-weight:600;cursor:pointer}.admin-user-menu-item:hover:not(:disabled){background:#d8783a1a}.admin-user-menu-item:disabled{opacity:.6;cursor:not-allowed}.admin-user-skeleton{height:104px;border-radius:18px}.admin-pagination{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-pagination-actions{display:flex;gap:10px}.performance-filters{margin-bottom:10px}.performance-filter-actions{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.performance-quick-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.performance-table{min-width:1220px}.performance-cell-stack{display:grid;gap:3px}.performance-header{align-items:flex-start}.performance-back-button{min-width:176px}.performance-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin-top:8px}.performance-summary-card{padding:14px;border-radius:16px;background:var(--color-surface-muted);border:1px solid var(--color-border-soft);display:grid;align-content:start;gap:10px;min-height:180px}.performance-summary-card h3{margin:0;font-size:.95rem;color:var(--color-slate)}.performance-summary-header{display:grid;gap:2px}.performance-summary-header p{margin:0;font-size:.74rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em}.performance-metric-list{display:grid;gap:8px}.performance-metric-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.performance-metric-row span{font-size:.82rem;color:var(--color-muted)}.performance-metric-row strong{font-size:.88rem;color:var(--color-slate)}.performance-limit-picker{min-width:140px}.performance-activities-wrap{margin-top:12px}.performance-activities-table{min-width:980px}.performance-entity{display:grid;gap:3px;min-width:0}.performance-entity strong{display:block;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;overflow-wrap:anywhere}.performance-entity .muted{font-size:.75rem;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;overflow-wrap:anywhere}.activity-pill{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.activity-pill.status-completed{background:#2e7d5426;color:#1f5c3a;border-color:#2e7d5440}.activity-pill.status-aborted{background:#dd4c3924;color:#8b2c1f;border-color:#dd4c3938}.activity-pill.status-imported{background:#3f70ff21;color:#234175;border-color:#3f70ff38}.activity-pill.source-live{background:#d8783a29;color:var(--color-accent-deep);border-color:#d8783a3d}.activity-pill.source-import{background:#3f70ff21;color:#234175;border-color:#3f70ff38}.activity-pill.source-backfill{background:#6d758429;color:#3b4252;border-color:#6d75843d}.online-badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.online-badge.online{background:#2e7d5426;color:#1f5c3a}.online-badge.offline{background:#6d75842e;color:#3b4252}.admin-secret-box{background:var(--color-surface-muted);border:1px solid var(--color-border-faint);border-radius:12px;padding:12px;overflow-wrap:anywhere}.admin-secret-box code{font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.95rem}.landing-shell{--landing-space-1: 8px;--landing-space-2: 16px;--landing-space-3: 24px;--landing-space-4: 32px;--landing-space-5: 48px;--landing-radius-lg: 20px;--landing-radius-xl: 30px;--landing-shadow-panel: 0 22px 50px rgba(30, 42, 54, .12);--landing-shadow-panel-hover: 0 26px 56px rgba(30, 42, 54, .16);--landing-line-heading: 1.22;--landing-line-body: 1.62;--landing-panel-border: rgba(35, 53, 68, .14);--landing-panel-bg: linear-gradient(148deg, rgba(255, 255, 255, .96), rgba(247, 241, 231, .92));--landing-text-primary: #1b1d1f;--landing-text-secondary: #233544;--landing-text-muted: #4b5763;--landing-link: #a5521f;--landing-link-hover: #cf6b2b;--landing-soft-strong: rgba(35, 53, 68, .88);max-width:1120px;margin:0 auto;padding:var(--landing-space-4) var(--landing-space-3) var(--landing-space-5);display:grid;gap:var(--landing-space-3)}.landing-shell>.panel{position:relative;overflow:hidden;border-radius:var(--landing-radius-xl);padding:var(--landing-space-4);border:1px solid var(--landing-panel-border);background:var(--landing-panel-bg);box-shadow:var(--landing-shadow-panel);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}.landing-shell,.landing-shell h1,.landing-shell h2,.landing-shell h3,.landing-shell strong{color:var(--landing-text-primary)}.landing-shell h1,.landing-shell h2{line-height:var(--landing-line-heading)}.landing-shell h1,.landing-shell h2,.landing-shell h3{letter-spacing:-.02em}.landing-shell p,.landing-shell li{line-height:var(--landing-line-body)}.landing-shell .muted{color:var(--landing-text-muted);font-size:.97rem}.landing-shell .panel-header{margin-bottom:var(--landing-space-2)}.landing-shell .panel h2{margin:0 0 var(--landing-space-1);font-size:clamp(1.4rem,2.2vw,1.92rem)}.landing-section{scroll-margin-top:96px}.landing-section:hover{transform:translateY(-3px);border-color:#d8783a42;box-shadow:var(--landing-shadow-panel-hover)}.landing-header{position:sticky;top:12px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:var(--landing-space-2);padding:var(--landing-space-2);border-radius:var(--landing-radius-lg);background:var(--color-surface-glass);border:1px solid rgba(35,53,68,.16);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 28px #2335441f}.landing-brand{display:inline-flex;align-items:center;gap:10px;min-width:0}.landing-brand-mark{width:34px;height:34px;border-radius:10px;overflow:hidden}.landing-brand-mark-logo{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.landing-brand-title{font-family:var(--font-display);font-weight:600;color:var(--landing-text-secondary)}.landing-nav{display:flex;align-items:center;justify-content:center;gap:var(--landing-space-1);flex-wrap:wrap}.landing-nav-link{padding:var(--landing-space-1) var(--landing-space-2);border-radius:999px;color:var(--landing-text-secondary);border:1px solid transparent;transition:.18s ease}.landing-nav-link:hover{background:#d8783a1f;border-color:#d8783a33}.landing-nav-link:focus-visible{outline:none;background:#d8783a26;border-color:#d8783a52;box-shadow:0 0 0 3px #d8783a33}.landing-auth{display:inline-flex;align-items:center;gap:var(--landing-space-1)}.landing-auth .primary-button,.landing-auth .ghost-button{white-space:nowrap}.landing-hero{background:radial-gradient(circle at 12% 12%,rgba(216,120,58,.22),transparent 36%),radial-gradient(circle at 86% 80%,rgba(35,53,68,.18),transparent 44%),linear-gradient(150deg,#fffffff7,#f6ede0eb)}.landing-hero-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);align-items:center;gap:var(--landing-space-4)}.landing-hero-copy{display:grid;gap:var(--landing-space-2);min-width:0}.landing-hero h1{margin:0;font-family:var(--font-display);font-size:clamp(2.05rem,4vw,3.35rem);max-width:18ch}.landing-accent-text{color:var(--color-accent-deep);background:linear-gradient(120deg,#cf6b2b,#a5521f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:var(--landing-space-2)}.landing-hero .primary-button,.landing-hero .ghost-button{padding:12px 22px}.landing-hero .primary-button{box-shadow:0 16px 30px #d8783a57}.landing-hero .ghost-button{background:#ffffffbd}.landing-lead{max-width:56ch}.landing-hero-note{width:-moz-fit-content;width:fit-content;margin:0;padding:10px 14px;border-radius:999px;border:1px solid rgba(216,120,58,.3);background:#d8783a1a;color:var(--landing-link);font-size:.92rem}.landing-list{margin:0;padding-left:var(--landing-space-3);display:grid;gap:var(--landing-space-1);color:var(--landing-text-secondary)}.landing-list li::marker{color:var(--color-accent-deep);font-weight:600}.landing-list li+li{margin-top:4px}.landing-flow{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--landing-space-2)}.landing-flow-step{position:relative;display:grid;gap:var(--landing-space-1);padding:var(--landing-space-3);border-radius:var(--landing-radius-lg);border:1px solid rgba(35,53,68,.14);background:linear-gradient(145deg,#fffffff5,#f8f1e7e0);box-shadow:0 14px 28px #2335441c;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.landing-flow-step:hover{transform:translateY(-3px);border-color:#d8783a47;box-shadow:0 18px 32px #23354429}.landing-flow-index{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;font-family:var(--font-display);font-size:.92rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-deep));box-shadow:0 12px 22px #d8783a3d}.landing-flow-step h3{margin:0;font-family:var(--font-display);font-size:1.12rem;line-height:1.35;color:var(--landing-text-secondary)}.landing-flow-step p{margin:0}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--landing-space-2)}.landing-guides{background:radial-gradient(circle at 86% 14%,rgba(216,120,58,.16),transparent 30%),linear-gradient(145deg,#fffffffa,#f5ece0f0)}.landing-guides-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--landing-space-2)}.landing-guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--landing-space-2)}.landing-guide-card{display:grid;gap:18px;padding:var(--landing-space-3);border-radius:var(--landing-radius-lg);border:1px solid rgba(35,53,68,.14);background:linear-gradient(148deg,#fffffff5,#faf4ebe6);box-shadow:0 14px 30px #2335441c;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.landing-guide-card:hover{transform:translateY(-3px);border-color:#d8783a4d;box-shadow:0 18px 34px #23354429}.landing-guide-card-copy{display:grid;gap:10px}.landing-guide-card h3{margin:0;font-family:var(--font-display);font-size:1.16rem;color:var(--landing-text-secondary)}.landing-guide-card p{margin:0}.landing-guide-link{width:-moz-fit-content;width:fit-content;padding:10px 16px;border-radius:999px;border:1px solid rgba(216,120,58,.28);background:#d8783a1a;color:var(--landing-link);font-weight:700;transition:background .18s ease,border-color .18s ease,transform .18s ease}.landing-guide-link:hover,.landing-guide-link:focus-visible{background:#d8783a29;border-color:#d8783a61;color:var(--landing-link-hover);transform:translateY(-1px);outline:none}.landing-feature-card{display:grid;gap:10px;padding:var(--landing-space-3);border-radius:var(--landing-radius-lg);border:1px solid rgba(35,53,68,.14);background:linear-gradient(145deg,#fffffff5,#f7f1e6e6);box-shadow:0 14px 30px #2335441c;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.landing-feature-card:hover{transform:translateY(-3px);border-color:#d8783a47;box-shadow:0 18px 34px #23354429}.landing-feature-tag{width:-moz-fit-content;width:fit-content;padding:5px 10px;border-radius:999px;border:1px solid rgba(216,120,58,.28);background:#d8783a1a;color:var(--landing-link);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.landing-feature-card h3{margin:0;font-family:var(--font-display);font-size:1.12rem;line-height:1.3;color:var(--landing-text-secondary)}.landing-feature-card p{margin:0}.landing-hero-pills{display:flex;flex-wrap:wrap;gap:var(--landing-space-1)}.landing-hero-pills span{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;border:1px solid rgba(35,53,68,.12);background:#ffffffb8;color:var(--landing-text-secondary);font-size:.82rem;font-weight:600}.landing-hero-visual{position:relative;min-height:320px;display:grid;place-items:center}.landing-hero-mockup{width:min(100%,470px);border-radius:24px;padding:12px;background:linear-gradient(148deg,#fffffff5,#f5ecdfe6);border:1px solid rgba(35,53,68,.16);box-shadow:0 28px 54px #1c273247;transform:rotate(1.2deg)}.landing-hero-mockup img{width:100%;display:block;aspect-ratio:16 / 10;-o-object-fit:cover;object-fit:cover;border-radius:16px}.landing-hero-chip{position:absolute;z-index:2;display:grid;gap:2px;padding:12px 14px;border-radius:14px;border:1px solid rgba(35,53,68,.14);background:#ffffffd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 30px #141f2b2e}.landing-hero-chip strong{color:var(--landing-text-secondary);font-size:.76rem;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.09em}.landing-hero-chip span{color:var(--landing-soft-strong);font-size:.84rem;font-weight:600}.landing-hero-chip-top{top:18px;left:-12px}.landing-hero-chip-bottom{right:-6px;bottom:14px}.landing-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--landing-space-2)}.landing-shot{border:1px solid rgba(35,53,68,.14);background:linear-gradient(150deg,#fffffff5,#f5eee4e6);border-radius:var(--landing-radius-lg);overflow:hidden;display:grid;padding:0;text-align:left;cursor:pointer;box-shadow:0 14px 28px #2335441f;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}.landing-shot:hover{transform:translateY(-4px);border-color:#d8783a47;box-shadow:0 18px 34px #2335442e}.landing-shot:focus-visible{outline:none;border-color:#d8783a59;box-shadow:0 0 0 3px #d8783a33}.landing-shot img{width:100%;aspect-ratio:16 / 10;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .35s ease}.landing-shot:hover img{transform:scale(1.03)}.landing-shot-caption{padding:var(--landing-space-2);display:grid;gap:var(--landing-space-1)}.landing-shot-caption strong{font-size:.98rem;color:var(--landing-text-secondary)}.landing-shot-caption span{font-size:.86rem;color:var(--landing-text-muted)}.landing-footer{display:flex;flex-wrap:wrap;gap:var(--landing-space-2);align-items:center;justify-content:space-between;padding-top:var(--landing-space-3);padding-bottom:var(--landing-space-3)}.landing-inline-link{color:var(--landing-link);text-decoration:underline;text-underline-offset:2px}.landing-inline-link:hover,.landing-inline-link:focus-visible{color:var(--landing-link-hover)}.landing-footer a{color:var(--landing-text-secondary)}.landing-footer a:hover,.landing-footer a:focus-visible{color:var(--landing-link-hover)}:root[data-theme=dark] .landing-shell{--landing-shadow-panel: 0 24px 56px rgba(2, 4, 8, .5);--landing-shadow-panel-hover: 0 28px 62px rgba(2, 4, 8, .58);--landing-panel-border: rgba(243, 239, 231, .16);--landing-panel-bg: linear-gradient(148deg, rgba(21, 26, 33, .96), rgba(16, 21, 28, .92));--landing-text-primary: #f3efe7;--landing-text-secondary: #e4ecf6;--landing-text-muted: #b8c4d2;--landing-link: #ffb579;--landing-link-hover: #ffc794;--landing-soft-strong: #dce5f0}:root[data-theme=dark] .landing-hero{background:radial-gradient(circle at 12% 12%,rgba(216,120,58,.22),transparent 36%),radial-gradient(circle at 86% 80%,rgba(5,8,13,.7),transparent 44%),linear-gradient(150deg,#151a21f7,#0e131aeb)}:root[data-theme=dark] .landing-flow-step,:root[data-theme=dark] .landing-feature-card,:root[data-theme=dark] .landing-guide-card,:root[data-theme=dark] .landing-shot,:root[data-theme=dark] .landing-hero-mockup{border-color:#f3efe729;background:linear-gradient(145deg,#191f27f5,#11161ee6)}:root[data-theme=dark] .landing-hero-pills span,:root[data-theme=dark] .landing-hero-chip{border-color:#f3efe72e;background:#181f27e6}:root[data-theme=dark] .landing-hero-note,:root[data-theme=dark] .landing-feature-tag{border-color:#ffb57959;background:#ffb57924}:root[data-theme=dark] .context-help-link{border-color:#ffb57959;background:#ffb57924;color:#ffcfaa}:root[data-theme=dark] .landing-guides{background:radial-gradient(circle at 86% 14%,rgba(255,181,121,.12),transparent 30%),linear-gradient(145deg,#151a21f7,#10151cf0)}:root[data-theme=dark] .landing-guide-link{border-color:#ffb57959;background:#ffb57924}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .landing-shell{--landing-shadow-panel: 0 24px 56px rgba(2, 4, 8, .5);--landing-shadow-panel-hover: 0 28px 62px rgba(2, 4, 8, .58);--landing-panel-border: rgba(243, 239, 231, .16);--landing-panel-bg: linear-gradient( 148deg, rgba(21, 26, 33, .96), rgba(16, 21, 28, .92) );--landing-text-primary: #f3efe7;--landing-text-secondary: #e4ecf6;--landing-text-muted: #b8c4d2;--landing-link: #ffb579;--landing-link-hover: #ffc794;--landing-soft-strong: #dce5f0}:root:not([data-theme=light]) .landing-hero{background:radial-gradient(circle at 12% 12%,rgba(216,120,58,.22),transparent 36%),radial-gradient(circle at 86% 80%,rgba(5,8,13,.7),transparent 44%),linear-gradient(150deg,#151a21f7,#0e131aeb)}:root:not([data-theme=light]) .landing-flow-step,:root:not([data-theme=light]) .landing-feature-card,:root:not([data-theme=light]) .landing-guide-card,:root:not([data-theme=light]) .landing-shot,:root:not([data-theme=light]) .landing-hero-mockup{border-color:#f3efe729;background:linear-gradient(145deg,#191f27f5,#11161ee6)}:root:not([data-theme=light]) .landing-hero-pills span,:root:not([data-theme=light]) .landing-hero-chip{border-color:#f3efe72e;background:#181f27e6}:root:not([data-theme=light]) .landing-hero-note,:root:not([data-theme=light]) .landing-feature-tag{border-color:#ffb57959;background:#ffb57924}:root:not([data-theme=light]) .context-help-link{border-color:#ffb57959;background:#ffb57924;color:#ffcfaa}:root:not([data-theme=light]) .landing-guides{background:radial-gradient(circle at 86% 14%,rgba(255,181,121,.12),transparent 30%),linear-gradient(145deg,#151a21f7,#10151cf0)}:root:not([data-theme=light]) .landing-guide-link{border-color:#ffb57959;background:#ffb57924}}.landing-lightbox{width:min(1000px,calc(100vw - 24px))}.landing-lightbox img{width:100%;max-height:70vh;-o-object-fit:contain;object-fit:contain;border-radius:12px;background:var(--color-surface-muted)}.backup-actions{margin-top:0}.backup-sections{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:stretch}.backup-card{gap:14px}.backup-card-intro{display:grid;gap:8px}.backup-card-intro p{margin:0}.backup-card h3{margin:0;font-family:var(--font-display)}.backup-card .form-actions{justify-content:flex-start}.backup-card .backup-import-actions{justify-content:flex-end}.backup-card-actions{margin-top:0;justify-content:flex-start}.backup-export-actions .backup-action-button{min-width:210px}.backup-import-actions{margin-top:2px;justify-content:flex-end;align-items:center;gap:12px;flex-wrap:wrap}.backup-import-note{margin-right:auto;font-size:.84rem}.backup-action-button{min-height:42px;border-radius:12px;padding:10px 18px;font-size:.93rem;font-weight:600;line-height:1;letter-spacing:.01em;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease;min-width:178px}.backup-action-button:focus-visible{outline:none;box-shadow:0 0 0 3px #d8783a33}.backup-action-button:not(:disabled):active{transform:translateY(1px)}.backup-action-primary{border:1px solid transparent;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-deep));color:#fff;box-shadow:0 12px 24px #d8783a47}.backup-action-primary:not(:disabled):hover{box-shadow:0 16px 28px #d8783a52;filter:saturate(1.05)}.backup-action-secondary{border:1px solid var(--color-border);background:linear-gradient(140deg,var(--color-surface),var(--color-surface-muted));color:var(--color-slate);box-shadow:inset 0 1px #fff9}.backup-action-secondary:not(:disabled):hover{border-color:#d8783a52;background:linear-gradient(140deg,#d8783a1a,#d8783a0f)}.backup-action-button:disabled{opacity:1;cursor:not-allowed;transform:none;box-shadow:none}.backup-action-primary:disabled{border-color:var(--color-border-faint);background:linear-gradient(140deg,var(--color-surface-muted),var(--color-surface));color:var(--color-muted)}.backup-action-secondary:disabled{border-color:var(--color-border-soft);background:var(--color-surface-muted);color:var(--color-muted)}.backup-import-flow{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}.backup-select-wrap{position:relative}.backup-mode-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:36px;background:linear-gradient(140deg,var(--color-surface),var(--color-surface-muted));transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.backup-mode-select:hover:not(:disabled){border-color:#d8783a4d}.backup-mode-select:focus-visible{outline:none;border-color:#d8783a6b;box-shadow:0 0 0 3px #d8783a24}.backup-mode-select:disabled{color:var(--color-muted);background:var(--color-surface-muted)}.backup-select-caret{position:absolute;top:50%;right:12px;transform:translateY(-50%);color:var(--color-muted);font-size:.8rem;pointer-events:none}.backup-mode-help{display:grid;gap:8px;margin-top:6px}.backup-mode-help-item{margin:0;padding:9px 11px;border-radius:10px;border:1px solid var(--color-border-soft);background:var(--color-surface-muted);color:var(--color-muted);font-size:.84rem;line-height:1.36;min-height:44px;display:flex;align-items:center}.backup-mode-help-item.active{border-color:#d8783a38;background:#d8783a0f;color:var(--color-slate)}.backup-mode-help-item.warning.active{border-color:#a5521f3d;background:#d8783a1a}.backup-mode-warning{width:100%;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(165,82,31,.22);background:linear-gradient(135deg,#d8783a14,#d8783a0a);color:var(--color-slate);border-radius:10px;padding:10px 12px;font-size:.84rem;line-height:1.4}.backup-mode-warning-icon{width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:.72rem;color:#fff;background:var(--color-accent-deep)}.backup-card input[type=file],.backup-card select,.backup-card .primary-button,.backup-card .ghost-button{min-height:42px}.backup-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.backup-file-picker{min-height:42px;border:1px solid var(--color-border-strong);border-radius:11px;background:var(--color-surface);display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:4px 6px;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.backup-file-picker:hover{border-color:#d8783a57}.backup-file-picker:focus-within{border-color:#d8783a70;box-shadow:0 0 0 3px #d8783a29}.backup-file-picker.disabled{opacity:.7;cursor:not-allowed;background:var(--color-surface-muted)}.backup-file-button{min-height:28px;padding:3px 11px;border-radius:8px;display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.84rem;color:#fff;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-deep));white-space:nowrap}.backup-file-picker.disabled .backup-file-button{background:linear-gradient(135deg,#b8b0a6,#9f988f)}.backup-file-state{color:var(--color-muted);font-size:.9rem;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.backup-confirm{display:flex;align-items:center;gap:10px;color:var(--color-slate);margin-top:0}.backup-summary h3,.backup-summary h4{margin:0}.backup-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:12px}.backup-columns ul{margin:8px 0 0;padding:0;list-style:none;display:grid;gap:8px}.backup-columns li{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px dashed var(--color-border-soft);padding-bottom:6px}.backup-warnings{margin-top:14px}.backup-warnings summary{cursor:pointer;font-weight:600}.backup-warnings ul{margin:8px 0 0;padding-left:18px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseSlide{0%{background-position:100% 0}to{background-position:-100% 0}}@media (max-width: 1024px){.app-shell{padding-left:var(--sidebar-width)}.app-shell.sidebar-collapsed{padding-left:var(--sidebar-width-collapsed)}.app-shell.sidebar-expanded{padding-left:var(--sidebar-width)}.sidebar{padding:24px 20px;gap:20px}.content{padding:24px 24px calc(32px + env(safe-area-inset-bottom))}.topbar{gap:18px;margin-bottom:24px}.page,.page-grid,.review-layout{gap:16px}.review-layout{grid-template-columns:1fr}.panel{padding:20px 22px;border-radius:22px}.panel-stack{gap:20px}.landing-header{top:8px;flex-wrap:wrap}.landing-nav{order:3;width:100%;justify-content:flex-start}.landing-auth{margin-left:auto}.landing-shell{padding:var(--landing-space-3) var(--landing-space-2) var(--landing-space-4)}.landing-shell>.panel{padding:var(--landing-space-3)}.landing-flow,.landing-hero-layout{grid-template-columns:1fr;gap:var(--landing-space-3)}.landing-hero h1{max-width:none}.landing-hero-visual{width:100%;min-height:0}.landing-hero-mockup{width:100%;max-width:560px;transform:none}.landing-hero-chip-top{left:8px;top:-10px}.landing-hero-chip-bottom{right:8px;bottom:-12px}.landing-footer{align-items:flex-start;flex-direction:column}.landing-guides-header{align-items:flex-start}}@media (min-width: 1024px){.settings-layout{grid-template-columns:minmax(0,.35fr) minmax(0,.65fr);align-items:start}.settings-full-width-panel{grid-column:1 / -1}}@media (max-width: 768px){.app-shell{padding-left:0;min-height:100vh;height:auto;overflow:visible}.sidebar{position:relative;height:auto;overflow:visible;padding:16px;gap:16px;border-right:none;border-bottom:1px solid var(--color-line)}.nav-wrap{flex:initial;overflow:visible;min-height:auto;padding-right:0}.nav{gap:12px}.nav-section-title{margin-top:0}.nav-item{min-height:44px}.content{height:auto;overflow:visible;padding:16px 16px calc(24px + env(safe-area-inset-bottom))}.topbar{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:20px}.topbar h1{font-size:clamp(1.75rem,8vw,2.125rem)}.topbar-actions{width:100%;flex-wrap:wrap}.page,.page-grid{gap:16px}.panel{padding:16px;border-radius:20px}.panel-stack{gap:16px}.summary-block,.summary-card,.card,.review-stats-card,.review-metric-card,.performance-summary-card{padding:14px}.panel-header,.book-card-header,.algorithm-header,.review-header,.review-list-toolbar,.review-item-header,.stats-header,.schedule-row,.code-snippet-header,.modal-header,.modal-actions,.form-actions,.list-row,.list-actions,.schedule-actions,.admin-pagination,.admin-pagination-actions,.performance-filter-actions,.backup-import-actions,.backup-confirm,.auth-actions,.auth-header,.typing-metrics,.prompt-header,.error-banner-header,.cookie-banner{flex-direction:column;align-items:stretch}.cookie-banner-actions{justify-content:space-between}.panel-header,.book-card-header,.algorithm-header,.review-header,.review-list-toolbar,.review-item-header,.stats-header,.schedule-row,.modal-header,.auth-header,.typing-metrics,.prompt-header,.error-banner-header{align-items:flex-start}.primary-button,.ghost-button,.danger-button,.tab-button,.backup-action-button,input,textarea,select{min-height:44px}.review-start-button{min-height:32px}.card-grid,.summary-grid,.about-grid,.book-stats,.form-grid,.form-inline,.admin-filters,.review-stats-overview,.review-stats-grid,.performance-summary-grid,.backup-columns{grid-template-columns:1fr}.import-target-row{flex-direction:column}.reading-session-setup-row{grid-template-columns:1fr}.reading-session-session-header{gap:12px}.session-meta-row{flex-direction:column;align-items:stretch;gap:12px}.reading-session-header-chip,.reading-session-part-inline{display:grid;gap:8px}.reading-session-header-select,.reading-session-part-inline input,.reading-session-book-select{width:100%;min-width:0}.reading-session-note-item{grid-template-columns:1fr}.reading-session-main{margin:0;padding-right:0}.reading-session-note-actions{justify-content:flex-start;flex-wrap:wrap}.reading-session-note-edit-row{flex-direction:column}.session-actions{flex-wrap:wrap;justify-content:flex-start}.session-action-group{flex-wrap:wrap}.reading-session-capture-field textarea{padding-right:16px;padding-top:46px}.capture-type-select{right:10px}.import-dropzone{padding:24px 18px}.book-stat-wide{grid-column:auto}.review-pager{width:100%;justify-content:space-between}.review-pager-label{min-width:0}.floating-timer{width:190px;height:240px;padding:16px;border-radius:20px}.floating-timer.collapsed{width:152px}.floating-timer-center{padding:28px}.floating-timer-time{font-size:30px}.floating-timer-control{width:44px;height:44px;font-size:22px}.floating-timer-controls{gap:10px}.review-row-item{grid-template-columns:minmax(120px,1fr) 120px 96px auto;gap:10px}.stats-controls{width:100%;flex-wrap:wrap}.stats-card{flex-basis:min(320px,calc(100vw - 48px))}.diff-header-row,.diff-line{grid-template-columns:1fr}.diff-cell{grid-template-columns:24px 1fr;font-size:12px}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{min-width:600px}.admin-user-row{grid-template-columns:minmax(0,1fr) auto;padding:14px}.admin-user-meta{grid-template-columns:1fr}.admin-user-meta-item-wide{grid-column:auto}.admin-icon-button{width:44px;min-width:44px;min-height:44px}.performance-table{min-width:1080px}.performance-activities-table{min-width:880px}.performance-entity strong,.performance-entity .muted{max-width:none;overflow:visible;text-overflow:clip;white-space:normal}.backup-columns li{align-items:flex-start;flex-direction:column}.modal-backdrop{padding:16px}.modal{padding:18px;border-radius:20px}.toast{left:16px;right:16px;bottom:16px;text-align:center}.landing-auth{width:100%;margin-left:0}.landing-auth .primary-button,.landing-auth .ghost-button{width:auto}}@media (max-width: 640px){.review-row-item{grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center}.review-col-title{grid-column:1;grid-row:1}.review-col-part{grid-column:1;grid-row:2}.review-col-date{grid-column:1;grid-row:3;font-size:14px}.review-start-button{grid-column:2;grid-row:1 / span 3;align-self:center}}@media (max-width: 480px){.algorithm-groups-page .list-actions>.ghost-button,.algorithm-group-detail-page .list-row>.ghost-button{font-size:13px}.sidebar{padding:12px}.content{padding:12px 12px calc(20px + env(safe-area-inset-bottom))}.panel{padding:14px}.topbar h1{font-size:26px}.modal-backdrop{padding:12px}.modal{padding:16px}.toast{left:12px;right:12px;bottom:12px}.landing-shell>.panel{border-radius:22px}.landing-hero-note{width:100%;border-radius:14px}.landing-hero-pills span{font-size:.78rem}.landing-hero-chip{position:static;width:100%}.landing-hero-visual{gap:var(--landing-space-2)}.landing-hero-actions{width:100%;flex-direction:column}.landing-hero-actions .primary-button,.landing-hero-actions .ghost-button{width:100%}}
