@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg-base: #F0F2F5;--bg-subtle: #F5F7FA;--bg-surface: #FFFFFF;--bg-card: #FFFFFF;--bg-elevated: #F5F7FA;--text-primary: #111827;--text-secondary: #4B5563;--text-muted: #9CA3AF;--border-subtle: #E5E7EB;--border-medium: #D1D5DB;--brand-primary: #4F46E5;--brand-primary-dark: #4338CA;--brand-primary-light: #EEF2FF;--brand-accent: #10B981;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--info: #4F46E5;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg: 0 10px 25px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.05);--shadow-brand: 0 4px 14px rgba(79,70,229,.24);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--radius-sm: 6px;--radius: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-base: "Inter", system-ui, -apple-system, sans-serif;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 30px;--transition-fast: .15s ease;--transition-base: .2s ease;--nav-height: 60px;--header-height: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--text-base);scroll-behavior:smooth}body{font-family:var(--font-base);background:var(--bg-base);color:var(--text-primary);min-height:100dvh;-webkit-font-smoothing:antialiased;overscroll-behavior:none}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}img{max-width:100%;display:block}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.page-content{flex:1;padding:var(--sp-4);padding-top:calc(var(--header-height) + var(--sp-5));padding-bottom:calc(var(--nav-height) + var(--sp-6));max-width:680px;margin:0 auto;width:100%}@media(min-width:768px){.app-shell{flex-direction:row}.page-content{max-width:1200px;padding-left:calc(240px + var(--sp-6));padding-top:calc(var(--header-height) + var(--sp-6));padding-bottom:var(--sp-8)}}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-4);z-index:100}@media(min-width:768px){.header{width:100%;margin-left:0;padding-left:calc(240px + var(--sp-4));z-index:90}}.header-logo{display:flex;align-items:center;gap:var(--sp-2)}.header-logo-icon{width:32px;height:32px;background:var(--brand-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff}.header-logo-text{font-weight:800;font-size:var(--text-md);color:var(--brand-primary);letter-spacing:-.5px}.header-title{font-size:var(--text-sm);font-weight:500;color:var(--text-muted)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-subtle);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;border:none;background:transparent;color:var(--text-muted);font-size:10px;font-weight:600;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;letter-spacing:.3px}.nav-item .nav-icon{width:40px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background var(--transition-fast),color var(--transition-fast)}.nav-item.active{color:var(--brand-primary)}.nav-item.active .nav-icon{background:var(--brand-primary-light);color:var(--brand-primary)}.nav-item:hover:not(.active){color:var(--text-secondary)}@media(min-width:768px){.bottom-nav{inset:0 auto 0 0;width:240px;height:100dvh;border-top:none;border-right:1px solid var(--border-subtle);flex-direction:column;justify-content:flex-start;padding:var(--sp-6) var(--sp-4);padding-top:calc(var(--header-height) + var(--sp-6));gap:var(--sp-2);z-index:95}.nav-item{flex:none;flex-direction:row;justify-content:flex-start;padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600}.nav-item:hover{background:var(--bg-elevated)}.nav-item.active{background:var(--brand-primary-light)}.nav-item .nav-icon{background:transparent!important;margin-right:var(--sp-3);width:24px;height:24px}}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-5);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.card:hover{border-color:var(--border-medium)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}.card-title{font-size:var(--text-md);font-weight:700;letter-spacing:-.3px;color:var(--text-primary)}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:10px var(--sp-5);border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);border:none;cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--brand-primary);color:#fff;box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 6px 18px #4f46e54d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-success{background:var(--brand-accent);color:#fff;box-shadow:0 4px 12px #10b98138}.btn-success:hover:not(:disabled){background:#0da572;transform:translateY(-1px)}.btn-danger{background:#fef2f2;color:var(--danger);border:1px solid #FECACA}.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.btn-ghost{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-subtle)}.btn-ghost:hover:not(:disabled){background:var(--bg-subtle);color:var(--text-primary);border-color:var(--border-medium)}.btn-icon{padding:var(--sp-2);width:36px;height:36px;border-radius:var(--radius-md);flex-shrink:0}.btn-full{width:100%}.btn-lg{padding:13px var(--sp-6);font-size:var(--text-base);font-weight:700}.fab{position:fixed;bottom:calc(var(--nav-height) + var(--sp-4));right:var(--sp-5);width:52px;height:52px;border-radius:var(--radius-lg);background:var(--brand-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-brand),var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);z-index:50;-webkit-tap-highlight-color:transparent}.fab:hover{transform:scale(1.06);background:var(--brand-primary-dark);box-shadow:0 6px 20px #4f46e559}.fab:active{transform:scale(.95)}.form-group{margin-bottom:var(--sp-4)}.form-label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:var(--sp-2);text-transform:uppercase;letter-spacing:.7px}.form-input{width:100%;background:var(--bg-surface);border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);padding:11px var(--sp-4);color:var(--text-primary);font-size:var(--text-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;appearance:none}.form-input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #4f46e51a}.form-input::placeholder{color:var(--text-muted)}.form-input.error{border-color:var(--danger)}.form-error{font-size:var(--text-xs);color:var(--danger);margin-top:var(--sp-1);display:flex;align-items:center;gap:4px;font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--sp-1);line-height:1.5}select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239CA3AF' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}select.form-input option{background:#fff;color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.badge-primary{background:var(--brand-primary-light);color:var(--brand-primary)}.badge-success{background:#ecfdf5;color:#059669}.badge-warning{background:#fffbeb;color:#b45309}.badge-danger{background:#fef2f2;color:#b91c1c}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}.section-title{font-size:var(--text-lg);font-weight:800;letter-spacing:-.4px;color:var(--text-primary)}.section-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.divider{height:1px;background:var(--border-subtle);margin:var(--sp-5) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-12) var(--sp-6);gap:var(--sp-4)}.empty-icon{width:64px;height:64px;background:var(--brand-primary-light);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--brand-primary)}.empty-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.empty-desc{font-size:var(--text-sm);color:var(--text-secondary);max-width:240px;line-height:1.6}.modal-overlay{position:fixed;inset:0;background:#11182766;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}@media(min-width:480px){.modal-overlay{align-items:center}}.modal-sheet{background:var(--bg-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--sp-6);width:100%;max-width:520px;max-height:90dvh;overflow-y:auto;animation:slideUp .24s ease;border:1px solid var(--border-subtle);border-bottom:none;box-shadow:var(--shadow-lg)}@media(min-width:480px){.modal-sheet{border-radius:var(--radius-xl);border:1px solid var(--border-medium)}}.modal-handle{width:36px;height:4px;background:var(--border-medium);border-radius:var(--radius-full);margin:0 auto var(--sp-5)}.modal-title{font-size:var(--text-lg);font-weight:800;margin-bottom:var(--sp-5);letter-spacing:-.3px;color:var(--text-primary)}.tabs{display:flex;background:var(--bg-elevated);border-radius:var(--radius-md);padding:4px;gap:4px;margin-bottom:var(--sp-5);border:1px solid var(--border-subtle)}.tab-item{flex:1;padding:8px var(--sp-3);border-radius:7px;font-size:var(--text-sm);font-weight:600;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);text-align:center;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:var(--sp-2)}.tab-item.active{background:var(--bg-surface);color:var(--brand-primary);box-shadow:var(--shadow-sm);font-weight:700}.cost-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm)}.cost-row:last-child{border-bottom:none}.cost-row-label{color:var(--text-secondary);display:flex;align-items:center;gap:var(--sp-2)}.cost-row-value{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary)}.cost-total{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);background:var(--brand-primary-light);border-radius:var(--radius-lg);border:1px solid #C7D2FE;margin-top:var(--sp-4)}.cost-total-label{font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.cost-total-value{font-size:var(--text-xl);font-weight:800;color:var(--brand-primary);font-variant-numeric:tabular-nums}.quote-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-5);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.quote-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--brand-primary)}.quote-card.status-final:before{background:var(--brand-accent)}.quote-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.quote-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-left:var(--sp-3)}.quote-client{font-weight:700;font-size:var(--text-base);color:var(--text-primary)}.quote-project{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.quote-meta{display:flex;gap:var(--sp-4);margin-top:var(--sp-3);margin-left:var(--sp-3)}.quote-meta-item{font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;gap:5px}.piece-card{background:var(--bg-elevated);border:1.5px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-4);margin-bottom:var(--sp-3);position:relative;transition:border-color var(--transition-fast)}.piece-card:hover{border-color:var(--border-medium)}.piece-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-3)}.piece-number{width:24px;height:24px;background:var(--brand-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:800;color:#fff;flex-shrink:0}.sticky-bottom-bar{position:fixed;bottom:var(--nav-height);left:0;right:0;background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-subtle);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);z-index:80}.step-indicator{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-6)}.step-dot{width:30px;height:30px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;transition:all var(--transition-base);flex-shrink:0}.step-dot.done{background:var(--brand-accent);color:#fff}.step-dot.active{background:var(--brand-primary);color:#fff;box-shadow:0 0 0 4px #4f46e526}.step-dot.pending{background:var(--bg-surface);color:var(--text-muted);border:1.5px solid var(--border-medium)}.step-line{flex:1;height:2px;background:var(--border-subtle);border-radius:var(--radius-full)}.step-line.done{background:var(--brand-accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-fade{animation:fadeIn var(--transition-base) both}.animate-slide-up{animation:slideUp var(--transition-base) both}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-brand{color:var(--brand-primary)}.font-bold{font-weight:700}.font-mono{font-family:"ui-monospace",Courier New,monospace}.w-full{width:100%}.hidden{display:none!important}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}@media(min-width:480px){.page-content{padding:var(--sp-6);padding-top:calc(var(--header-height) + var(--sp-6));padding-bottom:calc(var(--nav-height) + var(--sp-8))}}@media(min-width:768px){.page-content{padding-left:calc(240px + var(--sp-6));padding-bottom:var(--sp-8)}.grid-desktop-2{display:grid;grid-template-columns:1fr;gap:var(--sp-6)}.grid-desktop-2>*{min-width:0}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-4)}.desktop-sticky-panel{position:sticky;top:calc(var(--header-height) + var(--sp-6));align-self:start;display:flex;flex-direction:column;gap:var(--sp-4)}.sticky-bottom-bar{position:static;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;align-items:stretch;padding:var(--sp-5)}.sticky-bottom-bar .btn-lg{width:100%;margin-top:var(--sp-3)}.mobile-only{display:none!important}.desktop-only{display:flex!important}}@media(max-width:767px){.desktop-only{display:none!important}}@media(min-width:1024px){.grid-desktop-2{grid-template-columns:2fr 1fr}.grid-desktop-1-2{display:grid;grid-template-columns:1.25fr 2fr;gap:var(--sp-6)}.grid-desktop-1-2>*{min-width:0}.grid-desktop-3{grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}}
