@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg0: #060810;--bg1: #0A0D1A;--bg2: #0D1120;--bg3: #111828;--panel: rgba(255,255,255,.042);--panel-hover: rgba(255,255,255,.072);--brd: rgba(255,255,255,.09);--brd-hover: rgba(255,255,255,.18);--cyan: #22D3EE;--purple:#7C3AED;--blue: #3B82F6;--green: #10B981;--amber: #F59E0B;--pink: #EC4899;--red: #EF4444;--txt: #E4EAF4;--txt2: #C2CDE0;--muted: #7A8BA8;--muted2:#4B5E78;--radius: 14px;--radius-lg: 20px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-lg: 0 12px 48px rgba(0,0,0,.65);--glow-cyan: 0 0 20px rgba(34,211,238,.18);--glow-purple: 0 0 20px rgba(124,58,237,.22)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;color:var(--txt);background:radial-gradient(ellipse 1200px 600px at -5% -10%,rgba(124,58,237,.18) 0%,transparent 60%),radial-gradient(ellipse 900px 500px at 110% 5%,rgba(34,211,238,.13) 0%,transparent 55%),radial-gradient(ellipse 700px 400px at 50% 100%,rgba(59,130,246,.1) 0%,transparent 50%),linear-gradient(175deg,var(--bg0) 0%,var(--bg1) 40%,var(--bg2) 100%);background-attachment:fixed;min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5{font-family:Space Grotesk,sans-serif;line-height:1.2}p{line-height:1.6}a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}code,.mono{font-family:JetBrains Mono,monospace;font-size:.88em}.layout{display:flex;min-height:100vh}.side{width:240px;flex:0 0 240px;padding:20px 14px;border-right:1px solid var(--brd);background:linear-gradient(180deg,#0a0d1afa,#070910fc);position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column}.brand{display:flex;align-items:center;gap:10px;padding:8px 10px 16px;border-bottom:1px solid var(--brd);margin-bottom:14px}.brand h2{font-size:1.15rem;background:linear-gradient(90deg,#fff,#a5f3fc,#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-sub{font-size:.7rem;color:var(--muted2);margin-top:1px}.nav-label{font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);padding:10px 12px 4px;display:block}.navlink{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:.88rem;font-weight:500;margin-bottom:2px;transition:background .15s,color .15s}.navlink:hover{background:var(--panel-hover);color:var(--txt);text-decoration:none}.navlink.active{background:linear-gradient(135deg,#7c3aed8c,#3b82f666);color:#fff}.navlink .icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0}.side-user{font-size:.73rem;color:var(--muted);word-break:break-all;padding:6px 12px}.main{flex:1;min-width:0;padding:24px 28px}.topnav{display:none;gap:6px;flex-wrap:wrap;padding:10px 14px;border-bottom:1px solid var(--brd);background:#0a0d1af7;position:sticky;top:0;z-index:10}.topnav a{padding:6px 11px;border-radius:8px;background:var(--panel);border:1px solid var(--brd);color:var(--muted);font-size:.78rem;font-weight:600;text-decoration:none;white-space:nowrap}.topnav a.active{background:var(--purple);color:#fff;border-color:transparent}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:1.8rem;font-weight:700;background:linear-gradient(90deg,#fff,#d1e4ff 80%);-webkit-background-clip:text;background-clip:text;color:transparent}.page-subtitle{color:var(--muted);font-size:.9rem;margin-top:4px}.topo{background:linear-gradient(120deg,#7c3aed4d,#3b82f638 50%,#22d3ee42);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:center;gap:16px;margin-bottom:20px;box-shadow:0 8px 32px #060a1a80}.topo h1{font-size:1.5rem;background:linear-gradient(90deg,#fff,#a5f3fc,#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent;margin:0}.topo p{margin:3px 0 0;color:#c7d2fe;font-size:.88rem}.card{background:var(--panel);border:1px solid var(--brd);border-radius:var(--radius);padding:18px 20px;margin-bottom:12px}.card-hover{cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s}.card-hover:hover{border-color:#7c3aed73;box-shadow:0 8px 32px #0006,var(--glow-purple);transform:translateY(-2px)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--panel);border:1px solid var(--brd);border-radius:var(--radius);padding:18px 16px;text-align:center;transition:border-color .2s,transform .15s}.stat-card:hover{border-color:var(--brd-hover);transform:translateY(-1px)}.stat-num{font-family:Space Grotesk,sans-serif;font-size:2rem;font-weight:700;line-height:1;margin-bottom:5px}.stat-label{font-size:.76rem;color:var(--muted);font-weight:500}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.proj-card{background:var(--panel);border:1px solid var(--brd);border-radius:var(--radius);padding:18px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:8px}.proj-card:hover{border-color:#3b82f680;box-shadow:0 8px 28px #0006,0 0 0 1px #3b82f626;transform:translateY(-2px)}.proj-title{font-weight:700;font-size:.96rem;color:var(--txt)}.proj-desc{font-size:.82rem;color:var(--muted);flex:1;line-height:1.5}.proj-footer{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.book-card{display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:transform .15s;content-visibility:auto;contain-intrinsic-size:auto 260px}.book-card:hover{transform:translateY(-3px)}.capa{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:10px;box-shadow:0 8px 24px #0000008c}.capa-vazia{width:100%;aspect-ratio:3/4;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:2.2rem;background:linear-gradient(135deg,#1e1b4b,#312e81 42%,#1e40af);box-shadow:0 8px 24px #0000008c}.book-title{font-size:.8rem;font-weight:600;color:var(--txt2);line-height:1.3}.book-author{font-size:.72rem;color:var(--muted)}.ficha{background:linear-gradient(135deg,#7c3aed1f,#22d3ee12);border:1px solid var(--brd);border-radius:var(--radius);padding:18px 20px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;border:1px solid transparent}.badge-dev{background:#3b82f629;color:#93c5fd;border-color:#3b82f64d}.badge-ia{background:#7c3aed29;color:#c4b5fd;border-color:#7c3aed4d}.badge-auto{background:#f59e0b24;color:#fcd34d;border-color:#f59e0b4d}.badge-design{background:#10b98124;color:#6ee7b7;border-color:#10b9814d}.badge-python{background:#22d3ee1f;color:#67e8f9;border-color:#22d3ee4d}.badge-data{background:#ec489921;color:#f9a8d4;border-color:#ec48994d}.badge-ativo{background:#10b98124;color:#6ee7b7;border-color:#10b9814d}.badge-pausado{background:#f59e0b24;color:#fcd34d;border-color:#f59e0b4d}.badge-concluido{background:#3b82f629;color:#93c5fd;border-color:#3b82f64d}.tag{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.69rem;font-weight:600;background:var(--panel);border:1px solid var(--brd);color:var(--muted)}.filter-bar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.filter-chip{padding:6px 14px;border-radius:20px;background:var(--panel);border:1px solid var(--brd);color:var(--muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.filter-chip:hover{border-color:var(--brd-hover);color:var(--txt)}.filter-chip.active{background:#7c3aed80;color:#fff;border-color:#7c3aed80}input,select,textarea{width:100%;background:#ffffff0a;color:var(--txt);border:1px solid var(--brd);border-radius:var(--radius-sm);padding:10px 13px;font:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s;outline:none}input:focus,select:focus,textarea:focus{border-color:#7c3aed8c;box-shadow:0 0 0 3px #7c3aed1a}input::placeholder{color:var(--muted2)}textarea{resize:vertical;min-height:80px}select option{background:#1a1f35}button{background:var(--panel);color:var(--txt);border:1px solid var(--brd);border-radius:var(--radius-sm);padding:9px 16px;font:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;white-space:nowrap;outline:none}button:hover{background:var(--panel-hover);border-color:var(--brd-hover)}button:active{opacity:.85}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:linear-gradient(135deg,var(--purple),var(--blue));border:none;color:#fff;box-shadow:0 2px 12px #7c3aed59}button.primary:hover{box-shadow:0 4px 20px #7c3aed80;filter:brightness(1.1)}button.danger{background:transparent;border-color:#ef444466;color:#fca5a5}button.danger:hover{background:#ef44441a;border-color:#ef4444b3}button.ghost{background:transparent;border-color:transparent;color:var(--muted);padding:6px 10px}button.ghost:hover{background:var(--panel);color:var(--txt);border-color:var(--brd)}.bolha{padding:12px 16px;border-radius:var(--radius);border:1px solid var(--brd);background:var(--panel);margin-bottom:8px}.bolha.user{background:linear-gradient(135deg,#7c3aed21,#3b82f617);border-color:#7c3aed38;margin-left:20px}.flash{background:linear-gradient(135deg,#22d3ee12,#7c3aed1a);border:1px solid rgba(34,211,238,.22);border-radius:var(--radius-lg);padding:32px;text-align:center;font-size:1.1rem}.resource-card{background:var(--panel);border:1px solid var(--brd);border-radius:var(--radius);padding:16px;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:8px}.resource-card:hover{border-color:#22d3ee59;box-shadow:0 6px 24px #00000059,var(--glow-cyan);transform:translateY(-2px)}.resource-icon{font-size:1.5rem}.resource-title{font-size:.93rem;font-weight:700;color:var(--txt)}.resource-desc{font-size:.8rem;color:var(--muted);line-height:1.45;flex:1}.resource-link{font-size:.76rem;color:var(--cyan);font-weight:600}.repo-card{background:var(--panel);border:1px solid var(--brd);border-radius:var(--radius);padding:16px 18px;transition:border-color .2s,transform .15s;display:flex;flex-direction:column;gap:6px}.repo-card:hover{border-color:#3b82f666;transform:translateY(-1px)}.repo-name{font-weight:700;font-size:.9rem;color:var(--cyan)}.repo-desc{font-size:.8rem;color:var(--muted);line-height:1.4}.repo-meta{display:flex;gap:10px;align-items:center;font-size:.74rem;color:var(--muted2)}.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.kanban-col{background:#ffffff06;border:1px solid var(--brd);border-radius:var(--radius);padding:14px;min-height:200px}.kanban-col-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between}.kanban-item{background:var(--bg3);border:1px solid var(--brd);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:border-color .15s,transform .1s}.kanban-item:hover{border-color:var(--brd-hover);transform:translateY(-1px)}.progress-wrap{background:#ffffff0f;border-radius:10px;height:5px;overflow:hidden}.progress-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,var(--purple),var(--cyan));transition:width .4s}.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.col{display:flex;flex-direction:column;gap:8px}.muted{color:var(--muted)}.ok{color:#6ee7b7}.err{color:#fca5a5;font-size:.87rem}.warn{color:#fcd34d;font-size:.87rem}.small{font-size:.82rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex1{flex:1;min-width:0}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.section-title{font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:700;color:var(--txt2);margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-title:after{content:"";flex:1;height:1px;background:var(--brd)}.divider{border:none;border-top:1px solid var(--brd);margin:20px 0}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}.empty-title{font-size:.95rem;font-weight:600;margin-bottom:6px;color:var(--txt2)}.center-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-box{width:100%;max-width:400px}.spin{animation:spin .9s linear infinite;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.4s ease-in-out infinite}@media (max-width: 900px){.side{display:none}.topnav{display:flex}.main{padding:14px 16px}.kanban{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.grid,.grid-2,.grid-3{grid-template-columns:1fr}.book-grid{grid-template-columns:repeat(2,1fr)}.topo h1{font-size:1.25rem}.page-title{font-size:1.4rem}.main{padding:12px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#7c3aed99}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes popIn{0%{transform:scale(.8);opacity:0}80%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.fade-up{animation:fadeUp .35s ease both}.pop-in{animation:popIn .3s cubic-bezier(.34,1.56,.64,1) both}.spin{animation:spin 1s linear infinite}.skeleton{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a,#ffffff0d 75%);background-size:800px 100%;animation:shimmer 1.5s infinite;border-radius:6px}.skeleton-text{height:14px;margin-bottom:8px;border-radius:4px}.skeleton-title{height:22px;margin-bottom:12px;border-radius:6px;width:60%}.skeleton-card{height:120px;border-radius:var(--radius);margin-bottom:12px}.flip-scene{perspective:1000px}.flip-card{position:relative;width:100%;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.4,0,.2,1)}.flip-card.flipped{transform:rotateY(180deg)}.flip-front,.flip-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:var(--radius);padding:32px 24px;display:flex;align-items:center;justify-content:center;text-align:center}.flip-back{transform:rotateY(180deg)}.typing-cursor:after{content:"▋";animation:blink .7s step-end infinite;color:var(--cyan)}.citation{display:inline-flex;align-items:center;justify-content:center;background:#22d3ee26;color:var(--cyan);border:1px solid rgba(34,211,238,.35);border-radius:4px;padding:0 5px;font-size:.72rem;font-weight:700;cursor:pointer;margin:0 1px;vertical-align:super;transition:background .15s}.citation:hover{background:#22d3ee4d}.progress-ring circle{transition:stroke-dashoffset .6s ease}.fav-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.4;transition:all .2s;padding:2px 4px}.fav-btn:hover,.fav-btn.active{opacity:1;transform:scale(1.2)}.tag{display:inline-flex;align-items:center;gap:4px;background:#7c3aed26;color:#c4b5fd;border:1px solid rgba(124,58,237,.3);border-radius:20px;padding:2px 9px;font-size:.72rem;font-weight:600;cursor:default}.tag.removable{cursor:pointer}.tag.removable:hover{background:#ef444426;color:#fca5a5;border-color:#ef44444d}.goal-bar{height:6px;border-radius:3px;background:#ffffff12;overflow:hidden}.goal-fill{height:100%;border-radius:3px;transition:width .6s ease}.highlight{background:#22d3ee2e;border-radius:3px;padding:0 2px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;z-index:500;background:linear-gradient(180deg,#060810f7,#0a0d1af2);border-bottom:1px solid var(--brd);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);align-items:center;justify-content:space-between;padding:0 8px}.mobile-header-brand{display:flex;align-items:center;gap:8px;pointer-events:none}.mobile-header-btn{width:44px;height:44px;border-radius:10px;background:#ffffff0d;border:1px solid var(--brd);color:var(--txt);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.mobile-header-btn:hover{background:#ffffff1a}.bottom-tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;z-index:500;background:linear-gradient(0deg,#060810fa,#0a0d1af5);border-top:1px solid var(--brd);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 2px;background:none;border:none;color:var(--muted);cursor:pointer;text-decoration:none;transition:color .18s;-webkit-tap-highlight-color:transparent;min-height:44px}.bottom-tab:hover,.bottom-tab.active{color:var(--cyan);text-decoration:none}.bottom-tab-icon{position:relative;font-size:1.35rem;line-height:1;transition:transform .18s}.bottom-tab.active .bottom-tab-icon{transform:scale(1.1)}.bottom-tab-label{font-size:.58rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;text-transform:uppercase}.bottom-badge{position:absolute;top:-5px;right:-8px;background:#ef4444;color:#fff;border-radius:20px;padding:1px 5px;font-size:.55rem;font-weight:700;line-height:1.4;border:1.5px solid var(--bg0)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:700;background:#0009;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeOverlay .2s ease}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.mobile-drawer{position:fixed;bottom:0;left:0;right:0;z-index:800;max-height:85dvh;background:linear-gradient(180deg,#0a0d1afc,#070910);border-top:1px solid var(--brd);border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-drawer.open{transform:translateY(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--brd);flex-shrink:0}.drawer-close{width:36px;height:36px;border-radius:50%;background:#ffffff12;border:1px solid var(--brd);color:var(--muted);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center}.drawer-close:hover{background:#ffffff1f;color:var(--txt)}.drawer-scroll{flex:1;overflow-y:auto;padding:12px 10px;-webkit-overflow-scrolling:touch}.mobile-drawer:before{content:"";display:block;width:36px;height:4px;background:#ffffff2e;border-radius:2px;margin:10px auto 0;flex-shrink:0}.fab-container{position:fixed;bottom:20px;right:20px;z-index:400;display:flex;flex-direction:column;gap:8px}.fab{width:46px;height:46px;border-radius:50%;font-size:1.2rem;background:#7c3aed4d;border:1px solid rgba(124,58,237,.6);cursor:pointer;box-shadow:0 4px 16px #7c3aed4d;transition:background .2s,transform .15s;display:flex;align-items:center;justify-content:center}.fab:hover{transform:scale(1.08)}.fab-active{background:#7c3aedcc}.fab-cyan{background:#22d3ee33;border-color:#22d3ee80;box-shadow:0 4px 16px #22d3ee33}.fab-active-cyan{background:#22d3ee80}@media (max-width:768px){.side{display:none}.topnav{display:none!important}.layout{flex-direction:column}.main{padding:12px 12px 80px!important;margin-top:56px}.mobile-header,.bottom-tab-bar{display:flex}.fab-container{bottom:80px;right:12px}.fab{width:42px;height:42px;font-size:1.1rem}.stats-grid{grid-template-columns:repeat(2,1fr)!important}.grid-3{grid-template-columns:1fr 1fr!important}.grid,.grid-2{grid-template-columns:1fr!important}.topo h1{font-size:1.2rem}.topo{gap:10px;margin-bottom:14px}h1,.page-title{font-size:1.3rem}.card{padding:14px 12px}input,select,textarea{min-height:44px;font-size:16px!important}button{min-height:40px}.swipe-hints{display:flex}.mobile-page-footer{display:block}.row{flex-wrap:wrap}.book-grid{grid-template-columns:repeat(2,1fr)!important}}.qa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-3col{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px}.mini-stats,.summary-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.sug-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:560px}.shortcuts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.chat-page{display:flex;flex-direction:column;gap:12px;height:calc(100vh - 80px)}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.book-detail{display:flex;gap:20px;align-items:flex-start}.book-detail-cover{flex-shrink:0;width:180px}.pdf-frame{width:100%;height:70vh;border-radius:12px;border:1px solid var(--brd)}.mindmap-canvas{height:500px}.flip-front>div,.flip-back>div{max-height:100%;overflow-y:auto;width:100%}@media (max-width: 768px){.qa-grid{grid-template-columns:repeat(2,1fr)}.two-col,.form-3col,.summary-3{grid-template-columns:1fr}.sug-grid{grid-template-columns:1fr;max-width:none}.shortcuts-grid{grid-template-columns:1fr;gap:10px}.mini-stats{gap:6px}.chat-page{height:calc(100dvh - 152px)}.book-detail{flex-direction:column;align-items:center}.book-detail-cover{width:150px}.book-detail>div:last-child{width:100%}.pdf-frame{height:58vh}.mindmap-canvas{height:340px}.topo{padding:14px 16px}.toast-container{left:12px!important;right:12px!important;max-width:none!important}.flash{padding:20px 14px}.filter-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0}}.glass{background:#ffffff08;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08)}button.primary{position:relative;overflow:hidden}button.primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(255,255,255,.15),transparent 70%);opacity:0;transition:opacity .2s}button.primary:hover:after{opacity:1}.mobile-header-center{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.mobile-brand-text{font-weight:700;font-size:.95rem;font-family:Space Grotesk,sans-serif}.mobile-breadcrumb{display:flex;align-items:center;gap:5px;overflow:hidden;max-width:100%}.mobile-bc-home{font-size:.72rem;color:var(--muted);white-space:nowrap}.mobile-bc-sep{font-size:.72rem;color:var(--muted2)}.mobile-bc-page{font-size:.82rem;font-weight:600;color:var(--txt2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hscroll-tabs{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px;margin-bottom:16px}.hscroll-tabs::-webkit-scrollbar{display:none}.hscroll-tab{flex-shrink:0;padding:8px 16px;border-radius:20px;font-size:.82rem;font-weight:600;background:#ffffff0d;border:1px solid var(--brd);color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .18s}.hscroll-tab.active,.hscroll-tab:hover{background:#7c3aed2e;border-color:#7c3aed66;color:var(--txt)}.hscroll-tab.active{color:#c4b5fd}.swipe-hints{display:none;align-items:center;justify-content:space-between;padding:6px 16px;margin-bottom:6px}.swipe-hint{font-size:.75rem;font-weight:700;opacity:.35;transition:opacity .2s,color .2s}.swipe-hint-left{color:#ef4444}.swipe-hint-left.active{opacity:1}.swipe-hint-right{color:#10b981}.swipe-hint-right.active{opacity:1}.swipe-hint-center{opacity:.3}.mobile-page-footer{display:none;margin-top:32px;padding:20px 0 8px;border-top:1px solid var(--brd)}.mobile-page-footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mobile-footer-link{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-sm);background:#ffffff08;border:1px solid var(--brd);color:var(--txt2);font-size:.8rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}.mobile-footer-link:hover{background:#ffffff0f;border-color:var(--brd-hover);text-decoration:none}.mobile-footer-link span:first-child{font-size:1rem}.side-footer{margin-top:auto;padding-top:12px;border-top:1px solid var(--brd)}.side-user{font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:6px}.dot-online{width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b981;display:inline-block;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{box-shadow:0 0 6px #10b981}50%{box-shadow:0 0 12px #10b981,0 0 20px #10b98166}}#read-progress{position:fixed;top:0;left:0;height:3px;z-index:9999;background:linear-gradient(90deg,var(--purple),var(--cyan));transition:width .2s}.card-gradient{background:linear-gradient(135deg,#7c3aed1a,#22d3ee0d);border-color:#7c3aed40}.card-success{background:#10b98114;border-color:#10b9814d}.card-warning{background:#f59e0b14;border-color:#f59e0b4d}.card-danger{background:#ef444414;border-color:#ef44444d}input:focus,textarea:focus,select:focus{box-shadow:0 0 0 2px #7c3aed59,0 0 12px #7c3aed1a}.navlink{transition:all .18s ease}.clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
