:root{--canvas: oklch(97% .008 80);--canvas-soft: oklch(97% .006 80);--surface: #ffffff;--surface-warm: oklch(98% .012 80);--sb-bg: oklch(14% .025 265);--sb-bg-soft: oklch(19% .022 265);--sb-border: oklch(20% .02 265);--sb-border-soft: oklch(22% .02 265);--sb-input-bg: oklch(19% .022 265);--sb-input-border: oklch(24% .022 265);--sb-text: oklch(80% .02 265);--sb-text-muted: oklch(55% .03 265);--sb-text-faint: oklch(45% .03 265);--text: oklch(18% .02 265);--text-strong: oklch(14% .02 265);--text-muted: oklch(48% .02 265);--text-subtle: oklch(60% .02 265);--border: oklch(90% .01 265);--border-soft: oklch(92% .01 265);--border-strong: oklch(88% .012 265);--accent: oklch(58% .2 270);--accent-hover: oklch(52% .22 270);--accent-strong: oklch(50% .2 270);--accent-soft: oklch(58% .2 270 / .1);--accent-glow: 0 2px 14px oklch(58% .2 270 / .35);--tips-bg: oklch(98% .025 80);--tips-border: oklch(88% .05 70);--tips-icon-bg: oklch(82% .15 70);--tips-icon-color: oklch(45% .15 60);--tips-heading: oklch(35% .08 65);--tips-text: oklch(32% .05 70);--tips-pill-bg: oklch(90% .08 75);--tips-pill-text: oklch(60% .08 70);--tips-bullet-bg: oklch(85% .12 70);--tips-divider: oklch(91% .04 75);--green: oklch(60% .16 150);--red: oklch(58% .22 27);--amber: oklch(65% .18 60);--streak-orange: oklch(65% .18 40);--shadow-card: 0 1px 4px oklch(85% .01 265 / .5);--shadow-card-strong: 0 4px 18px oklch(82% .01 265 / .5);--radius: 12px;--radius-lg: 14px;--radius-sm: 8px;font-family:DM Sans,system-ui,-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--canvas);color:var(--text);font-family:DM Sans,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:oklch(80% .01 265);border-radius:99px}.sidebar ::-webkit-scrollbar-thumb{background:oklch(28% .02 265)}.auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--canvas)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014}.auth-brand{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;margin-bottom:1.5rem;color:var(--accent)}.auth-card h2{margin:0 0 .4rem;font-size:1.4rem}.auth-sub{color:var(--text-muted);font-size:.85rem;margin:0 0 1.5rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;margin-bottom:1rem;color:var(--text-secondary)}.auth-card input{padding:.55rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;background:var(--canvas);color:var(--text-primary);outline:none;transition:border-color .15s}.auth-card input:focus{border-color:var(--accent)}.auth-error{color:#e55;font-size:.85rem;margin:-.5rem 0 .75rem}.auth-submit{width:100%;justify-content:center;margin-top:.5rem}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.settings-section h3{font-size:.95rem;font-weight:600;margin:0 0 .3rem;color:var(--text-primary)}.settings-desc{font-size:.83rem;color:var(--text-muted);margin:0 0 .75rem;line-height:1.5}.settings-desc a{color:var(--accent)}.settings-key-row{display:flex;gap:.5rem;align-items:center}.settings-key-input{flex:1;font-family:monospace;font-size:.85rem}.settings-key-toggle{padding:.45rem .6rem}.settings-key-status{font-size:.82rem;margin:.4rem 0 0}.key-ok{color:#2a9d2a}.key-missing{color:var(--text-muted)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}.settings-row label{font-size:.87rem;color:var(--text-secondary)}.settings-select{width:120px}.settings-footer{display:flex;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.cheatsheet-export-bar{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.6rem .9rem;margin-bottom:1.25rem;background:var(--canvas-soft);border:1px solid var(--border);border-radius:8px}.export-bar-label{font-size:.8rem;color:var(--text-muted);font-weight:500;margin-right:.25rem}.export-bar-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.8rem;font-weight:500;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s}.export-bar-btn:hover{border-color:var(--accent);color:var(--accent)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.sidebar{background:var(--sb-bg);color:var(--sb-text);display:flex;flex-direction:column;transition:width .25s ease,min-width .25s ease;overflow:hidden;flex-shrink:0;border-right:1px solid var(--sb-border-soft);font-family:DM Sans,sans-serif}.sidebar.open{width:264px;min-width:264px}.sidebar.closed{width:0;min-width:0;border-right:none}.sidebar-header{padding:18px 16px 14px;border-bottom:1px solid var(--sb-border)}.sidebar-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}.sidebar-brand-mark{width:28px;height:28px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:14px}.sidebar-title{font-weight:600;font-size:14px;letter-spacing:-.01em;color:var(--sb-text)}.sidebar-toggle{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--sb-text-muted);padding:4px 6px;border-radius:6px;font-size:12px;transition:color .15s,background .15s}.sidebar-toggle:hover{color:var(--sb-text);background:oklch(20% .02 265)}.btn-new{width:100%;padding:9px 12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity .15s,box-shadow .15s;box-shadow:var(--accent-glow)}.btn-new:hover{opacity:.9}.sidebar-stats{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--sb-border)}.stat-pill{flex:1;background:var(--sb-bg-soft);border:none;border-radius:var(--radius-sm);padding:9px 11px;cursor:pointer;display:flex;flex-direction:column;gap:3px;text-align:left;font-family:inherit;transition:background .15s,opacity .15s}.stat-pill:hover:not(:disabled){background:oklch(22% .022 265)}.stat-pill:disabled{opacity:.5;cursor:default}.stat-pill.active{background:oklch(58% .2 270 / .18)}.stat-num{font-weight:700;font-size:17px;color:oklch(75% .18 270);font-feature-settings:"tnum"}.stat-pill.due .stat-num{color:var(--streak-orange)}.stat-label{font-size:10px;font-weight:500;letter-spacing:.06em;color:var(--sb-text-faint);text-transform:uppercase}.sidebar-search{padding:10px 16px;border-bottom:1px solid var(--sb-border)}.search-input{width:100%;padding:7px 10px 7px 30px;background:var(--sb-input-bg);border:1px solid var(--sb-input-border);border-radius:var(--radius-sm);color:var(--sb-text);font-family:inherit;font-size:13px;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23808a9c' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' width='13' height='13'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:9px center}.search-input::placeholder{color:var(--sb-text-faint)}.search-input:focus{border-color:var(--accent)}.sidebar-scroll{flex:1;overflow-y:auto;padding:8px}.nb-section{margin-bottom:2px}.nb-header{display:flex;align-items:center;position:relative}.nb-title{flex:1;background:none;border:none;cursor:pointer;padding:7px 8px;text-align:left;display:flex;align-items:center;gap:6px;font-family:inherit;font-size:13px;font-weight:500;color:var(--sb-text);border-radius:6px;transition:background .15s}.nb-title:hover{background:oklch(20% .02 265)}.nb-arrow{display:inline-flex;align-items:center;width:12px;opacity:.6;font-size:9px;transition:transform .2s}.nb-emoji{font-size:13px}.nb-name{flex:1}.nb-count{font-size:10px;background:oklch(22% .02 265);color:var(--sb-text-muted);padding:1px 7px;border-radius:99px}.nb-menu-btn{background:none;border:none;color:var(--sb-text-faint);cursor:pointer;padding:4px 8px;font-size:14px}.nb-menu-btn:hover{color:var(--sb-text)}.nb-menu{position:absolute;top:100%;right:0;background:oklch(20% .02 265);border:1px solid oklch(28% .02 265);border-radius:8px;box-shadow:0 8px 28px #00000080;padding:4px;z-index:50;min-width:180px}.nb-menu button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--sb-text);padding:7px 10px;cursor:pointer;font-size:12px;font-family:inherit;border-radius:5px}.nb-menu button:hover{background:oklch(26% .025 265)}.nb-menu hr{border:none;border-top:1px solid oklch(28% .02 265);margin:4px 0}.nb-notes{padding:2px 0 4px}.nb-empty{padding:4px 8px 4px 32px;font-size:11px;color:var(--sb-text-faint)}.saved-note-item{position:relative;padding:7px 22px 7px 28px;margin:0 4px 1px;border-radius:0 6px 6px 0;border-left:2px solid transparent;cursor:pointer;transition:background .15s,border-color .15s}.saved-note-item:hover{background:oklch(20% .02 265)}.saved-note-item.active{background:oklch(58% .2 270 / .15);border-left-color:var(--accent)}.saved-note-title{font-size:12px;font-weight:500;color:var(--sb-text);line-height:1.35}.saved-note-item.active .saved-note-title{color:oklch(75% .12 270)}.saved-note-meta{font-size:11px;color:var(--sb-text-faint);margin-top:2px}.saved-note-actions{position:absolute;top:6px;right:4px;display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .15s}.saved-note-item:hover .saved-note-actions{opacity:1}.saved-note-delete,.saved-note-tab-btn{background:none;border:none;color:var(--sb-text-faint);cursor:pointer;font-size:11px;padding:2px 3px;border-radius:3px;transition:color .15s,background .15s}.saved-note-delete:hover{color:var(--red)}.saved-note-tab-btn:hover{color:var(--accent);background:oklch(58% .2 270 / .12)}.note-tab-badge{color:var(--accent);opacity:.7;font-style:italic}.nb-tab-strip{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:4px 8px 2px;border-bottom:1px solid oklch(25% .02 265)}.nb-tab-wrap{position:relative;display:flex;align-items:center}.nb-tab{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px 5px 0 0;font-size:11px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;color:var(--sb-text-faint);cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.nb-tab:hover{color:var(--sb-text);background:oklch(20% .02 265)}.nb-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.nb-tab-count{font-size:10px;background:oklch(25% .02 265);border-radius:8px;padding:0 4px;min-width:14px;text-align:center}.nb-tab.active .nb-tab-count{background:oklch(58% .2 270 / .2);color:var(--accent)}.nb-tab-del{font-size:10px;background:none;border:none;cursor:pointer;color:var(--sb-text-faint);padding:0 2px;margin-left:-2px;opacity:0;transition:opacity .15s,color .15s}.nb-tab-wrap:hover .nb-tab-del{opacity:1}.nb-tab-del:hover{color:var(--red)}.nb-tab-add{font-size:13px;line-height:1;background:none;border:none;color:var(--sb-text-faint);cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.nb-tab-add:hover{color:var(--accent);background:oklch(20% .02 265)}.nb-tab-new-form,.nb-tab-rename-form{display:inline-flex}.nb-tab-new-input,.nb-tab-rename-input{width:90px;padding:2px 6px;font-size:11px;background:oklch(18% .02 265);border:1px solid var(--accent);border-radius:4px;color:var(--sb-text);outline:none}.note-tab-picker-wrap{position:relative}.note-tab-popover{position:absolute;right:0;top:20px;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:140px;padding:4px 0;overflow:hidden}.note-tab-popover-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:6px 12px 4px}.note-tab-option{display:block;width:100%;text-align:left;padding:6px 12px;font-size:12px;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:background .1s}.note-tab-option:hover{background:var(--canvas-soft)}.note-tab-option.active{color:var(--accent);font-weight:600}.index-intro{max-width:680px}.index-intro p{margin-bottom:.9rem;line-height:1.6}.index-intro-tip{background:oklch(97% .015 80);border:1px solid oklch(88% .04 80);border-radius:8px;padding:.7rem 1rem;font-size:.87rem}.index-view{padding-bottom:3rem}.index-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.index-section-tabs{display:flex;flex-wrap:wrap;gap:.25rem;flex:1}.index-section-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.82rem;font-weight:500;background:none;border:1px solid var(--border);border-bottom:2px solid transparent;border-radius:5px 5px 0 0;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.index-section-tab:hover{color:var(--text-primary);border-color:var(--border)}.index-section-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:oklch(98% .01 270)}.index-tab-count{font-size:.75rem;background:var(--canvas-soft);border-radius:8px;padding:0 5px}.index-search{width:240px;font-size:.85rem;padding:.4rem .7rem}.index-section{margin-bottom:2rem}.index-section-header{display:flex;align-items:center;gap:.6rem;border-left:4px solid;padding-left:.6rem;margin-bottom:.6rem}.index-section-header h2{font-size:1rem;font-weight:700}.index-section-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.index-section-count{font-size:.8rem;color:var(--text-muted);margin-left:auto}.index-table{width:100%;border-collapse:collapse;font-size:.83rem}.index-table th{text-align:left;padding:.35rem .6rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--canvas-soft);border-bottom:1px solid var(--border);white-space:nowrap}.index-table td{padding:.3rem .6rem;vertical-align:top;border-bottom:1px solid var(--border)}.index-table .row-even td{background:oklch(99% .003 80)}.index-table .col-keyword{width:22%}.index-table .col-topic{width:18%;font-weight:600}.index-table .col-source{width:16%;color:var(--text-muted);font-style:italic;font-size:.78rem}.index-table .col-notes{width:44%}.index-table .col-notes strong{color:#c0392b}.keyword-part{color:var(--text-muted);font-size:.8rem}.keyword-sep{color:var(--border);font-size:.8rem}.keyword-last{color:var(--text-primary);font-weight:500}.page-head-actions{display:flex;gap:.5rem}.sidebar-add-nb{display:flex;width:calc(100% - 8px);align-items:center;justify-content:center;gap:6px;margin:8px 4px;padding:7px 8px;background:none;border:1px dashed oklch(25% .02 265);border-radius:6px;color:var(--sb-text-muted);cursor:pointer;font-family:inherit;font-size:12px;transition:all .15s}.sidebar-add-nb:hover{border-color:oklch(58% .2 270 / .5);color:oklch(70% .16 270)}.sidebar-footer{padding:10px 16px;border-top:1px solid var(--sb-border);font-size:11px;color:var(--sb-text-faint)}.search-results{padding:4px}.search-result{padding:8px 10px;border-radius:6px;margin-bottom:4px;cursor:pointer;background:oklch(19% .022 265);border-left:2px solid transparent;transition:border-color .15s,background .15s}.search-result:hover{background:oklch(22% .022 265);border-left-color:var(--accent)}.search-title{font-size:12px;font-weight:600;color:var(--sb-text);margin-bottom:4px}.search-snippet{font-size:10px;color:var(--sb-text-muted);line-height:1.4;margin-top:2px}.search-field{display:inline-block;background:oklch(58% .2 270 / .2);color:oklch(75% .12 270);border-radius:3px;padding:0 5px;margin-right:4px;font-size:9px;text-transform:uppercase}.empty-state{font-size:12px;color:var(--sb-text-faint);padding:16px 12px;text-align:center}.app-header{height:52px;display:flex;align-items:center;padding:0 20px;gap:14px;background:var(--surface);border-bottom:1px solid var(--border-soft);flex-shrink:0;z-index:10}.brand{display:flex;align-items:center;gap:9px;margin-right:auto}.brand-mark{width:26px;height:26px;border-radius:7px;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--accent-glow)}.brand-name{font-weight:700;font-size:15px;letter-spacing:-.02em;color:var(--text-strong)}.brand-name .brand-accent{color:var(--accent)}.header-burger{background:none;border:none;color:var(--text-muted);padding:5px 6px;border-radius:6px;cursor:pointer;display:flex;align-items:center;transition:background .15s}.header-burger:hover{background:oklch(94% .01 265)}.header-nav{display:flex;gap:4px}.nav-btn{background:none;border:none;cursor:pointer;padding:6px 12px;border-radius:7px;font-family:inherit;font-size:13px;font-weight:500;color:var(--text-muted);transition:all .15s}.nav-btn.active{color:var(--accent-strong);background:var(--accent-soft)}.nav-btn:hover:not(.active){background:oklch(94% .01 265);color:var(--text)}.nav-settings-btn{display:flex;align-items:center;gap:5px}.main-shell{display:flex;flex:1;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--canvas-soft)}.content-area{flex:1;overflow-y:auto;padding:36px 48px;position:relative}.content-wrap{max-width:760px;margin:0 auto}.page-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.page-head h1{flex:1;font-family:Lora,serif;font-size:24px;font-weight:600;letter-spacing:-.01em;color:var(--text-strong)}.muted{color:var(--text-muted);font-size:13px}.row-gap{display:flex;gap:6px}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:oklch(97% .008 80 / .85);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-spinner{width:42px;height:42px;border:3px solid var(--border-soft);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-msg{margin-top:14px;color:var(--text-muted);font-size:14px}.input-view{max-width:760px;margin:0 auto}.welcome{text-align:center;margin-bottom:32px}.welcome h1{font-family:Lora,serif;font-size:30px;font-weight:600;letter-spacing:-.02em;color:var(--text-strong);margin-bottom:12px}.welcome p{color:var(--text-muted);font-size:15px;line-height:1.6;max-width:600px;margin:0 auto}.input-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border);overflow:hidden}.no-key-banner{display:flex;gap:14px;align-items:flex-start;padding:18px 20px;background:oklch(97% .015 265);border-bottom:1px solid oklch(86% .05 265)}.no-key-icon{font-size:22px;flex-shrink:0;margin-top:1px}.no-key-body{display:flex;flex-direction:column;gap:4px;font-size:13.5px;color:var(--text-secondary)}.no-key-body strong{font-size:14px;font-weight:600;color:var(--text)}.no-key-links{display:flex;align-items:center;gap:16px;margin-top:6px;flex-wrap:wrap}.no-key-cta{font-size:13px;padding:6px 14px}.no-key-get-key{font-size:13px;color:var(--accent);text-decoration:none}.no-key-get-key:hover{text-decoration:underline}.tab-bar{display:flex;border-bottom:1px solid var(--border-soft);background:oklch(98% .005 80)}.tab-bar.wrap{flex-wrap:wrap}.tab-btn{flex:1;min-width:110px;padding:11px 8px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab-btn.active{color:var(--accent-strong);border-bottom-color:var(--accent);background:var(--surface)}.tab-btn:hover:not(.active){background:oklch(96% .005 80);color:var(--text)}.tab-content{padding:22px;background:var(--surface)}.input-form{display:flex;flex-direction:column;gap:12px}.input-label{font-size:13px;font-weight:600;color:var(--text)}.input-label.small{font-size:12px}.url-row{display:flex;gap:10px}.text-input{width:100%;padding:10px 14px;background:var(--canvas);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:14px;outline:none;transition:border-color .15s,background .15s}.text-input:focus{border-color:var(--accent);background:var(--surface)}.text-input.small{padding:6px 8px;font-size:12px}.textarea{resize:vertical;min-height:140px;font-family:inherit}.textarea.code{font-family:SF Mono,Consolas,monospace;font-size:13px}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;cursor:pointer;font-size:14px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:8px;background:oklch(98% .005 80);transition:border-color .15s,background .15s}.drop-zone:hover{border-color:var(--accent);background:oklch(99% .012 280)}.drop-icon{font-size:28px}.file-name{font-weight:600;color:var(--text)}.hint{font-size:12px;color:var(--text-muted)}.img-preview{max-width:100%;max-height:220px;border-radius:8px}.page-range-row{display:flex;align-items:center;gap:10px}.page-range-row .text-input{width:80px}.source-row{display:grid;grid-template-columns:110px 160px 1fr auto;gap:8px;align-items:start}.source-row .textarea{min-height:80px}.error-box{padding:12px 16px;background:oklch(97% .04 25);border:1px solid oklch(85% .08 25);border-radius:var(--radius-sm);font-size:13px;color:oklch(45% .18 25)}.btn-primary{padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:9px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:7px;transition:background .15s,opacity .15s,box-shadow .15s;white-space:nowrap;box-shadow:var(--accent-glow)}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-primary.small{padding:6px 14px;font-size:12px}.btn-secondary{padding:8px 14px;background:oklch(95% .008 80);color:var(--text-muted);border:1px solid var(--border-strong);border-radius:9px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:7px;transition:all .15s}.btn-secondary:hover{background:oklch(92% .01 265);color:var(--text-strong)}.btn-secondary.small{padding:5px 10px;font-size:12px}.btn-ghost{background:none;border:none;cursor:pointer;color:var(--accent);font-family:inherit;font-size:13px;padding:6px 0;transition:opacity .15s}.btn-ghost:hover{opacity:.75}.btn-ghost.small{font-size:12px}.btn-danger{padding:8px 14px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600}.btn-danger:hover{filter:brightness(.9)}.btn-danger-ghost{padding:8px 12px;background:none;color:var(--red);border:1px solid oklch(85% .08 25);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:13px}.btn-danger-ghost:hover{background:oklch(97% .04 25)}.refine-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:13px;color:var(--text-muted);transition:all .15s}.refine-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.notes-display{max-width:760px;margin:0 auto}.notes-header{margin-bottom:28px}.notes-tag-row{margin-bottom:14px;display:flex;gap:6px;flex-wrap:wrap}.notebook-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:99px;background:var(--accent-soft);color:var(--accent-strong);border:1px solid oklch(58% .2 270 / .2)}.notebook-tag.warn{background:oklch(96% .04 70);color:oklch(45% .16 60);border-color:oklch(85% .08 65)}.notes-title{font-family:Lora,serif;font-size:26px;font-weight:600;line-height:1.25;color:var(--text-strong);letter-spacing:-.02em;margin-bottom:14px}.notes-summary{font-size:14px;line-height:1.7;color:var(--text-muted);margin-bottom:24px}.notes-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:28px}.notes-actions .spacer{flex:1}.notes-sections{display:flex;flex-direction:column;gap:12px}.notes-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.section-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:14px 18px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s}.section-toggle:hover{background:oklch(98% .005 80)}.section-toggle .heading{font-size:14px;font-weight:600;color:var(--accent-strong);flex:1}.section-toggle .chev{color:var(--text-subtle);font-size:12px;transition:transform .2s}.section-toggle.open .chev{transform:rotate(90deg)}.section-body{padding:4px 18px 18px;border-top:1px solid var(--border-soft)}.section-content{font-size:13.5px;line-height:1.7;color:oklch(35% .02 265);white-space:pre-wrap}.key-points{margin-top:12px;list-style:none;display:flex;flex-direction:column;gap:6px}.key-points li{font-size:13px;color:var(--text);padding-left:18px;position:relative;line-height:1.55}.key-points li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.accuracy-warnings{background:oklch(98% .012 60);border:1px solid oklch(85% .06 55);border-left:4px solid oklch(68% .16 50);border-radius:var(--radius-lg);padding:14px 18px 14px 16px}.accuracy-warnings-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.accuracy-icon{width:28px;height:28px;border-radius:8px;background:oklch(90% .12 55);color:oklch(48% .18 45);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700}.accuracy-title{font-size:13px;font-weight:600;color:oklch(42% .12 45)}.accuracy-list{margin:0;padding:0 0 0 20px;display:flex;flex-direction:column;gap:6px}.accuracy-item{font-size:13px;color:oklch(38% .1 45);line-height:1.5}.exam-tips{background:var(--tips-bg);border:1px solid var(--tips-border);border-radius:var(--radius-lg);overflow:hidden}.exam-tips .section-toggle .heading{color:var(--tips-heading)}.exam-tips-icon{width:28px;height:28px;border-radius:8px;background:var(--tips-icon-bg);color:var(--tips-icon-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700}.exam-tips-pill{font-size:11px;background:var(--tips-pill-bg);color:var(--tips-pill-text);padding:2px 9px;border-radius:99px}.exam-tips-list{padding:4px 18px 14px}.exam-tip{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--tips-divider)}.exam-tip:last-child{border-bottom:none}.exam-tip-mark{width:20px;height:20px;border-radius:6px;background:var(--tips-bullet-bg);color:var(--tips-icon-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:12px;font-weight:700}.exam-tip-text{font-size:13.5px;line-height:1.6;color:var(--tips-text)}.definitions-grid{display:flex;flex-direction:column;gap:8px;margin-top:4px}.definition-card{display:flex;gap:12px;background:var(--canvas);border-radius:8px;padding:10px 14px}.def-term{font-weight:700;font-size:13px;color:var(--accent-strong);white-space:nowrap;min-width:120px}.def-text{font-size:13px;color:var(--text);line-height:1.55}.section-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.flashcard-preview-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mastery-progress{margin-top:8px;padding:14px 20px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}.mastery-row{display:flex;justify-content:space-between;margin-bottom:6px}.mastery-label{font-size:12px;color:var(--text-muted);font-weight:500}.mastery-value{font-size:12px;color:var(--accent-strong);font-weight:600;font-feature-settings:"tnum"}.mastery-bar{height:5px;background:oklch(92% .01 265);border-radius:99px;overflow:hidden}.mastery-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .3s ease}.diagram-block{margin-top:16px}.diagram-caption{font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-muted)}.diagram-svg{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;overflow-x:auto}.diagram-svg svg{max-width:100%;height:auto}.diagram-error{background:oklch(97% .04 25);border:1px solid oklch(85% .08 25);padding:10px;border-radius:6px;font-size:12px;color:oklch(45% .18 25)}.diagram-actions{display:flex;gap:6px;margin-top:6px}.diagram-edit{margin-top:8px}.refine-presets{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.preset-btn{flex:1;min-width:110px;padding:10px;background:var(--canvas);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.preset-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.refine-diff{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-height:50vh;overflow-y:auto;margin-bottom:12px}.refine-col{padding:14px;background:var(--canvas);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px}.refine-col.refined{background:oklch(98% .04 280);border-color:oklch(80% .12 270)}.refine-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.refine-col h5{font-size:14px;margin-bottom:6px;font-family:Lora,serif}.refine-col p{line-height:1.6}.refine-col ul{margin-top:8px;padding-left:20px}.refine-col li{font-size:12px;line-height:1.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:oklch(14% .025 265 / .55);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 20px 60px oklch(14% .025 265 / .4)}.modal-card.wide{max-width:820px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:16px;font-weight:600;font-family:Lora,serif}.modal-close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--text-muted);padding:4px 8px}.modal-close:hover{color:var(--text)}.modal-body{padding:20px;overflow-y:auto}.modal-form{display:flex;flex-direction:column;gap:12px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}.modal-spacer{flex:1}.modal-para{font-size:14px;line-height:1.55;margin-bottom:12px}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px}.emoji-btn{background:var(--canvas);border:2px solid transparent;cursor:pointer;padding:6px;border-radius:8px;font-size:18px}.emoji-btn.active{border-color:var(--accent);background:var(--accent-soft)}.color-grid{display:flex;gap:6px;flex-wrap:wrap}.color-swatch{width:26px;height:26px;border:2px solid var(--surface);border-radius:50%;cursor:pointer;box-shadow:0 0 0 1px var(--border)}.color-swatch.active{box-shadow:0 0 0 2px var(--accent)}.picker-list{display:flex;flex-direction:column;gap:6px}.picker-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--canvas);border:1px solid var(--border);border-left:4px solid oklch(70% .02 265);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;text-align:left;transition:background .15s,border-color .15s}.picker-item:hover{background:oklch(96% .01 265)}.picker-item.picker-unfiled{border-left-color:oklch(70% .02 265)}.picker-item.picker-new{border-left-color:var(--accent);color:var(--accent);border-style:dashed}.export-list{display:flex;flex-direction:column;gap:8px}.export-list hr{border:none;border-top:1px solid var(--border);margin:8px 0 4px}.export-btn{display:flex;align-items:center;gap:12px;padding:12px;background:var(--canvas);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-family:inherit;transition:background .15s,border-color .15s}.export-btn:hover{background:oklch(96% .01 265);border-color:var(--accent)}.export-icon{font-size:22px;flex-shrink:0}.export-btn span:nth-child(2){display:flex;flex-direction:column;gap:2px;flex:1}.export-btn strong{font-size:13px;font-weight:600}.export-btn .muted{font-size:11px}.study-screen{min-height:60vh;display:flex;align-items:center;justify-content:center}.study-card-wrap{width:100%;max-width:720px}.study-card-wrap h2{margin-bottom:8px;font-family:Lora,serif;font-size:24px;font-weight:600}.study-card-wrap>p{margin-bottom:16px}.study-progress{display:flex;justify-content:space-between;margin-bottom:16px;font-size:13px}.study-exit{margin-top:16px}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}.srs-rating-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}.srs-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px;border:2px solid;border-radius:10px;cursor:pointer;font-family:inherit;background:var(--surface);transition:transform .1s,background .15s}.srs-btn span{font-weight:600;font-size:14px}.srs-btn small{font-size:11px;color:var(--text-muted)}.srs-btn:hover{transform:translateY(-1px)}.srs-btn.again{border-color:oklch(85% .08 25);color:var(--red)}.srs-btn.hard{border-color:oklch(85% .1 60);color:oklch(45% .16 60)}.srs-btn.good{border-color:oklch(85% .1 150);color:var(--green)}.srs-btn.easy{border-color:oklch(82% .1 240);color:oklch(45% .18 240)}.quiz-question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-card)}.quiz-q{font-size:18px;font-weight:500;margin-top:8px;line-height:1.5;font-family:Lora,serif}.quiz-feedback{margin-top:16px;padding:16px;border-radius:10px;border:1px solid}.quiz-feedback.correct{border-color:oklch(85% .1 150);background:oklch(98% .04 150)}.quiz-feedback.partial{border-color:oklch(85% .1 60);background:oklch(98% .04 70)}.quiz-feedback.incorrect{border-color:oklch(85% .08 25);background:oklch(98% .04 25)}.qf-result{font-weight:700;font-size:16px;margin-bottom:6px}.qf-explain{margin-bottom:8px;line-height:1.55;font-size:14px}.qf-missing ul{padding-left:20px;margin:4px 0}.qf-missing li{font-size:13px}.qf-expected{background:var(--surface);padding:10px;border-radius:6px;margin:10px 0;font-size:13px}.quiz-summary{display:flex;gap:12px;margin-bottom:18px}.qs{padding:8px 14px;border-radius:99px;font-weight:600;font-size:13px}.qs.correct{background:oklch(95% .05 150);color:var(--green)}.qs.partial{background:oklch(96% .06 70);color:oklch(45% .16 60)}.qs.incorrect{background:oklch(96% .04 25);color:var(--red)}.quiz-review{display:flex;flex-direction:column;gap:10px}.quiz-review-item{padding:12px;border-radius:var(--radius-sm);font-size:13px;border:1px solid}.quiz-review-item.correct{background:oklch(98% .04 150);border-color:oklch(85% .1 150)}.quiz-review-item.partial{background:oklch(98% .04 70);border-color:oklch(85% .1 60)}.quiz-review-item.incorrect{background:oklch(98% .04 25);border-color:oklch(85% .08 25)}.qr-q{font-weight:600;margin-bottom:6px}.qr-your,.qr-expected,.qr-explain{margin-top:4px;line-height:1.55}.exam-shell{max-width:880px;margin:0 auto}.exam-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.exam-bar-left{display:flex;align-items:center;gap:12px;font-size:13px}.exam-bar-right{display:flex;align-items:center;gap:12px;justify-content:flex-end}.exam-timer{font-family:SF Mono,monospace;font-size:22px;font-weight:700;padding:4px 12px;border-radius:6px;background:var(--canvas);font-feature-settings:"tnum"}.exam-timer.urgent{background:oklch(97% .04 25);color:var(--red);animation:pulse 1s infinite}.exam-question{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-card)}.exam-q-num{font-size:11px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:8px}.exam-q-text{font-family:Lora,serif;font-size:18px;font-weight:500;line-height:1.5;margin-bottom:18px}.exam-options{display:flex;flex-direction:column;gap:8px}.exam-option{display:flex;align-items:flex-start;gap:12px;padding:12px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;line-height:1.5;transition:all .15s}.exam-option:hover,.exam-option.selected{border-color:var(--accent);background:var(--accent-soft)}.exam-option input{margin-top:4px}.exam-opt-letter{font-weight:700;color:var(--accent-strong);flex-shrink:0}.exam-nav{display:flex;align-items:center;gap:12px}.exam-jump{display:flex;gap:4px;flex-wrap:wrap;flex:1;justify-content:center}.exam-dot{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit}.exam-dot.answered{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-strong)}.exam-dot.current{background:var(--accent);color:#fff;border-color:var(--accent)}.exam-results{max-width:880px;margin:0 auto}.exam-results-head{text-align:center;margin-bottom:24px}.exam-score{font-size:64px;font-weight:800;line-height:1;margin:12px 0;font-family:Lora,serif}.exam-score.pass{color:var(--green)}.exam-score.fail{color:var(--red)}.exam-meta{color:var(--text-muted);font-size:14px}.exam-question-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.exam-q-result{padding:14px 16px;border:1px solid;border-radius:var(--radius-sm);background:var(--surface)}.exam-q-result.correct{border-color:oklch(85% .1 150)}.exam-q-result.wrong{border-color:oklch(85% .08 25)}.qr-head{font-weight:600;margin-bottom:8px;font-size:13px}.qr-q{font-weight:500;margin-bottom:10px;line-height:1.55;font-family:Lora,serif}.qr-options{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.qr-opt{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;font-size:13px;line-height:1.4}.qr-opt.correct{background:oklch(98% .04 150)}.qr-opt.wrong{background:oklch(98% .04 25)}.qr-letter{font-weight:700;color:var(--text-muted)}.qr-badge{margin-left:auto;padding:2px 8px;background:var(--green);color:#fff;border-radius:99px;font-size:10px;text-transform:uppercase}.qr-badge.wrong{background:var(--red)}.qr-explain{font-size:13px;line-height:1.55;color:var(--text-muted);padding-top:8px;border-top:1px solid var(--border)}.dashboard{max-width:1000px;margin:0 auto}.dashboard h1{font-family:Lora,serif;font-size:28px;font-weight:600;letter-spacing:-.01em;margin-bottom:24px}.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px}.dash-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-card)}.dash-stat-label{font-size:11px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.06em}.dash-stat-value{font-size:30px;font-weight:700;margin:4px 0;color:var(--accent);font-family:Lora,serif;font-feature-settings:"tnum"}.dash-stat-sub{font-size:12px;color:var(--text-muted)}.dash-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-card)}.dash-section h2{font-family:Lora,serif;font-size:16px;font-weight:600;margin-bottom:14px}.dash-twocol{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 720px){.dash-twocol{grid-template-columns:1fr}}.activity-bars{display:flex;align-items:flex-end;gap:3px;height:80px;margin-bottom:6px}.activity-bar{flex:1;height:100%;background:oklch(95% .005 80);border-radius:3px;display:flex;align-items:flex-end;overflow:hidden}.activity-fill{width:100%;background:linear-gradient(180deg,var(--accent),var(--accent-hover));border-radius:3px;min-height:1px}.activity-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.weak-row{padding:8px 0;border-bottom:1px solid var(--border-soft);font-size:13px}.weak-row:last-child{border-bottom:none}.weak-q{font-weight:500;line-height:1.4}.weak-meta{font-size:11px;margin-top:2px}.exam-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-soft);font-size:13px}.exam-row:last-child{border-bottom:none}.exam-row-title{font-weight:600}.exam-row-meta{font-size:11px}.exam-row-score{font-weight:700;font-size:17px;font-family:Lora,serif;font-feature-settings:"tnum"}.exam-row-score.pass{color:var(--green)}.exam-row-score.fail{color:var(--red)}.compare-pick-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;margin-bottom:16px}.compare-pick{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;cursor:pointer;font-size:13px}.compare-pick:hover{background:var(--canvas)}.compare-pick.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.compare-table{width:100%;border-collapse:collapse;margin-top:8px}.compare-table th,.compare-table td{padding:10px 12px;border:1px solid var(--border);text-align:left;font-size:13px;line-height:1.55;vertical-align:top}.compare-table th{background:var(--canvas);font-weight:700}.compare-dim{font-weight:600;color:var(--accent-strong)}.cheatsheet .notes-section{padding:14px 18px}.coverage-summary{display:flex;align-items:center;gap:24px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;box-shadow:var(--shadow-card)}.coverage-pct{font-size:48px;font-weight:700;font-family:Lora,serif;color:var(--accent)}.coverage-actions{margin-left:auto;display:flex;gap:8px}.objective-list{display:flex;flex-direction:column;gap:8px}.objective-row{display:flex;gap:10px;padding:12px;border-left:3px solid;background:var(--canvas);border-radius:0 8px 8px 0}.objective-row.covered{border-left-color:var(--green)}.objective-row.uncovered{border-left-color:oklch(70% .02 265);opacity:.85}.obj-status{font-size:16px;flex-shrink:0}.obj-content{flex:1}.obj-label{font-weight:500;font-size:13px;line-height:1.55}.obj-notes{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.obj-note-pill{background:var(--surface);border:1px solid var(--border);font-size:11px;padding:2px 8px;border-radius:99px}.flashcard-viewer{max-width:680px;margin:0 auto}.fc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.fc-header h2{font-family:Lora,serif;font-size:20px;font-weight:600;flex:1;text-align:center;margin:0 12px}.fc-counter{font-size:14px;color:var(--text-muted);white-space:nowrap}.fc-progress-bar{height:4px;background:var(--border-soft);border-radius:2px;margin-bottom:28px;overflow:hidden}.fc-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.fc-card{perspective:1000px;cursor:pointer;height:260px;margin-bottom:24px}.fc-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .4s ease}.fc-card.flipped .fc-card-inner{transform:rotateY(180deg)}.fc-front,.fc-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card-strong);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center}.fc-back{transform:rotateY(180deg);background:oklch(98% .012 280)}.fc-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px}.fc-text{font-family:Lora,serif;font-size:18px;line-height:1.6;color:var(--text);font-weight:500}.fc-hint{font-size:12px;color:var(--text-muted);margin-top:16px}.fc-actions{display:flex;gap:16px}.btn-incorrect,.btn-correct{flex:1;padding:12px;border:2px solid;border-radius:10px;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;transition:transform .1s,filter .15s}.btn-incorrect{background:oklch(98% .04 25);color:var(--red);border-color:oklch(85% .08 25)}.btn-correct{background:oklch(98% .04 150);color:var(--green);border-color:oklch(85% .1 150)}.btn-incorrect:hover,.btn-correct:hover{filter:brightness(.95);transform:scale(.99)}.fc-tap-hint{text-align:center;color:var(--text-muted);font-size:13px;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.fc-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;text-align:center;box-shadow:var(--shadow-card-strong)}.results-score{font-size:72px;font-weight:700;line-height:1;font-family:Lora,serif}.results-label{font-size:18px;color:var(--text-muted);margin:8px 0}.results-message{font-size:15px;margin-bottom:28px}.results-breakdown{text-align:left;max-height:300px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;margin-bottom:24px;display:flex;flex-direction:column;gap:6px}.result-item{display:flex;align-items:flex-start;gap:10px;padding:8px;border-radius:6px;font-size:13px}.result-item.correct{background:oklch(98% .04 150)}.result-item.incorrect{background:oklch(98% .04 25)}.result-icon{flex-shrink:0}.result-q{color:var(--text);line-height:1.4}.results-actions{display:flex;gap:12px;justify-content:center}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100%;z-index:200}.sidebar.open{width:280px;min-width:280px}.sidebar.closed{width:0;min-width:0}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:oklch(14% .025 265 / .5);z-index:199;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.app-header{padding:0 12px;gap:8px}.brand-name{font-size:14px}.header-nav .nav-btn:not(.nav-settings-btn){font-size:0;padding:8px 10px}.nav-settings-btn svg{display:block}.nav-settings-btn{font-size:0;padding:8px 10px;gap:0}.content-area{padding:20px 16px}.welcome h1{font-size:22px}.welcome p{font-size:14px}.tab-content{padding:16px}.url-row{flex-direction:column}.url-row .btn-primary{width:100%;justify-content:center}.page-range-row{flex-wrap:wrap}.page-range-row .text-input{width:70px}.source-row{grid-template-columns:1fr}.source-row select{width:100%}.notes-title{font-size:22px}.notes-actions{gap:6px}.notes-actions .spacer{display:none}.notes-actions .btn-primary,.notes-actions .btn-secondary{flex:1;justify-content:center;min-height:44px}.btn-primary,.btn-secondary,.btn-ghost{min-height:44px}.tab-btn{min-height:44px;padding:10px 14px}.section-toggle{min-height:52px;padding:14px 16px}.nav-btn{min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.modal-overlay{padding:0;align-items:flex-end;z-index:300}.modal-card{max-width:100%;width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh}.modal-card.wide{max-width:100%}.no-key-banner{flex-direction:column;gap:10px}.no-key-links{flex-direction:column;align-items:flex-start;gap:10px}.no-key-cta{width:100%;justify-content:center}.accuracy-warnings{padding:12px 14px}.fc-card{height:220px}.fc-front,.fc-back{padding:20px}.fc-nav{gap:8px}.fc-nav .btn-secondary{flex:1;justify-content:center}.dashboard{padding:0}.settings-key-row{flex-wrap:wrap}.settings-key-input{min-width:0}}@media (max-width: 400px){.content-area{padding:14px 12px}.tab-content{padding:12px}.notes-title{font-size:20px}.brand-name{display:none}}.sidebar-backdrop,.print-only{display:none}@media print{body,.app-layout,.main-content,.content-area{background:white!important;height:auto!important;overflow:visible!important}.sidebar,.app-header,.no-print,.notes-actions,.header-nav,.nav-btn,.btn-primary,.btn-secondary,.btn-ghost,.btn-new,.refine-btn,.modal-overlay,.header-burger{display:none!important}.main-content{width:100%}.content-area{padding:0!important;overflow:visible!important}.notes-display,.content-wrap,.dashboard,.exam-results{max-width:100%!important}.notes-section,.exam-tips{box-shadow:none!important;border:1px solid #ddd!important;page-break-inside:avoid}.section-toggle .heading{page-break-after:avoid}.section-body{display:block!important}.print-only{display:block}.card-print-list{margin-top:12px;column-count:2;column-gap:16px}.card-print-item{break-inside:avoid;margin-bottom:10px;padding:8px;border:1px solid #ddd;font-size:11px;line-height:1.4}.notebook-tag{background:white!important;border:1px solid #ddd;color:#000!important}}
