:root{--bg-primary: #f7f9fb;--bg-secondary: #ffffff;--bg-tertiary: #e6e8ea;--text-primary: #191c1e;--text-secondary: #49454f;--text-muted: #757575;--accent-primary: #a7f3d0;--accent-secondary: #e2e8f0;--accent-hover: #6ee7b7;--accent-success: #10B981;--accent-warning: #855300;--accent-danger: #EF4444;--border-color: rgba(25, 28, 30, .12);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--shadow-sm: 0 2px 4px rgba(15, 23, 42, .02);--shadow-md: 0 4px 12px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .06);--font-family: "Inter", system-ui, -apple-system, sans-serif}body{margin:0;font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.container{max-width:1200px;margin:0 auto;padding:2rem}.header{margin-bottom:2rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.header p{color:var(--text-muted);margin-top:.5rem}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.card-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.form-group{margin-bottom:1rem}label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}input[type=text],input[type=number],select{width:100%;padding:.75rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:border-color .2s;box-sizing:border-box}input:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#0f172a;border:1px solid rgba(255,255,255,.5);box-shadow:0 2px 4px #0000000d,inset 0 1px #fff9}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent-secondary) 100%);box-shadow:0 4px 6px #00000014,inset 0 1px #fff9;transform:translateY(-1px)}.btn-icon{padding:.5rem;border-radius:50%}.btn-sm{padding:.25rem .5rem;font-size:.875rem}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-color)}.btn-outline-danger{background-color:transparent;border:1px solid var(--accent-danger);color:var(--accent-danger)}.btn-outline-danger:hover{background-color:var(--accent-danger);color:#fff}.stage-builder-controls{display:flex;gap:1rem;align-items:flex-end;margin-bottom:2rem;background:var(--bg-secondary);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.stage-list{display:grid;gap:1.5rem}.summary-panel{position:sticky;top:2rem;height:max-content}.grid-layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem}@media(max-width:768px){.grid-layout{grid-template-columns:1fr}}.printable-report,.print-page-footer{display:none}@media print{@page{margin:1.5cm 1.5cm 2cm;size:A4}html,body,#root,.project-view-container,.printable-report{height:auto!important;overflow:visible!important;position:static!important}body{background-color:#fff!important;color:#000!important;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:10pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}.container,.header,.stage-builder-controls,.stage-list,.summary-panel,.btn,.footer{display:none!important}.printable-report,.grid-layout{display:block!important}.report-header{text-align:center;border-bottom:2px solid #333;padding-bottom:1rem;margin-bottom:2rem}.report-header h1{font-size:20pt;margin:0;text-transform:uppercase;letter-spacing:1px}.report-meta{margin-top:.5rem;font-size:10pt;color:#555}.report-section{margin-bottom:2rem;page-break-inside:avoid}.section-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #ccc;margin-bottom:.5rem;padding:.5rem;background-color:#f5f5f5!important;border-radius:4px}.section-header h2{font-size:12pt;margin:0;font-weight:700}.section-total{font-weight:700;font-size:12pt}.report-table{width:100%;border-collapse:collapse;font-size:10pt;margin-top:.5rem}.report-table th{border-bottom:2px solid #ddd;text-align:left;padding:.25rem .5rem;font-weight:700;color:#444}.report-table td{border-bottom:1px solid #eee;padding:.25rem .5rem}.report-footer{margin-top:3rem;text-align:right;page-break-inside:avoid}.grand-total-box{display:inline-block;border:2px solid #333;padding:1rem 2rem;background-color:#fff!important;border-radius:8px}.grand-total-box span{display:block;font-size:9pt;text-transform:uppercase;color:#666;margin-bottom:.25rem}.grand-total-box strong{display:block;font-size:18pt}.disclaimer{margin-top:2rem;font-size:8pt;color:#888;text-align:center;font-style:italic}.no-materials{font-style:italic;color:#999;padding:.5rem}.report-container-table{width:100%;border-collapse:collapse;border:none}.report-container-table td{padding:0;border:none}thead{display:table-header-group}tfoot{display:table-footer-group}.footer-spacer{height:50px}.print-page-footer{position:fixed;bottom:10px;left:0;right:0;text-align:center;font-size:9pt;color:#888;background:transparent;display:block!important;z-index:9999}}@media screen{.print-page-footer{display:none}}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background-color:var(--bg-secondary);padding:2.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:90%;text-align:center;animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}.modal-message{color:var(--text-primary);font-size:1.25rem;line-height:1.6;margin-bottom:2rem;font-weight:500}.modal-actions{display:flex;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.project-view-container{height:100%;width:100%}.footer{margin-top:4rem;padding:2rem 0;border-top:1px solid var(--border-color);background-color:transparent}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;color:var(--text-muted);font-size:.875rem}.footer-left{justify-self:start}.footer-center{justify-self:center;text-align:center}.footer-right{justify-self:end}.footer-link{color:var(--text-muted);text-decoration:none;transition:color .2s ease;display:inline-flex;align-items:center;gap:.5rem}.footer-link:hover{color:var(--text-primary)}@media(max-width:768px){.footer-content{grid-template-columns:1fr;justify-items:center;text-align:center;gap:1.5rem}.footer-left,.footer-center,.footer-right{justify-self:center}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 1.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.app-header-brand{display:flex;align-items:center;gap:1rem}.app-header-icon{font-size:2rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}.app-header-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .2rem;letter-spacing:-.01em}.app-header-subtitle{font-size:.8rem;font-weight:500;color:var(--text-muted);margin:0;text-transform:uppercase;letter-spacing:.05em}.stage-builder-controls{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem;background:var(--bg-secondary);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.stage-builder-label{display:block;font-size:.7rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}.stage-builder-select{width:100%;padding:.625rem 2.5rem .625rem .875rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-weight:500;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23757575' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center}.stage-builder-select:focus{outline:none;border-color:var(--accent-hover);box-shadow:0 0 0 3px #6ee7b740}.stage-builder-btn{white-space:nowrap;height:2.75rem;padding:0 1.5rem;border-radius:var(--radius-lg);font-size:.9375rem;display:flex;align-items:center;gap:.5rem}.empty-state{padding:2.5rem 2rem;border:2px dashed var(--border-color);background:var(--bg-secondary);text-align:center}.empty-state-header{margin-bottom:2rem}.empty-state-title{color:var(--text-primary);font-size:1.375rem;font-weight:700;margin:0 0 .5rem;letter-spacing:-.01em}.empty-state-desc{color:var(--text-muted);font-size:.9rem;margin:0}.empty-state-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;text-align:left}.empty-state-step{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.empty-state-step-num{width:2.25rem;height:2.25rem;flex-shrink:0;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:var(--text-primary);box-shadow:var(--shadow-sm)}.empty-state-step-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.empty-state-step-desc{font-size:.8125rem;color:var(--text-muted);margin:0;line-height:1.5}.empty-state-fade-in{animation:emptyFadeSlideDown .6s ease-out both}.empty-state-typewriter{min-height:1.5em;color:var(--text-muted);font-size:.9rem;margin:0}.typing-cursor{display:inline-block;width:2px;height:1em;background:var(--accent-success);margin-left:2px;vertical-align:text-bottom;animation:cursorBlink .7s step-end infinite}.step-hidden{opacity:0;transform:translateY(20px)}.step-visible{opacity:1;transform:translateY(0);transition:opacity .5s ease-out,transform .5s ease-out}@keyframes emptyFadeSlideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.card{background-color:var(--bg-secondary);border:none;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1.5rem;transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-lg)}.card-title-left{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:0}.collapse-toggle{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:.9rem;padding:.15rem .25rem;flex-shrink:0;transition:transform .2s;line-height:1}.card-title-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.card-title-name{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.card-title-cost{font-size:.85rem;font-weight:500;color:var(--text-muted)}.card-title-actions{flex-shrink:0}.btn-delete{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);font-size:.8125rem;font-weight:500;padding:.3rem .75rem;border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.btn-delete:hover{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:transparent;box-shadow:0 2px 4px #0000000d}.delete-confirm{display:flex;flex-direction:column;align-items:flex-end;gap:.375rem}.delete-confirm-text{font-size:.8125rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.delete-confirm-buttons{display:flex;gap:.375rem}.btn-danger{background-color:var(--accent-danger);color:#fff;border:none;cursor:pointer;transition:background-color .15s,transform .15s}.btn-danger:hover{background-color:#dc2626;transform:translateY(-1px)}.btn-icon-confirm,.btn-icon-cancel{width:2rem;height:2rem;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;cursor:pointer;transition:all .2s;border:1px solid var(--border-color);background:var(--bg-secondary);padding:0}.btn-icon-confirm{color:var(--accent-success)}.btn-icon-confirm:hover{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:transparent;box-shadow:0 2px 4px #00000014;transform:translateY(-1px)}.btn-icon-cancel{color:var(--text-muted)}.btn-icon-cancel:hover{background-color:var(--accent-danger);color:#fff;border-color:transparent;box-shadow:0 2px 4px #00000014;transform:translateY(-1px)}.btn-add{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-add:hover{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:transparent;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}@media(max-width:768px){.container{padding:1rem 1rem 5rem}.grid-layout{grid-template-columns:1fr;gap:1rem}.summary-panel{position:static}.app-header{padding:1rem 0 .875rem;margin-bottom:1rem}.app-header-icon{font-size:1.5rem}.app-header-title{font-size:1.125rem}.app-header-subtitle{font-size:.7rem}.stage-builder-controls{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem}.stage-builder-btn{width:100%;height:3rem;justify-content:center;border-radius:var(--radius-lg);font-size:1rem}.stage-builder-select{font-size:1rem;height:3rem}.empty-state{padding:2rem 1.25rem}.empty-state-steps{grid-template-columns:1fr;gap:1rem}.empty-state-step{padding:1rem}.card{padding:1.25rem;margin-bottom:1rem}.card-title{flex-wrap:wrap;gap:.5rem;font-size:1rem}.card-title-name{font-size:1.05rem}.card-title-cost{font-size:.8rem}.stage-list{gap:1rem}.footer{margin-top:2rem;padding:1.5rem 0}.footer-content{grid-template-columns:1fr;justify-items:center;text-align:center;gap:1rem}.footer-left,.footer-center,.footer-right{justify-self:center}}.stage-notice{display:flex;align-items:flex-start;gap:.5rem;background:linear-gradient(135deg,#a7f3d026,#e2e8f033);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;margin-bottom:1.25rem;font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.stage-notice strong{color:var(--text-primary)}.section-label{display:flex;align-items:center;justify-content:space-between;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);margin:1.25rem 0 .5rem}.section-label:first-child{margin-top:0}.section-label span{font-size:.7rem;font-weight:600;color:var(--accent-hover);text-transform:none;letter-spacing:0}.input-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-md);margin-bottom:1rem}.input-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.input-card-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.input-readonly{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.625rem .875rem;color:var(--text-muted);font-size:.9375rem;font-weight:500;height:2.75rem;display:flex;align-items:center;box-sizing:border-box;width:100%}.data-row-header,.data-row{display:grid;gap:.5rem}.data-row-header{margin-bottom:.3rem}.data-row-header small{color:var(--text-muted);font-weight:500;font-size:.75rem}.data-row{margin-bottom:.5rem;align-items:center}.data-row-header.cols-wide,.data-row.cols-wide{grid-template-columns:2fr 1fr 1fr auto}.data-row-header.cols-equal,.data-row.cols-equal{grid-template-columns:1fr 1fr 1fr auto}.mobile-label{display:none}.price-accordion{margin-top:1rem;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color)}.price-accordion-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-primary);border:none;cursor:pointer;color:var(--text-secondary);font-size:.8125rem;font-weight:500;text-align:left;transition:background .15s}.price-accordion-toggle:hover{background:var(--bg-tertiary)}.price-accordion-toggle-icon{transition:transform .2s;display:inline-block;font-size:.75rem;color:var(--text-muted)}.price-accordion-toggle-icon.open{transform:rotate(180deg)}.price-accordion-body{padding:1rem;background:var(--bg-secondary);display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.price-accordion-note{grid-column:1 / -1}.price-accordion-body label{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem;font-weight:500}.custom-materials{margin-top:1.25rem;border-top:1px dashed var(--border-color);padding-top:1rem}.custom-materials-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0}.custom-materials-toggle{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;font-weight:500;padding:0;transition:color .15s}.custom-materials-toggle:hover{color:var(--text-primary)}.custom-materials-badge{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--text-primary);border-radius:999px;padding:.1rem .5rem;font-size:.7rem;font-weight:600}.custom-materials-grid-header{display:grid;grid-template-columns:2fr 1fr 90px 1fr auto;gap:.5rem;margin-bottom:.375rem;margin-top:.75rem}.custom-materials-total{text-align:right;margin-top:.5rem;font-size:.8125rem;color:var(--text-muted)}.openings-total{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.openings-total-label{font-size:.8125rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.openings-total-value{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap}@media(max-width:768px){.input-card{padding:1rem}.input-card-grid,.input-card-grid-3{grid-template-columns:1fr}.data-row-header.cols-wide{display:none}.data-row.cols-wide{grid-template-columns:1fr 1fr auto}.data-row.cols-wide>select{grid-column:1 / -1}.mobile-label{display:block;font-size:.7rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.15rem}.price-accordion-body{grid-template-columns:1fr}.custom-materials-grid-header,.custom-materials-row{display:none}.custom-material-card{display:block}}.custom-material-card{display:none}.custom-materials-row{display:grid;grid-template-columns:2fr 1fr 90px 1fr auto;gap:.5rem;margin-bottom:.375rem;align-items:center}.cm-label{display:block;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem}.custom-material-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.875rem;margin-bottom:.75rem}.custom-material-card-name{margin-bottom:.75rem}.custom-material-card-row{display:grid;grid-template-columns:1fr 80px 1fr;gap:.625rem;margin-bottom:.75rem}.custom-material-card-delete{width:100%;justify-content:center;font-size:.8rem}@media(max-width:768px){.custom-materials-grid-header,.custom-materials-row{display:none!important}.custom-material-card{display:block!important}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;width:3rem;height:3rem;background-color:var(--accent-primary);color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:9999;opacity:0;pointer-events:none;transform:translateY(20px);transition:all .3s ease-in-out}.scroll-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-to-top:hover{background-color:var(--accent-hover);transform:scale(1.1)}@media print{.scroll-to-top{display:none!important}}
