:root{--font-fluid-base: clamp(14px, 1.2vw + 10px, 18px);--radius: 12px;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-md: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);font-family:Inter,Noto Sans TC,-apple-system,system-ui,sans-serif}[data-theme=sakura]{--bg: #FFFAFC;--shell: #FFFFFF;--surface: rgba(255, 255, 255, .72);--surface-soft: rgba(255, 250, 252, .88);--surface-tint: #FBE7EF;--ink: #2B2028;--muted: #8B7180;--soft: #D783A3;--line: rgba(232, 213, 222, .8);--line-strong: rgba(215, 131, 163, .5);--primary: #B94E76;--primary-strong: #9A3E5F;--primary-soft: #FBE7EF;--red: #C44858;--red-soft: #FCE9EC}[data-theme=ocean]{--bg: #F6FAFB;--shell: #FFFFFF;--surface: rgba(255, 255, 255, .72);--surface-soft: rgba(246, 250, 251, .88);--surface-tint: #E1EFF3;--ink: #16323B;--muted: #6E8A92;--soft: #7FB8C4;--line: rgba(211, 229, 234, .8);--line-strong: rgba(127, 184, 196, .5);--primary: #2E7D9A;--primary-strong: #225C73;--primary-soft: #E1EFF3;--red: #C2543E;--red-soft: #FBEAE5}[data-theme=sunset]{--bg: #FFFDF9;--shell: #FFFFFF;--surface: rgba(255, 255, 255, .72);--surface-soft: rgba(255, 253, 249, .88);--surface-tint: #FBE8D6;--ink: #221404;--muted: #7A6650;--soft: #D98B3C;--line: rgba(232, 216, 194, .8);--line-strong: rgba(217, 139, 60, .5);--primary: #C8631E;--primary-strong: #A35017;--primary-soft: #FBE8D6;--red: #BC3B28;--red-soft: #FBE6E1}[data-theme=forest]{--bg: #F4F1E8;--shell: #FBF9F2;--surface: rgba(251, 249, 242, .72);--surface-soft: rgba(244, 241, 232, .88);--surface-tint: #E1EDE2;--ink: #232A22;--muted: #6E776A;--soft: #6E9B7E;--line: rgba(217, 210, 191, .8);--line-strong: rgba(110, 155, 126, .5);--primary: #2F6B4F;--primary-strong: #23513C;--primary-soft: #E1EDE2;--red: #A8523A;--red-soft: #F2E5DE}[data-theme=lavender]{--bg: #F8F6FA;--shell: #FFFFFF;--surface: rgba(255, 255, 255, .72);--surface-soft: rgba(248, 246, 250, .88);--surface-tint: #EBE5F2;--ink: #2B2333;--muted: #857492;--soft: #BCA6D1;--line: rgba(226, 218, 235, .8);--line-strong: rgba(188, 166, 209, .5);--primary: #755B8A;--primary-strong: #5A446B;--primary-soft: #EBE5F2;--red: #B54E62;--red-soft: #F5E5E8}[data-theme=night]{--bg: #171410;--shell: #211b16;--surface: rgba(33, 27, 22, .72);--surface-soft: rgba(23, 20, 16, .88);--surface-tint: #2f271f;--ink: #e8decd;--muted: #978874;--soft: #9e8975;--line: rgba(59, 49, 39, .8);--line-strong: rgba(155, 122, 89, .5);--primary: #c8a071;--primary-strong: #e3be91;--primary-soft: #4a3a29;--red: #c88b77;--red-soft: #3d221c;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-md: 0 20px 25px -5px rgba(0, 0, 0, .5)}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{margin:0;background-color:var(--bg);color:var(--ink);font-size:var(--base-font-size, var(--font-fluid-base));line-height:1.6;transition:background-color .3s ease,color .3s ease;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.app-shell{width:min(1480px,calc(100% - 28px));min-height:calc(100vh - 28px);margin:14px auto;display:flex;flex-direction:column;background:var(--surface);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-md);overflow:hidden;transition:background .3s ease,border-color .3s ease}.main{flex:1;padding:24px 32px;overflow-y:auto}.topbar{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 24px;background:var(--surface-soft);border-bottom:1px solid var(--line);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);transition:background .3s ease,border-color .3s ease}.topbar h1{margin:2px 0 0;font-size:calc(var(--base-font-size) * 1.71);line-height:1.18;letter-spacing:0}.topbar h1:before{content:"學";display:inline-grid;place-items:center;width:34px;height:34px;margin-right:10px;border-radius:8px;background:var(--ink);color:#fff;font-size:calc(var(--base-font-size) * .85);font-weight:900;vertical-align:middle}.eyebrow{margin:0;color:var(--muted);font-size:calc(var(--base-font-size) * .85);font-weight:800;letter-spacing:.08em;text-transform:uppercase}.topbar-actions,.button-row,.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hamburger-btn{font-size:calc(var(--base-font-size) * 1.42);padding:4px 8px;min-height:auto;color:var(--ink)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:100}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer-panel{position:fixed;top:0;left:-280px;width:260px;height:100vh;background:var(--shell);border-right:1px solid var(--line-strong);z-index:101;display:flex;flex-direction:column;gap:12px;padding:24px 14px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}.drawer-panel.open{transform:translate(280px)}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:0 8px 16px;border-bottom:1px solid var(--line);margin-bottom:8px}.tab,.ghost-button,.solid-button,.danger-button,.small-button{border:1px solid transparent;border-radius:var(--radius);min-height:38px;padding:0 14px;background:transparent;color:var(--ink);white-space:nowrap}.tab{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:12px;width:100%;padding:12px 16px;color:var(--muted);font-weight:700;text-align:left;background:var(--surface);border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:all .2s ease}.tab:hover{background:var(--surface-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}.tab.is-active{background:var(--primary-soft);color:var(--primary-strong);border-color:var(--primary)}.tab .tab-icon{font-size:calc(var(--base-font-size) * 1.71)}.tab[data-view=dashboard]:before{background:linear-gradient(135deg,var(--primary),#49a88d)}.tab[data-view=library]:before{background:linear-gradient(135deg,var(--blue),#75a3d2)}.tab[data-view=rescue]:before{background:linear-gradient(135deg,var(--amber),#d59a4b)}.tab[data-view=sessions]:before{background:linear-gradient(135deg,#6b5b95,#a894d1)}.tab[data-view=settings]:before{background:linear-gradient(135deg,#596460,#96a39e)}.tab.is-active{background:var(--surface);color:var(--ink);border-color:var(--line-strong);box-shadow:var(--shadow-sm)}[data-theme=light] .tab.is-active{background:#ffffffeb}.ghost-button,.small-button{border-color:var(--line);background:var(--surface)}.ghost-button:hover,.small-button:hover{border-color:var(--line-strong);background:var(--surface-soft)}.small-button{min-height:32px;padding:0 10px;font-size:calc(var(--base-font-size) * .92)}.solid-button{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 8px 18px #156a5b2e}.solid-button:hover{background:var(--primary-strong)}.danger-button{background:var(--red-soft);color:var(--red);border-color:#ebc4bf}.main{grid-column:2;grid-row:2;min-width:0;padding:22px 24px 40px}.layout-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;align-items:start}.dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.panel,.metric,.item-row,.detail-shell{background:var(--surface-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card,.panel{background:var(--shell);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);transition:box-shadow .3s ease}.card:hover{box-shadow:var(--shadow-md)}.swatch-container{display:flex;flex-wrap:wrap;gap:12px}.color-swatch{width:48px;height:48px;border-radius:50%;border:2px solid var(--line);cursor:pointer;transition:transform .2s ease,border-color .2s ease}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:var(--primary-strong);box-shadow:0 0 0 4px var(--primary-soft)}.global-fab{position:fixed;bottom:24px;right:24px;width:64px;height:64px;border-radius:32px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:calc(var(--base-font-size) * 2.28);box-shadow:var(--shadow-md);border:none;cursor:pointer;z-index:1000;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),background .3s ease}.global-fab:hover{transform:scale(1.1);background:var(--primary-strong)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--shell);padding:24px;border-radius:16px;width:90%;max-width:400px;box-shadow:var(--shadow-md)}.panel,.detail-shell{padding:16px}.panel{overflow:hidden}.metric{position:relative;min-height:112px;padding:16px;overflow:hidden}.metric:after{content:"";position:absolute;right:14px;bottom:14px;width:44px;height:6px;border-radius:999px;background:var(--primary-soft)}.metric:nth-child(2):after{background:var(--amber-soft)}.metric:nth-child(3):after{background:var(--blue-soft)}.metric:nth-child(4):after{background:#eee8fb}.metric dt,.section-label{margin:0 0 8px;color:var(--muted);font-size:calc(var(--base-font-size) * .85);font-weight:850;letter-spacing:.05em;text-transform:uppercase}.metric dd{margin:0;font-size:calc(var(--base-font-size) * 2.42);line-height:1;font-weight:900}.panel-header,.list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-title{margin:0;font-size:calc(var(--base-font-size) * 1.28);line-height:1.3;letter-spacing:0}.panel-subtitle{margin:5px 0 0;color:var(--muted);line-height:1.55;font-size:calc(var(--base-font-size) * 1)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.form-grid.one{grid-template-columns:1fr}.field{display:grid;gap:6px}.field.full{grid-column:1 / -1}.field label{color:var(--muted);font-size:calc(var(--base-font-size) * .85);font-weight:850;letter-spacing:.02em}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--ink);min-height:42px;padding:9px 11px;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease,color .15s ease}input:focus,select:focus,textarea:focus{border-color:#156a5b9e;box-shadow:0 0 0 3px #156a5b1f}textarea{min-height:110px;resize:vertical;line-height:1.58}.toolbar{display:grid;grid-template-columns:minmax(180px,1fr) 160px 160px;gap:10px;margin-bottom:12px}.item-list,.session-list,.attachment-list,.chapter-list{display:grid;gap:10px}.item-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;padding:14px;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}.item-row:hover{border-color:var(--line-strong);transform:translateY(-1px);box-shadow:0 8px 24px #19272312}.item-row h3,.chapter-title,.session-title{margin:0;font-size:calc(var(--base-font-size) * 1.14);line-height:1.35;letter-spacing:0}.item-meta,.muted,.session-meta{color:var(--muted);font-size:calc(var(--base-font-size) * .92);line-height:1.5}.item-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tag,.status-pill,.type-pill{display:inline-flex;align-items:center;border-radius:999px;min-height:24px;padding:0 9px;font-size:calc(var(--base-font-size) * .85);font-weight:800;background:var(--surface-soft);color:var(--muted)}.status-pill.in_progress{background:var(--primary-soft);color:var(--primary-strong)}.status-pill.completed{background:#e4f1dc;color:#3e652d}.status-pill.paused,.status-pill.backlog{background:var(--amber-soft);color:var(--amber)}.status-pill.archived{background:#ecefee;color:#66716e}.progress-bar{height:8px;border-radius:999px;overflow:hidden;background:#eef2f0;margin-top:12px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#42a98e);width:0}.detail-shell{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px}.side-stack,.content-stack{display:grid;gap:12px}.chapter-row,.session-row,.attachment-row,.next-action-box{border:1px solid var(--line);border-radius:var(--radius);padding:13px;background:var(--surface)}.next-action-box{position:relative;background:var(--surface-tint);border-color:#c7e6dd}.next-action-box h3{margin:0 0 8px;font-size:calc(var(--base-font-size) * 1.42);line-height:1.28}.next-action-box p:not(.section-label){color:#2b3a36;line-height:1.62}.empty-state{border:1px dashed var(--line-strong);border-radius:var(--radius);padding:24px;text-align:center;color:var(--muted);background:var(--surface-soft)}.split-line{height:1px;background:var(--line);margin:12px 0}.preview-image{max-width:100%;border-radius:var(--radius);border:1px solid var(--line);margin-top:10px}.file-drop{border:1px dashed var(--line-strong);border-radius:var(--radius);padding:12px;background:var(--surface-soft)}.notice{padding:12px;border:1px solid #d8c392;background:#fff8df;color:#67521b;border-radius:var(--radius);line-height:1.6}.timeline-list,.timeline-events{display:grid;gap:12px}.timeline-day>h3{margin:18px 0 10px;color:var(--primary-strong);font-size:calc(var(--base-font-size) * 1)}.timeline-event{display:grid;grid-template-columns:36px minmax(0,1fr);gap:12px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.timeline-icon{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--primary-soft);color:var(--primary-strong);font-weight:900}.timeline-event h4,.timeline-event p{margin:0}.timeline-event h4{margin-top:3px;font-size:calc(var(--base-font-size) * 1.07)}.timeline-event p:not(.timeline-type){margin-top:5px}.timeline-type{color:var(--muted);font-size:calc(var(--base-font-size) * .85);font-weight:750}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.topbar,.main,.tabs{grid-column:1}.tabs{grid-row:2;flex-direction:row;padding:8px;border-right:0;border-bottom:1px solid var(--line-strong);overflow-x:auto}.tabs:before{content:none}.main{grid-row:3}.tab{width:auto;min-width:132px}.layout-grid,.detail-shell{grid-template-columns:1fr}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 600px){.topbar{padding:14px 16px;flex-direction:column;align-items:flex-start;gap:12px}.dashboard-grid,.form-grid,.toolbar{grid-template-columns:1fr}.main{padding:16px 12px 30px}}.fab-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:28px;background:var(--primary);color:#fff;border:none;font-size:calc(var(--base-font-size) * 1.14);font-weight:700;box-shadow:0 10px 20px #0ea5e94d;display:flex;align-items:center;justify-content:center;z-index:100;transition:transform .2s}.fab-button:active{transform:scale(.9)}.mobile-only{display:none}@media (max-width: 1100px){.mobile-only{display:flex}}.asset-editor-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#17201d66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.asset-editor-modal{width:min(900px,calc(100% - 40px));height:min(800px,calc(100vh - 40px));background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line-strong)}.asset-editor-header{padding:16px 20px;background:var(--surface-tint);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px}.asset-editor-header input{flex:1;font-size:calc(var(--base-font-size) * 1.28);font-weight:700;background:transparent;border:none;padding:0;min-height:auto}.asset-editor-header input:focus{box-shadow:none}.asset-editor-body{flex:1;display:flex;flex-direction:column;padding:0}.asset-editor-body textarea{flex:1;width:100%;border:none;border-radius:0;padding:24px;font-family:JetBrains Mono,Cascadia Code,Fira Code,monospace;font-size:calc(var(--base-font-size) * 1.07);line-height:1.7;resize:none;outline:none;background:var(--surface)}.asset-editor-footer{padding:12px 20px;background:var(--surface-soft);border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.asset-editor-hint{font-size:calc(var(--base-font-size) * .85);color:var(--soft)}@media (max-width: 700px){.app-shell{width:100%;min-height:100vh;margin:0;border:0;border-radius:0}.topbar{align-items:stretch;flex-direction:column;padding:16px}.topbar h1{font-size:calc(var(--base-font-size) * 1.57)}.topbar-actions{display:grid;grid-template-columns:1fr 1fr}.topbar-actions .solid-button{grid-column:1 / -1}.main{padding:16px}.dashboard-grid,.toolbar,.form-grid,.item-row{grid-template-columns:1fr}}.achievement-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--surface-tint),#f0fdf4);border:1px solid #bbf7d0;padding:6px 12px;border-radius:999px;box-shadow:0 2px 4px #156a5b0d;transition:transform .2s,box-shadow .2s;cursor:default}.achievement-badge:hover{transform:translateY(-2px);box-shadow:0 4px 8px #156a5b1a;border-color:#86efac}.achievement-icon{font-size:calc(var(--base-font-size) * 1.14)}.achievement-title{font-size:calc(var(--base-font-size) * .92);font-weight:700;color:var(--primary-strong);letter-spacing:.02em}.asset-wall-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--line)}.section-title{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:.25rem}.highlight-panel{border-left:4px solid var(--primary)}.rescue-center .item-row{border:1px solid var(--red-soft);background:var(--red-soft);opacity:.95}.warning-text{color:var(--red);font-weight:800;font-size:calc(var(--base-font-size) * .92);margin:4px 0;text-transform:uppercase;letter-spacing:.05em}.rescue-action-box{margin-top:12px;padding:12px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line)}.rescue-widget .mini-row{display:flex;justify-content:space-between;align-items:center;padding:8px;background:var(--surface-soft);border-radius:6px;margin-bottom:6px;font-size:calc(var(--base-font-size) * .92)}.mini-row{display:flex;justify-content:space-between;align-items:center}.mini-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:65%;font-weight:600}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.template-card{display:flex;flex-direction:column;align-items:flex-start;padding:14px;background:var(--surface-tint);border:1px dashed var(--line-strong);border-radius:var(--radius);cursor:pointer;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1)}.template-card:hover{border-color:var(--primary);background:var(--primary-soft);transform:translateY(-2px)}.template-card strong{display:block;font-size:calc(var(--base-font-size) * 1);margin-bottom:4px;color:var(--primary-strong)}.template-card span{font-size:calc(var(--base-font-size) * .85);color:var(--muted)}.asset-list{display:grid;gap:8px}.asset-row{display:flex;align-items:center;gap:14px;padding:12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:6px}.asset-icon{font-size:calc(var(--base-font-size) * 1.42);filter:grayscale(.2)}.asset-info{flex:1}.asset-info h4{font-size:calc(var(--base-font-size) * 1);font-weight:700;margin:0}.full-width{width:100%}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:1000;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.toast-enter{opacity:1;transform:translate(-50%)}.toast-exit{opacity:0;transform:translate(-50%,20px)}.toast-content{background:var(--ink);color:#fff;padding:12px 24px;border-radius:999px;box-shadow:0 8px 16px #0003;display:flex;align-items:center;gap:8px;font-weight:600;font-size:calc(var(--base-font-size) * 1);pointer-events:auto}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;animation:fadeIn .2s ease}.drawer-content{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:600px;background:var(--shell);box-shadow:-8px 0 24px #00000026;z-index:51;overflow-y:auto;padding:24px;animation:slideInRight .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}
