:root{--bg-dark:#050510;--card:#ffffff0a;--input-bg:#ffffff0f;--border:#ffffff14;--text-main:#fff;--text-dim:#88a;--text-muted:#666;--cyan:#2dd4bf;--purple:#bc13fe;--accent:#2dd4bf;--font-head:"Plus Jakarta Sans", sans-serif;--font-mono:"JetBrains Mono", monospace;--font-body:"Inter", sans-serif}[data-theme=light]{--bg-dark:#e8edf5;--card:#fffffff2;--input-bg:#e8eef4;--border:#0000001f;--text-main:#0f172a;--text-dim:#334155;--text-muted:#64748b;--cyan:#0f766e;--accent:#0f766e;--purple:#7c3aed}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-dark);color:var(--text-main);font-family:var(--font-body);min-height:100vh;transition:background .3s,color .3s}.calc-main{max-width:1600px;margin:0 auto;padding:2rem 1.5rem 3rem}.calc-hero{text-align:center;margin-bottom:2rem}.calc-title{font-family:var(--font-head);margin-bottom:.5rem;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800}.calc-subtitle{color:var(--text-dim);max-width:640px;margin:0 auto;font-size:.95rem}.calc-shell{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.tab-bar{border-bottom:1px solid var(--border);background:#ffffff05;gap:0;display:flex;overflow-x:auto}[data-theme=light] .tab-bar{background:#f8fafc}.tab-btn{color:var(--text-dim);font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;padding:.85rem 1.4rem;font-size:.88rem;font-weight:600;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}[data-theme=light] .tab-btn.active{background:#0f766e0f}.tab-panel{padding:1.5rem;display:none}.tab-panel.active{display:block}.calc-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=900px){.calc-grid{grid-template-columns:1fr}}.input-card{border:1px solid #2dd4bf2e;border-left:3px solid var(--cyan);background:#2dd4bf0a;border-radius:12px;flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}[data-theme=light] .input-card{background:#fff;border-color:#0f766e33 #0f766e33 #0f766e33 #0f766e}.card-section-title{font-family:var(--font-head);letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);margin-top:.25rem;font-size:.8rem;font-weight:700}.input-label{color:var(--text-dim);margin-bottom:-.4rem;font-size:.8rem;font-weight:600}.input-wrap{align-items:center;gap:.5rem;display:flex}.glass-input{background:var(--input-bg);border:1px solid var(--border);color:var(--text-main);font-family:var(--font-mono);border-radius:8px;flex:1;padding:.55rem .75rem;font-size:.95rem;transition:border-color .2s}.glass-input:focus{border-color:var(--cyan);outline:none}[data-theme=light] .glass-input{color:#0f172a;background:#f0f4f9;border-color:#00000026}[data-theme=light] .glass-input:focus{border-color:#0f766e}[data-theme=light] .glass-input::placeholder{color:#0006}.input-unit,.input-prefix{font-family:var(--font-mono);color:var(--text-dim);white-space:nowrap;font-size:.78rem}.input-prefix{order:-1}.chip-row{flex-wrap:wrap;gap:.4rem;display:flex}.chip{border:1px solid var(--border);background:var(--input-bg);color:var(--text-dim);cursor:pointer;border-radius:20px;padding:.3rem .75rem;font-size:.78rem;font-weight:600;transition:all .2s}.chip:hover{border-color:var(--cyan);color:var(--text-main)}.chip.active{border-color:var(--cyan);color:var(--cyan);background:#2dd4bf26}[data-theme=light] .chip{color:#475569;background:#f0f4f9;border-color:#00000026}[data-theme=light] .chip.active{color:#0f766e;background:#0f766e1f;border-color:#0f766e}.hidden-row{display:none}.hidden-row.visible{align-items:center;gap:.5rem;display:flex}.result-card{border:1px solid #bc13fe2e;border-left:3px solid var(--purple);background:#bc13fe0a;border-radius:12px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}[data-theme=light] .result-card{background:#fff;border-color:#7c3aed33 #7c3aed33 #7c3aed33 #7c3aed}.hero-result{text-align:center;padding:1rem 0 .5rem}.hero-result-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-size:.75rem;font-weight:700}.hero-result-value{font-family:var(--font-mono);color:var(--cyan);margin:.25rem 0;font-size:clamp(2rem,5vw,2.8rem);font-weight:700;line-height:1.1}.hero-result-sub{color:var(--text-muted);font-size:.78rem}.stat-grid{grid-template-columns:1fr 1fr;gap:.6rem;display:grid}.stat-cell{border:1px solid var(--border);text-align:center;background:#ffffff08;border-radius:10px;padding:.7rem .75rem}[data-theme=light] .stat-cell{background:#edf2f9;border-color:#0000001a}.stat-val{font-family:var(--font-mono);color:var(--text-main);font-size:1.1rem;font-weight:700}.stat-lbl{color:var(--text-dim);margin-top:.15rem;font-size:.72rem}.framing-members-card{border:1px solid var(--border);background:#ffffff08;border-radius:10px;padding:.85rem}[data-theme=light] .framing-members-card{background:#edf2f9;border-color:#0000001a}.fm-title{letter-spacing:.07em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.6rem;font-size:.72rem;font-weight:700}.framing-members-list{flex-direction:column;gap:.35rem;display:flex}.fm-item{justify-content:space-between;align-items:center;font-size:.82rem;display:flex}.fm-item-label{color:var(--text-dim)}.fm-item-value{font-family:var(--font-mono);color:var(--cyan);font-weight:700}[data-theme=light] .fm-item-label{color:#475569}[data-theme=light] .fm-item-value{color:#0f766e}.diagram-wrap{border:1px solid var(--border);background:#ffffff05;border-radius:10px;padding:.75rem}[data-theme=light] .diagram-wrap{background:#f0f4f9;border-color:#0000001f}.diagram-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.5rem;font-size:.72rem;font-weight:600}.framing-svg{width:100%;height:auto;display:block}.act-row{flex-wrap:wrap;gap:.5rem;display:flex}.act-btn{border:1px solid var(--border);min-width:80px;color:var(--text-dim);cursor:pointer;background:#ffffff0a;border-radius:8px;flex:1;padding:.5rem;font-size:.78rem;font-weight:600;transition:all .2s}.act-btn:hover{border-color:var(--cyan);color:var(--cyan);background:#2dd4bf1a}[data-theme=light] .act-btn{color:#475569;background:#f0f4f9;border-color:#00000026}[data-theme=light] .act-btn:hover{color:#0f766e;background:#0f766e14;border-color:#0f766e}.panel-section-title{font-family:var(--font-head);color:var(--text-main);margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.panel-intro{color:var(--text-dim);margin-bottom:1rem;font-size:.88rem}.header-content{flex-direction:column;gap:1.5rem;display:flex}.header-table-wrap{overflow-x:auto}.header-table{border-collapse:collapse;width:100%;font-size:.85rem}.header-table th{color:var(--cyan);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border);background:#2dd4bf1a;padding:.55rem .75rem;font-size:.75rem;font-weight:700}[data-theme=light] .header-table th{color:#0f766e;background:#0f766e14}.header-table td{color:var(--text-dim);border-bottom:1px solid #ffffff0a;padding:.5rem .75rem}[data-theme=light] .header-table td{color:#334155;border-bottom:1px solid #0000000f}.header-table tr:hover td{background:#ffffff05}[data-theme=light] .header-table tr:hover td{background:#f0f4f9}.header-table .current-span td{color:var(--text-main);background:#2dd4bf14;font-weight:600}[data-theme=light] .header-table .current-span td{color:#0f172a;background:#0f766e0f}.header-notes{flex-direction:column;gap:.5rem;display:flex}.header-note{color:var(--text-dim);border:1px solid var(--border);background:#ffffff08;border-radius:8px;align-items:flex-start;gap:.75rem;padding:.5rem .75rem;font-size:.83rem;display:flex}[data-theme=light] .header-note{color:#334155;background:#edf2f9;border-color:#0000001a}.header-note-icon{flex-shrink:0}.multidoor-content{flex-direction:column;gap:1rem;display:flex}.door-list-wrap{overflow-x:auto}.door-list-table{border-collapse:collapse;width:100%;font-size:.85rem}.door-list-table th{color:var(--cyan);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border);background:#2dd4bf1a;padding:.55rem .75rem;font-size:.75rem;font-weight:700}[data-theme=light] .door-list-table th{color:#0f766e;background:#0f766e14}.door-list-table td{color:var(--text-dim);border-bottom:1px solid #ffffff0a;padding:.5rem .75rem}[data-theme=light] .door-list-table td{color:#334155;border-bottom:1px solid #0000000f}.door-list-table tr:hover td{background:#ffffff05}[data-theme=light] .door-list-table tr:hover td{background:#f0f4f9}.door-list-empty{text-align:center;color:var(--text-muted);border:1px dashed var(--border);background:#ffffff05;border-radius:10px;padding:2rem;font-size:.88rem}[data-theme=light] .door-list-empty{color:#64748b;background:#f0f4f9;border-color:#00000026}.remove-door-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.1rem .3rem;font-size:.9rem;transition:color .2s}.remove-door-btn:hover{color:#ef4444}.door-list-actions{flex-wrap:wrap;gap:.5rem;display:flex}.list-action-btn{cursor:pointer;border:1px solid var(--border);color:var(--text-dim);background:#ffffff0a;border-radius:8px;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:all .2s}.list-action-btn:hover{border-color:var(--cyan);color:var(--cyan)}.list-action-btn.danger:hover{color:#ef4444;border-color:#ef4444}[data-theme=light] .list-action-btn{color:#475569;background:#f0f4f9;border-color:#00000026}[data-theme=light] .list-action-btn:hover{color:#0f766e;border-color:#0f766e}[data-theme=light] .list-action-btn.danger:hover{color:#b91c1c;border-color:#b91c1c}.reference-content{flex-direction:column;gap:1.5rem;display:flex}.ref-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;display:grid}.ref-card{border:1px solid var(--border);background:#ffffff08;border-radius:10px;padding:1rem}[data-theme=light] .ref-card{background:#fff;border-color:#0000001f;box-shadow:0 1px 4px #0000000f}.ref-card-title{font-family:var(--font-head);color:var(--cyan);margin-bottom:.6rem;font-size:.85rem;font-weight:700}[data-theme=light] .ref-card-title{color:#0f766e}.ref-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.ref-list li{color:var(--text-dim);padding-left:.9rem;font-size:.82rem;line-height:1.55;position:relative}.ref-list li:before{content:"–";color:var(--text-muted);position:absolute;left:0}[data-theme=light] .ref-list li{color:#475569}.ro-rules-wrap{overflow-x:auto}.ro-rules-table{border-collapse:collapse;width:100%;font-size:.85rem}.ro-rules-table th{color:var(--cyan);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border);background:#2dd4bf1a;padding:.55rem .75rem;font-size:.75rem;font-weight:700}[data-theme=light] .ro-rules-table th{color:#0f766e;background:#0f766e14}.ro-rules-table td{color:var(--text-dim);border-bottom:1px solid #ffffff0a;padding:.5rem .75rem}[data-theme=light] .ro-rules-table td{color:#334155;border-bottom:1px solid #0000000f}.ro-rules-table tr:hover td{background:#ffffff05}[data-theme=light] .ro-rules-table tr:hover td{background:#f0f4f9}.page-sections-outer{max-width:1600px;margin:0 auto;padding:0 1.5rem 3rem}.how-section{margin-top:3rem;margin-bottom:2rem}.section2-title{font-family:var(--font-head);color:var(--text-main);margin-bottom:1.25rem;font-size:1.3rem;font-weight:800}.how-list{counter-reset:how-count;flex-direction:column;gap:.85rem;list-style:none;display:flex}.how-list li{counter-increment:how-count;color:var(--text-dim);align-items:flex-start;gap:1rem;font-size:.88rem;line-height:1.65;display:flex}.how-list li:before{content:counter(how-count);width:26px;height:26px;color:var(--cyan);font-family:var(--font-mono);background:#2dd4bf26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}[data-theme=light] .how-list li:before{color:#0f766e;background:#0f766e1f}[data-theme=light] .how-list li{color:#334155}.pill-row{flex-wrap:wrap;gap:.5rem;display:flex}.formula-pill{color:var(--cyan);font-family:var(--font-mono);background:#2dd4bf14;border:1px solid #2dd4bf33;border-radius:20px;padding:.4rem .9rem;font-size:.78rem}[data-theme=light] .formula-pill{color:#0f766e;background:#0f766e14;border-color:#0f766e33}.gloss-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem;display:grid}.gloss-item{border:1px solid var(--border);background:#ffffff08;border-radius:10px;flex-direction:column;gap:.2rem;padding:.75rem;display:flex}[data-theme=light] .gloss-item{background:#fff;border-color:#0000001a;box-shadow:0 1px 4px #0000000f}.gloss-term{font-family:var(--font-mono);color:var(--cyan);font-size:.8rem;font-weight:700}[data-theme=light] .gloss-term{color:#0f766e}.gloss-def{color:var(--text-dim);font-size:.82rem;line-height:1.55}[data-theme=light] .gloss-def{color:#475569}.faq-section{margin-bottom:2rem}.faq-list{flex-direction:column;display:flex}.faq-item{border-bottom:1px solid #ffffff0f}.faq-item__question{cursor:pointer;color:var(--text-main);user-select:none;justify-content:space-between;align-items:center;padding:14px 4px;font-size:.9rem;font-weight:600;list-style:none;transition:color .2s;display:flex}.faq-item__question::-webkit-details-marker{display:none}.faq-item__question:after{content:"+";font-family:var(--font-mono);color:var(--text-dim);flex-shrink:0;margin-left:16px;font-size:1.1rem;transition:color .2s}.faq-item[open] .faq-item__question:after{content:"−";color:var(--accent)}.faq-item__question:hover{color:var(--cyan)}.faq-item__answer{color:var(--text-dim);padding:0 4px 14px;font-size:.85rem;line-height:1.75}[data-theme=light] .faq-list{gap:8px}[data-theme=light] .faq-item{background:#fff;border:1px solid #0000001a;border-radius:10px;transition:box-shadow .2s,border-color .2s;overflow:hidden;box-shadow:0 1px 4px #0000000f}[data-theme=light] .faq-item:hover{border-color:#0f766e59;box-shadow:0 2px 10px #0f766e14}[data-theme=light] .faq-item[open]{border-color:#0f766e66 #0f766e66 #0f766e66 #0f766e;border-left-style:solid;border-left-width:3px;box-shadow:0 2px 12px #0f766e1a}[data-theme=light] .faq-item__question{color:#0f172a;padding:14px 16px}[data-theme=light] .faq-item__question:after{color:#64748b}[data-theme=light] .faq-item[open] .faq-item__question:after,[data-theme=light] .faq-item__question:hover{color:#0f766e}[data-theme=light] .faq-item__answer{color:#475569;border-top:1px solid #0000000f;padding:12px 16px 16px}.calc-related{margin-bottom:2rem}.related-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;display:grid}.related-card{border:1px solid var(--border);background:#ffffff08;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:1.1rem;text-decoration:none;transition:all .2s;display:flex}.related-card:hover{border-color:var(--cyan);background:#2dd4bf12}[data-theme=light] .related-card{background:#fff;border-color:#0000001f;box-shadow:0 1px 4px #0000000f}[data-theme=light] .related-card:hover{background:#0f766e0d;border-color:#0f766e}.related-icon{font-size:1.6rem}.related-name{color:var(--text-dim);text-align:center;font-size:.8rem;font-weight:600}[data-theme=light] .related-name{color:#334155}.toast{z-index:9999;pointer-events:none;border-radius:8px;padding:.6rem 1.1rem;font-size:.83rem;font-weight:600;animation:.25s toastIn;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #0000004d}.toast-success{color:#fff;background:#10b981e6}.toast-warn{color:#fff;background:#f59e0be6}.toast-error{color:#fff;background:#ef4444e6}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.how-title{margin-bottom:1.5rem;font-size:1.25rem;font-weight:700}.how-steps{flex-direction:column;gap:1rem;list-style:none;display:flex}.how-step{color:var(--text-dim);align-items:flex-start;gap:1rem;font-size:.9rem;line-height:1.7;display:flex}.how-num{background:var(--cyan);color:#050510;font-family:var(--font-mono);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:28px;height:28px;font-size:.85rem;font-weight:700;display:flex}[data-theme=light] .how-num{color:#fff;background:#0e7490}.how-step strong{color:var(--text-main)}.gloss-section2{margin-bottom:3rem}.gs2-title{margin-bottom:1rem;font-size:1.1rem;font-weight:700}.gs2-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (width<=700px){.gs2-grid{grid-template-columns:1fr}}.gs2-item{background:var(--card);border:1px solid var(--border);color:var(--text-dim);border-radius:10px;padding:1rem;font-size:.83rem;line-height:1.7}[data-theme=light] .gs2-item{background:#fff;border-color:#0000001a;box-shadow:0 1px 3px #0000000d}.gs2-item strong{color:var(--text-main)}.formula-pills2{margin-bottom:3rem}.fp2-title{margin-bottom:1rem;font-size:1.1rem;font-weight:700}.fp2-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}@media (width<=700px){.fp2-grid{grid-template-columns:repeat(2,1fr)}}.fp2-pill{background:#00f3ff0f;border:1px solid #00f3ff26;border-radius:10px;flex-direction:column;gap:4px;padding:.75rem 1rem;display:flex}[data-theme=light] .fp2-pill{background:#0e74900f;border-color:#0e749033}.fp2-name{color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.fp2-eq{font-family:var(--font-mono);color:var(--cyan);font-size:.82rem;font-weight:600}[data-theme=light] .fp2-eq{color:#0e7490}@media print{.glass-navbar,.calc-page-footer,.calc-back-to-top,.tab-nav,.tabs-outer,.outer-tab-nav,.tab-btn,.act-row,.act-row2,.action-bar,.btn-copy,.btn-share,.btn-csv,.btn-pdf,.btn-export-pdf,.share-btn,.copy-btn,.print-btn,.how-section,.formula-pills2,.gloss-section2,.ex-section2,.faq-section,.faq-section-extra,.calc-related,.page-sections-outer{display:none!important}body{color:#000;background:#fff}.result-card,.stat-card,.card,.glass-card,.result-panel{box-shadow:none;page-break-inside:avoid;color:#000;background:#fff;border:1px solid #ccc}.stat-value,.stat-label,.result-value,h1,h2,h3{color:#000;text-shadow:none}.tab-panel{display:block!important}}