:root{--accent:#00d1c1;--bg-app:#050510;--bg-card:#0d0d1f;--bg-input:#111128;--text-primary:#fff;--text-secondary:#88a;--text-muted:#557;--cyan:#00f3ff;--purple:#bc13fe;--green:#10b981;--red:#f43f5e;--amber:#f59e0b;--border:#ffffff14;--radius:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-app);color:var(--text-primary);min-height:100vh;font-family:Inter,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}.calc-breadcrumb{color:var(--text-muted);padding:10px 24px;font-size:.79rem}.calc-breadcrumb a{color:var(--text-secondary)}.calc-breadcrumb a:hover{color:var(--accent)}.main-container{max-width:1200px;margin:0 auto;padding:24px}.calc-title{margin-bottom:8px;font-size:2rem;font-weight:700}.calc-subtitle{color:var(--text-secondary);margin-bottom:24px}.tab-nav{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 22px;font-family:inherit;font-size:.9rem;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.tab-content{display:none}.tab-content.active{display:block}.calc-layout{grid-template-columns:380px 1fr;align-items:start;gap:20px;display:grid}@media (width<=960px){.calc-layout{grid-template-columns:minmax(0,1fr);overflow:hidden}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.input-card{border-left:3px solid var(--cyan)}.result-card{border-left:3px solid var(--purple)}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.82rem;font-weight:500;display:block}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:.92rem;transition:border-color .2s}.form-input:focus,.form-select:focus{border-color:var(--accent);outline:none}.form-select option{background:var(--bg-card)}.inline-inputs{grid-template-columns:1fr 1fr;gap:8px;display:grid}.section-title{margin-bottom:14px;font-size:1rem;font-weight:700}.mat-chips{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.mat-chip{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:6px 13px;font-size:.81rem;font-weight:500;transition:all .18s}.mat-chip:hover{color:var(--accent);border-color:#00d1c166}.mat-chip.active{border-color:var(--accent);color:var(--accent);background:#00d1c11f;font-weight:600}.mat-note{color:var(--text-muted);min-height:1.1em;margin-top:2px;font-size:.78rem;font-style:italic}.shape-chips{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.shape-chip{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:7px 14px;font-size:.83rem;transition:all .2s}.shape-chip:hover{color:var(--accent);border-color:#00d1c166}.shape-chip.active{border-color:var(--accent);color:var(--accent);background:#00d1c11a;font-weight:600}.toggle-row{gap:6px;display:flex}.labor-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;border-radius:8px;flex:1;padding:8px 10px;font-family:inherit;font-size:.82rem;transition:all .18s}.labor-btn.active{border-color:var(--accent);color:var(--accent);background:#00d1c11f;font-weight:600}.depth-chips{gap:8px;display:flex}.depth-chip{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:7px 16px;font-size:.82rem;transition:all .18s}.depth-chip.active{border-color:var(--amber);color:var(--amber);background:#f59e0b1f;font-weight:600}.patio-svg-wrap{border-radius:var(--radius);background:#0000004d;border:1px solid #00d1c140;margin-bottom:16px;position:relative;overflow:hidden}.patio-svg-wrap svg{width:100%;display:block}.hero-result{text-align:center;border-radius:var(--radius);background:linear-gradient(135deg,#00d1c114,#00f3ff0a);border:1px solid #00d1c133;margin-bottom:16px;padding:22px}.hero-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-size:.75rem}.hero-value{color:var(--accent);font-size:2.4rem;font-weight:800;line-height:1.1}.hero-sub{color:var(--text-secondary);margin-top:5px;font-size:.84rem}.stat-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}@media (width<=600px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--purple);border-radius:var(--radius);padding:12px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.68rem}.stat-value{color:var(--text-primary);font-size:1rem;font-weight:700}.formula-strip{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.formula-pill{color:var(--accent);white-space:nowrap;background:#00d1c114;border:1px solid #00d1c140;border-radius:20px;padding:5px 13px;font-size:.73rem}.donut-wrap{border:1px solid var(--border);border-radius:var(--radius);background:#0003;margin-bottom:14px;padding:14px 16px}.donut-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:.75rem;font-weight:600}.alert-stack{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.alert{border-left:3px solid;border-radius:8px;padding:10px 14px;font-size:.83rem;line-height:1.45}.alert-success{border-color:var(--green);color:#6ee7b7;background:#10b98114}.alert-info{color:#7fffd4;background:#00d1c112;border-color:#00d1c1}.alert-warn{border-color:var(--amber);color:#fcd34d;background:#f59e0b14}.alert-danger{border-color:var(--red);color:#fca5a5;background:#ef444414}.data-table{border-collapse:collapse;width:100%;font-size:.86rem}.data-table th{color:var(--accent);text-align:left;border-bottom:1px solid var(--border);background:#00d1c114;padding:10px 14px;font-weight:600}.data-table td{color:var(--text-secondary);vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:9px 14px}.data-table tr:hover td{background:#ffffff05}.section-heading{margin:0 0 16px}.section-heading h2{margin-bottom:4px;font-size:1.2rem;font-weight:700}.section-heading p{color:var(--text-secondary);font-size:.85rem}.cur-cell-note{color:var(--accent);font-weight:600}.scenario-cards{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px;display:grid}@media (width<=700px){.scenario-cards{grid-template-columns:minmax(0,1fr);overflow:hidden}}.scenario-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:border-color .2s}.scenario-card--active{border-color:var(--accent);background:#00d1c10a}.sc-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.sc-icon{font-size:1.3rem}.sc-label{font-size:.95rem;font-weight:700}.delta{border-radius:12px;margin-left:auto;padding:2px 7px;font-size:.75rem;font-weight:700}.delta-up{color:#fca5a5;background:#ef444426}.delta-down{color:#6ee7b7;background:#10b98126}.sc-material{color:var(--text-muted);margin-bottom:6px;font-size:.8rem}.sc-total{font-size:1.7rem;font-weight:800;line-height:1.1}.sc-costsf{color:var(--text-secondary);margin-bottom:10px;font-size:.82rem}.sc-stats{flex-wrap:wrap;gap:12px;margin-bottom:8px;display:flex}.sc-stats span{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a;border-radius:6px;padding:3px 8px;font-size:.78rem}.sc-desc{color:var(--text-muted);font-size:.75rem;font-style:italic}.matrix-wrap{margin-bottom:32px;overflow-x:auto}.matrix-table{border-collapse:collapse;width:100%;font-size:.82rem}.matrix-table th{color:var(--accent);text-align:center;border:1px solid var(--border);background:#00d1c114;padding:8px 12px;font-weight:600}.matrix-table td.matrix-cell{text-align:center;color:var(--text-secondary);border:1px solid #ffffff0a;padding:8px 12px;font-weight:500;transition:opacity .15s}.matrix-cell--current{outline:2px solid var(--accent);outline-offset:-2px;color:#fff!important;font-weight:700!important}.mat-chart-outer{border:1px solid var(--border);border-radius:var(--radius);background:#0003;margin-bottom:8px;padding:16px}.proj-chart-card{border:1px solid var(--border);border-radius:var(--radius);background:#0003;margin-bottom:20px;padding:16px}.cost-range-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width<=600px){.cost-range-row{grid-template-columns:minmax(0,1fr);overflow:hidden}}.cost-range-card{text-align:center;border-radius:var(--radius);border:1px solid;padding:18px 12px}.cost-range-card--low{background:#10b98112;border-color:#10b9814d}.cost-range-card--est{background:#00d1c112;border-color:#00d1c159}.cost-range-card--high{background:#f59e0b12;border-color:#f59e0b4d}.cr-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:.72rem}.cr-value{margin-bottom:4px;font-size:1.6rem;font-weight:800}.cost-range-card--low .cr-value{color:var(--green)}.cost-range-card--est .cr-value{color:var(--accent)}.cost-range-card--high .cr-value{color:var(--amber)}.cr-note{color:var(--text-muted);font-size:.74rem}.proj-cards-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}@media (width<=700px){.proj-cards-row{grid-template-columns:minmax(0,1fr);overflow:hidden}}.proj-card-title{color:var(--accent);margin-bottom:14px;font-size:.88rem;font-weight:700}.timeline-content{flex-direction:column;gap:10px;display:flex}.tl-phase{color:var(--text-secondary);align-items:flex-start;gap:10px;font-size:.83rem;display:flex}.tl-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-top:4px}.tl-amber{background:var(--amber)}.tl-cyan{background:var(--accent)}.tl-purple{background:var(--purple)}.tl-green{background:var(--green)}.tl-total{color:var(--text-primary);border-top:1px solid var(--border);margin-top:4px;padding-top:10px;font-size:.85rem;font-weight:600}.roi-content{flex-direction:column;gap:10px;display:flex}.roi-stat{justify-content:space-between;align-items:center;display:flex}.roi-label{color:var(--text-secondary);font-size:.82rem}.roi-val{font-size:1rem;font-weight:700}.roi-val.green{color:var(--green)}.roi-note{color:var(--text-muted);border-top:1px solid var(--border);padding-top:10px;font-size:.77rem;line-height:1.5}.toast{z-index:9999;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);opacity:0;border-radius:10px;max-width:320px;padding:12px 18px;font-size:.87rem;line-height:1.45;transition:transform .3s,opacity .3s;position:fixed;bottom:24px;right:24px;transform:translateY(20px);box-shadow:0 8px 24px #0006}.toast--visible{opacity:1;transform:translateY(0)}.toast-success{border-left:3px solid var(--green)}.toast-warn{border-left:3px solid var(--amber)}.toast-error{border-left:3px solid var(--red)}.faq-list{flex-direction:column;display:flex}.faq-item{border-bottom:1px solid #ffffff0f}.faq-item__question{cursor:pointer;color:var(--text-primary);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:"+";color:var(--text-muted);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(--accent)}.faq-item__answer{color:var(--text-secondary);padding:0 4px 14px;font-size:.85rem;line-height:1.75}@media (width<=768px){.main-container{padding:16px}.calc-title{font-size:1.5rem}.tab-btn{padding:8px 12px;font-size:.81rem}}[data-theme=light]{--bg-app:#e8edf5;--bg-card:#fff;--bg-input:#f0f4f9;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--cyan:#0e7490;--purple:#7c3aed;--green:#059669;--red:#dc2626;--amber:#d97706;--border:#0000001a;--accent:#0e7490}[data-theme=light] .card{background:#fff;border-color:#0000001a;box-shadow:0 2px 10px #00000012}[data-theme=light] .form-input,[data-theme=light] .form-select{color:#0f172a;background:#fff;border-color:#0000001f}[data-theme=light] .form-input:focus,[data-theme=light] .form-select:focus{border-color:#0e7490}[data-theme=light] .form-select option{background:#fff}[data-theme=light] input,[data-theme=light] select{color-scheme:light}[data-theme=light] .form-input::placeholder{color:#00000061}[data-theme=light] .mat-chip{color:#334155;background:#f0f4f9;border-color:#0000001f}[data-theme=light] .mat-chip:hover{color:#0e7490;border-color:#0e749066}[data-theme=light] .mat-chip.active{color:#0e7490;background:#0e74901a;border-color:#0e7490}[data-theme=light] .mat-note{color:#64748b}[data-theme=light] .shape-chip{color:#334155;background:#f0f4f9;border-color:#0000001f}[data-theme=light] .shape-chip:hover{color:#0e7490;border-color:#0e749066}[data-theme=light] .shape-chip.active{color:#0e7490;background:#0e74901a;border-color:#0e7490}[data-theme=light] .labor-btn{color:#334155;background:#f0f4f9;border-color:#0000001f}[data-theme=light] .labor-btn.active{color:#0e7490;background:#0e74901a;border-color:#0e7490}[data-theme=light] .depth-chip{color:#334155;background:#f0f4f9;border-color:#0000001f}[data-theme=light] .depth-chip.active{color:#d97706;background:#d977061a;border-color:#d97706}[data-theme=light] .patio-svg-wrap{background:#edf2f9;border-color:#0e749040}[data-theme=light] .hero-result{background:linear-gradient(135deg,#0e74900f,#0e749008);border-color:#0e749033}[data-theme=light] .hero-value{text-shadow:none}[data-theme=light] .stat-card{background:#edf2f9;border-color:#0000001a #0000001a #0000001a #7c3aed;box-shadow:0 1px 4px #0000000d}[data-theme=light] .formula-pill{color:#0e7490;background:#0e749014;border-color:#0e749040}[data-theme=light] .donut-wrap{background:#edf2f9;border-color:#00000014}[data-theme=light] .donut-title{color:#64748b}[data-theme=light] .tab-nav{background:0 0;border-bottom-color:#0000001a}[data-theme=light] .tab-btn{color:#475569}[data-theme=light] .tab-btn:hover{color:#0f172a}[data-theme=light] .tab-btn.active{color:#0e7490;border-bottom-color:#0e7490}[data-theme=light] .alert-success{color:#065f46;background:#f0fdf4;border-color:#05966966}[data-theme=light] .alert-info{color:#0e7490;background:#eff9fb;border-color:#0e749066}[data-theme=light] .alert-warn{color:#b45309;background:#fffbeb;border-color:#d9770666}[data-theme=light] .alert-danger{color:#dc2626;background:#fff1f2;border-color:#dc262659}[data-theme=light] .data-table th{color:#0e7490;background:#0e749012;border-bottom-color:#0000001a}[data-theme=light] .data-table td{color:#334155;border-bottom-color:#0000000f}[data-theme=light] .data-table tr:hover td{background:#00000008}[data-theme=light] .section-heading h2{color:#0f172a}[data-theme=light] .section-heading p{color:#64748b}[data-theme=light] .scenario-card{background:#fff;border-color:#0000001a;box-shadow:0 1px 4px #0000000f}[data-theme=light] .scenario-card--active{background:#0e74900a;border-color:#0e7490}[data-theme=light] .sc-stats span{color:#334155;background:#edf2f9;border-color:#0000001a}[data-theme=light] .matrix-table th{color:#0e7490;background:#0e749012;border-color:#0000001a}[data-theme=light] .matrix-table td.matrix-cell{color:#0f172a;border-color:#0000000f}[data-theme=light] .matrix-cell--current{outline-color:#0e7490}[data-theme=light] .mat-chart-outer,[data-theme=light] .proj-chart-card{background:#edf2f9;border-color:#00000014}[data-theme=light] .cost-range-card--low{background:#f0fdf4;border-color:#0596694d}[data-theme=light] .cost-range-card--est{background:#eff9fb;border-color:#0e74904d}[data-theme=light] .cost-range-card--high{background:#fffbeb;border-color:#d977064d}[data-theme=light] .cr-label{color:#64748b}[data-theme=light] .cr-note{color:#94a3b8}[data-theme=light] .cost-range-card--low .cr-value{color:#059669}[data-theme=light] .cost-range-card--est .cr-value{color:#0e7490}[data-theme=light] .cost-range-card--high .cr-value{color:#d97706}[data-theme=light] .proj-card-title{color:#0e7490}[data-theme=light] .tl-phase{color:#475569}[data-theme=light] .tl-total{color:#0f172a;border-top-color:#0000001a}[data-theme=light] .roi-label{color:#475569}[data-theme=light] .roi-note{color:#64748b;border-top-color:#0000001a}[data-theme=light] .toast{color:#0f172a;background:#fff;border-color:#0000001f;box-shadow:0 8px 24px #0000001f}[data-theme=light] .toast-success{border-left-color:#059669}[data-theme=light] .toast-warn{border-left-color:#d97706}[data-theme=light] .toast-error{border-left-color:#dc2626}[data-theme=light] .faq-list{gap:8px}[data-theme=light] .faq-item{background:#fff;border:1px solid #0000001a;border-radius:10px;overflow:hidden;box-shadow:0 1px 4px #0000000f}[data-theme=light] .faq-item:hover{border-color:#0e74904d}[data-theme=light] .faq-item[open]{border-color:#0e749066 #0e749066 #0e749066 #0e7490;border-left-style:solid;border-left-width:3px}[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:#0e7490}[data-theme=light] .faq-item__answer{color:#475569;border-top:1px solid #0000000f;padding:12px 16px 16px}[data-theme=light] .ob-card{background:#fff;border-color:#0e749033}[data-theme=light] .ob-num{color:#0e7490;opacity:.5}[data-theme=light] .ob-card h3{color:#0f172a}[data-theme=light] .ob-card p{color:#475569}[data-theme=light] .fp2{background:#7c3aed0f;border-color:#7c3aed33}[data-theme=light] .fp2-label{color:#7c3aed}[data-theme=light] .fp2-desc{color:#475569}[data-theme=light] .g-item2{background:#fff;border-color:#0000001a}[data-theme=light] .g-item2 dt{color:#0e7490}[data-theme=light] .g-item2 dd{color:#475569}[data-theme=light] .ex-card2{background:#fff;border-color:#0000001a}[data-theme=light] .ex-card2 h3{color:#0f172a}[data-theme=light] .ex-card2 p{color:#475569}[data-theme=light] .ex-badge2{color:#0e7490;background:#0e74901a}[data-theme=light] .rel-card2{background:#fff;border-color:#0000001a}[data-theme=light] .rel-card2:hover{background:#0e74900a;border-color:#0e749059}[data-theme=light] .rc-title2{color:#0f172a}[data-theme=light] .rc-desc2{color:#64748b}[data-theme=light] .act-btn2{color:#334155;background:#edf2f9;border-color:#0000001f}[data-theme=light] .act-btn2:hover{color:#0e7490;background:#0e749014;border-color:#0e74904d}[data-theme=light] .article-body2{color:#475569}[data-theme=light] .article-body2 h3{color:#0f172a}[data-theme=light] .breadcrumb a{color:#64748b}.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}.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,#88a);align-items:flex-start;gap:1rem;font-size:.9rem;line-height:1.7;display:flex}.how-num{background:var(--cyan,#00f3ff);color:#050510;font-family:var(--font-mono,monospace);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,#fff)}.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,#ffffff0a);border:1px solid var(--border,#ffffff1a);color:var(--text-dim,#88a);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,#fff)}@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}}