@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--bg-primary:#0a0a0a;--bg-secondary:#141414;--bg-card:#1c1c1cd9;--bg-card-solid:#1c1c1c;--bg-input:#242424;--bg-nav:#0a0a0af5;--accent:#2f8f3e;--accent-strong:#256e30;--accent-light:#7ed492;--accent-dim:#2f8f3e1a;--accent-glow:#2f8f3e26;--green:#34d399;--green-dim:#34d39914;--red:#f87171;--red-dim:#f8717114;--orange:#fb923c;--whatsapp:#25d366;--blue:#60a5fa;--grad-accent:linear-gradient(135deg, #2f8f3e, #1f6e2e);--grad-accent-soft:linear-gradient(135deg, #2f8f3e26, #1f6e2e0d);--grad-green:linear-gradient(135deg, #34d399, #10b981);--grad-whatsapp:linear-gradient(135deg, #25d366, #128c7e);--grad-card:linear-gradient(145deg, #2f8f3e0f, #1f6e2e05);--grad-hero:linear-gradient(180deg, #2f8f3e0f 0%, transparent 50%);--text-1:#f5f5f5;--text-2:#a8a8a8;--text-3:#6b6b6b;--border:#2f8f3e1f;--border-subtle:#ffffff0f;--shadow:0 4px 24px #0006;--glow:0 0 40px #2f8f3e0f;--r-sm:12px;--r-md:16px;--r-lg:20px;--r-xl:24px;--nav-h:72px;--header-h:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;font-size:16px}body{background:var(--bg-primary);color:var(--text-1);min-height:100dvh;padding-bottom:calc(var(--nav-h) + 24px);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");position:fixed;inset:0}#app{z-index:1;position:relative}.app-header{z-index:100;background:var(--bg-nav);-webkit-backdrop-filter:blur(24px)saturate(1.3);border-bottom:1px solid var(--border);height:var(--header-h);align-items:center;gap:14px;padding:0 20px;display:flex;position:sticky;top:0}.app-header .logo-icon{filter:drop-shadow(0 2px 6px #2f8f3e4d);font-size:30px;line-height:1}.app-header h1{background:linear-gradient(135deg,#2f8f3e,#7ed492);-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800}.header-tagline{color:var(--text-3);letter-spacing:.01em;margin-left:auto;font-size:.68rem;font-weight:500}.bottom-nav{z-index:200;background:var(--bg-nav);-webkit-backdrop-filter:blur(24px)saturate(1.3);border-top:1px solid var(--border);height:var(--nav-h);padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-btn{color:var(--text-3);cursor:pointer;letter-spacing:.03em;text-transform:uppercase;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;padding:8px 20px;font-family:inherit;font-size:.68rem;font-weight:600;transition:all .3s;display:flex;position:relative}.nav-btn .nav-icon{font-size:24px;line-height:1;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.nav-btn.active{color:var(--accent)}.nav-btn.active .nav-icon{transform:scale(1.2)translateY(-2px)}.nav-btn.active:after{content:"";background:var(--grad-accent);border-radius:0 0 6px 6px;width:36px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #2f8f3e4d}.nav-btn:active{transform:scale(.92)}.nav-badge{background:var(--red);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.62rem;font-weight:800;display:none;position:absolute;top:2px;right:6px;box-shadow:0 2px 6px #f8717166}.nav-badge.show{animation:.3s cubic-bezier(.175,.885,.32,1.275) popIn;display:flex}.tab-content{padding:20px 16px;animation:.4s cubic-bezier(.25,.46,.45,.94) fadeInUp;display:none}.tab-content.active{display:block}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes wallSlideIn{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:200px;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.section-title{letter-spacing:-.04em;background:linear-gradient(135deg, var(--text-1) 30%, var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:1.5rem;font-weight:900}.section-subtitle{color:var(--text-2);margin-bottom:28px;font-size:.85rem;line-height:1.6}.category-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-top:12px;margin-bottom:6px;padding:14px 0 10px;display:flex;position:relative}.category-header:after{content:"";background:var(--grad-accent);border-radius:1px;width:60px;height:2px;position:absolute;bottom:-1px;left:0}.category-icon{font-size:20px}.category-label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:.82rem;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);-webkit-backdrop-filter:blur(12px);margin-bottom:12px;padding:20px;transition:all .3s;position:relative;overflow:hidden}.card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000,#2f8f3e26,#0000);height:1px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.card:hover:before{opacity:1}.card:hover{border-color:var(--border);box-shadow:var(--glow)}.card-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.card-icon{border-radius:var(--r-sm);background:var(--grad-accent-soft);border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:22px;transition:transform .3s;display:flex}.card:hover .card-icon{transform:scale(1.05)}.card-title{color:var(--text-1);letter-spacing:-.01em;font-size:.95rem;font-weight:700}.card-unit{color:var(--text-3);margin-top:2px;font-size:.74rem;font-weight:500}.input-group{margin-bottom:12px}.input-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.76rem;font-weight:600;display:block}.input-field{background:var(--bg-input);border:1.5px solid var(--border-subtle);border-radius:var(--r-md);width:100%;color:var(--text-1);appearance:none;outline:none;padding:14px 16px;font-family:inherit;font-size:1.05rem;font-weight:600;transition:all .3s}.input-field::placeholder{color:var(--text-3);font-weight:400}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim), 0 0 20px #2f8f3e14;background:var(--bg-secondary)}.input-prefix{position:relative}.input-prefix .input-field{padding-left:44px}.input-prefix:before{content:"R$";color:var(--accent);z-index:1;font-size:.9rem;font-weight:700;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.service-selector{margin-bottom:20px}.service-grid{grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;display:grid}.service-chip{border:1.5px solid var(--border-subtle);border-radius:var(--r-md);background:var(--bg-card);color:var(--text-2);cursor:pointer;text-align:left;align-items:center;gap:10px;padding:13px 14px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.service-chip:before{content:"";background:var(--grad-accent-soft);opacity:0;transition:opacity .3s;position:absolute;inset:0}.service-chip:hover:before{opacity:.5}.service-chip .chip-icon{z-index:1;flex-shrink:0;font-size:20px;position:relative}.service-chip .chip-label{z-index:1;line-height:1.25;position:relative}.service-chip:active{transform:scale(.96)}.service-chip.active{border-color:var(--accent);background:var(--accent-dim);color:var(--text-1);box-shadow:0 0 20px #2f8f3e1a,inset 0 0 20px #2f8f3e08}.service-chip.active:before{opacity:1}.service-chip.active .chip-label{color:var(--accent);font-weight:700}.selected-service-info{background:var(--grad-accent-soft);border:1px solid var(--border);border-radius:var(--r-md);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:16px;padding:14px 18px;display:flex}.selected-service-name{color:var(--text-1);font-size:.9rem;font-weight:700}.selected-service-price{color:var(--accent);font-size:.82rem;font-weight:600}.calc-card{border-width:1.5px;border-color:#2f8f3e33}.calc-section-title{color:var(--text-1);margin-bottom:8px;font-size:1rem;font-weight:700}.dim-hint{color:var(--accent);opacity:.8;margin-bottom:12px;font-size:.78rem;font-weight:500}.wall-area-display{text-align:right;color:var(--text-3);margin-top:6px;padding-right:4px;font-size:.78rem;font-weight:600;transition:color .3s}.wall-area-display.has-value{color:var(--green)}.total-m2-bar{background:var(--green-dim);border-radius:var(--r-md);border:1.5px solid #34d3992e;justify-content:space-between;align-items:center;margin:16px 0 12px;padding:16px 18px;display:flex}.total-m2-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;font-weight:600}.total-m2-value{color:var(--green);font-size:1.25rem;font-weight:800}.calc-result{background:var(--accent-dim);border-radius:var(--r-sm);border:1px solid #2f8f3e1a;justify-content:space-between;align-items:center;margin-top:12px;padding:14px 18px;display:flex}.calc-result-label{color:var(--text-2);font-size:.82rem;font-weight:500}.calc-result-value{color:var(--accent);font-size:1.2rem;font-weight:800}.btn{border-radius:var(--r-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;min-height:56px;padding:14px 24px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;background:linear-gradient(90deg,#0000,#ffffff0f,#0000) 0 0/200% 100%;transition:opacity .3s;position:absolute;inset:0}.btn:hover:after{opacity:1;animation:1.5s infinite shimmer}.btn:active{transform:scale(.96)}.btn-icon{font-size:20px;line-height:1}.btn-primary{background:var(--grad-accent);color:#fff;text-shadow:0 1px 2px #0003;box-shadow:0 4px 20px #2f8f3e4d}.btn-primary:hover{box-shadow:0 8px 32px #2f8f3e66}.btn-secondary{background:var(--bg-input);color:var(--text-1);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-whatsapp{background:var(--grad-whatsapp);color:#fff;text-shadow:0 1px 2px #0003;box-shadow:0 4px 20px #25d3664d}.btn-print{background:var(--grad-accent);color:#fff;text-shadow:0 1px 2px #0003;box-shadow:0 4px 20px #2f8f3e4d}.btn-add{background:var(--grad-green);color:#fff;text-shadow:0 1px 2px #0003;margin-top:12px;box-shadow:0 4px 20px #34d39940}.btn-add-wall{border:1.5px dashed var(--border);color:var(--text-2);background:0 0;min-height:48px;margin-bottom:4px;font-size:.88rem}.btn-add-wall:hover{border-color:var(--accent);color:var(--accent)}.btn-clear{color:var(--red);background:0 0;border:1.5px solid #f8717140}.action-buttons{flex-direction:column;gap:12px;margin-top:20px;display:flex}.walls-container{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.wall-row{border-radius:var(--r-sm);background:#2f8f3e08;border:1px solid #2f8f3e1a;padding:12px;transition:all .25s;overflow:hidden}.wall-row:hover{border-color:#2f8f3e33}.wall-row-enter{animation:.3s forwards wallSlideIn}.wall-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.wall-label{color:var(--accent);letter-spacing:-.01em;font-size:.82rem;font-weight:700}.btn-remove-wall{background:var(--red-dim);width:28px;height:28px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.btn-remove-wall:active{background:#f8717133;transform:scale(.9)}.budget-list{list-style:none}.budget-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-md);align-items:center;gap:12px;margin-bottom:10px;padding:16px;transition:all .25s;animation:.3s fadeInUp;display:flex}.budget-item:hover{border-color:var(--border)}.budget-item-info{flex:1;min-width:0}.budget-item-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;overflow:hidden}.budget-item-detail{color:var(--text-3);margin-top:2px;font-size:.75rem}.budget-item-value{color:var(--accent);white-space:nowrap;font-size:1rem;font-weight:800}.budget-item-remove{background:var(--red-dim);width:36px;height:36px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex}.budget-item-remove:active{transform:scale(.9)}.total-card{background:var(--grad-accent-soft);border:2px solid var(--accent);border-radius:var(--r-lg);text-align:center;margin:20px 0;padding:28px;position:relative;overflow:hidden;box-shadow:0 0 40px #2f8f3e14,0 8px 32px #0003}.total-card:before{content:"";pointer-events:none;background:linear-gradient(#2f8f3e0d 0%,#0000 100%);position:absolute;inset:0}.total-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:.82rem;font-weight:600;position:relative}.total-value{background:linear-gradient(135deg,#2f8f3e,#7ed492);-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:2.4rem;font-weight:900;position:relative}.client-input{background:var(--bg-input);border:1.5px solid var(--border-subtle);border-radius:var(--r-md);width:100%;color:var(--text-1);outline:none;padding:16px;font-family:inherit;font-size:1rem;font-weight:500;transition:all .3s}.client-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.client-input::placeholder{color:var(--text-3)}.contract-fields{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:20px;padding:20px}.contract-fields-title{color:var(--text-1);margin-bottom:16px;font-size:1rem;font-weight:700}.contract-section-label{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-subtle);margin-bottom:10px;padding-bottom:6px;font-size:.72rem;font-weight:700}.logo-preview{border:1.5px dashed var(--border);border-radius:var(--r-md);background:var(--bg-input);cursor:pointer;justify-content:center;align-items:center;width:100%;min-height:110px;transition:all .2s;display:flex;position:relative;overflow:hidden}.logo-preview:hover{border-color:var(--accent);background:var(--accent-dim,#6366f10f)}.logo-preview.has-logo{border-style:solid;border-color:var(--border-subtle);cursor:default;padding:10px}.logo-preview.has-logo:hover{background:var(--bg-input);border-color:var(--border-subtle)}.logo-placeholder{text-align:center;color:var(--text-3);pointer-events:none;padding:18px 12px}.logo-placeholder-icon{opacity:.7;margin-bottom:6px;font-size:32px;display:block}.logo-placeholder-text{color:var(--text-2);font-size:.9rem;font-weight:600;display:block}.logo-placeholder-hint{opacity:.7;margin-top:2px;font-size:.75rem;display:block}.logo-thumb{object-fit:contain;border-radius:4px;max-width:100%;max-height:120px;display:block}.btn-remove-logo{color:#fff;cursor:pointer;background:#ef4444f2;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex;position:absolute;top:6px;right:6px;box-shadow:0 2px 6px #00000040}.btn-remove-logo:hover{background:#dc2626;transform:scale(1.05)}.empty-state{text-align:center;color:var(--text-3);padding:48px 24px}.empty-state-icon{opacity:.4;margin-bottom:16px;font-size:56px}.empty-state-text{font-size:.95rem;line-height:1.6}.toast{bottom:calc(var(--nav-h) + 20px);background:var(--bg-card-solid);border:1px solid var(--accent);color:var(--text-1);border-radius:var(--r-xl);z-index:500;opacity:0;white-space:nowrap;pointer-events:none;padding:14px 28px;font-size:.88rem;font-weight:600;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:fixed;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 12px 40px #00000080,0 0 20px #2f8f3e1a}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.numpad-overlay{z-index:400;-webkit-backdrop-filter:blur(8px);background:#000000a6;justify-content:center;align-items:flex-end;display:none;position:fixed;inset:0}.numpad-overlay.open{display:flex}.numpad-modal{background:var(--bg-secondary);border-radius:var(--r-xl) var(--r-xl) 0 0;border:1px solid var(--border);border-bottom:none;width:100%;max-width:420px;padding:0;animation:.35s cubic-bezier(.25,.46,.45,.94) slideUp;box-shadow:0 -8px 48px #0009}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.numpad-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.numpad-title{color:var(--text-1);font-size:1rem;font-weight:700}.numpad-field-name{color:var(--accent);font-size:.78rem;font-weight:600}.numpad-close{background:var(--red-dim);width:32px;height:32px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.numpad-close:active{transform:scale(.9)}.numpad-display{text-align:right;background:var(--bg-primary);border-bottom:1px solid var(--border-subtle);padding:16px 20px}.numpad-expression{color:var(--text-3);word-break:break-all;min-height:22px;font-size:.82rem;font-weight:500}.numpad-result{color:var(--text-1);letter-spacing:-.02em;min-height:40px;margin-top:4px;font-size:2rem;font-weight:800}.numpad-keys{padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0));grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.numpad-key{border-radius:var(--r-sm);background:var(--bg-input);height:60px;color:var(--text-1);cursor:pointer;border:none;justify-content:center;align-items:center;font-family:inherit;font-size:1.3rem;font-weight:600;transition:all .15s;display:flex}.numpad-key:active{background:var(--bg-card-solid);transform:scale(.93)}.numpad-op{color:var(--accent);background:#2f8f3e0f;font-weight:700}.numpad-op:active{background:#2f8f3e26}.numpad-equals{background:var(--grad-accent);color:#fff;text-shadow:0 1px 2px #0003;grid-row:span 2;font-size:1.6rem;font-weight:800}.numpad-equals:active{transform:scale(.93)}.numpad-zero{grid-column:span 1}.numpad-ok{background:var(--grad-green);color:#fff;letter-spacing:.02em;text-shadow:0 1px 2px #0003;font-size:.95rem;font-weight:800}.numpad-ok:active{transform:scale(.93)}.install-banner{bottom:calc(var(--nav-h) + 16px);z-index:150;opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:fixed;left:16px;right:16px;transform:translateY(20px)}.install-banner.show{opacity:1;pointer-events:auto;transform:translateY(0)}.install-banner-content{background:var(--bg-card-solid);border:1.5px solid var(--accent);border-radius:var(--r-lg);-webkit-backdrop-filter:blur(20px);align-items:center;gap:12px;padding:14px 16px;animation:3s ease-in-out infinite installPulse;display:flex;box-shadow:0 8px 32px #2f8f3e26,0 0 0 1px #2f8f3e0f}@keyframes installPulse{0%,to{box-shadow:0 8px 32px #2f8f3e26,0 0 0 1px #2f8f3e0f}50%{box-shadow:0 8px 32px #2f8f3e4d,0 0 0 1px #2f8f3e1f}}.install-banner-icon{flex-shrink:0;font-size:28px;animation:2s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.install-banner-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.install-banner-title{color:var(--text-1);font-size:.88rem;font-weight:700}.install-banner-desc{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;font-weight:500;overflow:hidden}.install-btn{background:var(--grad-accent);border-radius:var(--r-sm);color:#fff;cursor:pointer;white-space:nowrap;text-shadow:0 1px 2px #0003;border:none;flex-shrink:0;align-items:center;gap:6px;padding:10px 18px;font-family:inherit;font-size:.82rem;font-weight:700;transition:all .25s;display:inline-flex;box-shadow:0 4px 14px #2f8f3e4d}.install-btn:active{transform:scale(.94)}.install-btn:hover{box-shadow:0 6px 24px #2f8f3e66}.install-banner-close{width:28px;height:28px;color:var(--text-3);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;transition:all .2s;display:flex}.install-banner-close:hover{background:var(--red-dim);color:var(--red);border-color:#f871714d}.install-banner-close:active{transform:scale(.9)}.install-modal-overlay{z-index:500;-webkit-backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.install-modal-overlay.open{animation:.25s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.install-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:400px;animation:.35s cubic-bezier(.175,.885,.32,1.275) modalSlideUp;overflow:hidden;box-shadow:0 24px 64px #00000080}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.install-modal-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.install-modal-icon{font-size:28px}.install-modal-title{color:var(--text-1);letter-spacing:-.02em;flex:1;font-size:1.15rem;font-weight:800}.install-modal-close{background:var(--red-dim);width:32px;height:32px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.install-modal-close:active{transform:scale(.9)}.install-modal-body{padding:20px}.install-instructions-intro{color:var(--text-2);margin-bottom:20px;font-size:.88rem;line-height:1.6}.install-steps{flex-direction:column;gap:16px;margin-bottom:20px;display:flex}.install-step{align-items:flex-start;gap:14px;display:flex}.install-step-number{background:var(--grad-accent);color:#fff;text-shadow:0 1px 2px #0003;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:800;display:flex;box-shadow:0 4px 12px #2f8f3e4d}.install-step-content{flex:1;padding-top:4px}.install-step-title{color:var(--text-1);margin-bottom:4px;font-size:.88rem;font-weight:700}.install-step-desc{color:var(--text-2);font-size:.8rem;line-height:1.5}.install-step-desc strong{color:var(--accent);font-weight:700}.install-step-icon-inline{vertical-align:middle;margin:0 2px;display:inline-block}.install-dots-icon{color:var(--accent);vertical-align:middle;margin:0 3px;font-size:1.1rem;font-weight:800;display:inline-block}.install-note{background:var(--accent-dim);border-radius:var(--r-sm);color:var(--text-2);border:1px solid #2f8f3e1a;align-items:center;gap:10px;padding:12px 16px;font-size:.8rem;line-height:1.5;display:flex}.install-note strong{color:var(--accent)}.install-note-icon{flex-shrink:0;font-size:18px}.print-area{display:none}@media print{body *{visibility:hidden}.print-area,.print-area *{visibility:visible}.print-area{width:100%;display:block;position:absolute;top:0;left:0}.bottom-nav,.app-header,.toast,.numpad-overlay,.install-banner,.install-modal-overlay{display:none!important}}.mt-12{margin-top:12px}.mt-20{margin-top:20px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#2f8f3e26;border-radius:4px}::selection{color:#fff;background:#2f8f3e40}.lock-overlay{background:radial-gradient(ellipse at top, #1c1c1c 0%, var(--bg-primary) 70%);z-index:1000;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.lock-card{background:var(--bg-card-solid);border:1px solid var(--border);border-radius:var(--r-xl);text-align:center;width:100%;max-width:420px;padding:36px 28px 28px;position:relative;overflow:hidden;box-shadow:0 24px 64px #00000080,0 0 0 1px #2f8f3e0a,0 0 80px #2f8f3e0a}.lock-card:before{content:"";background:var(--grad-accent);height:3px;position:absolute;top:0;left:0;right:0}.lock-icon{filter:drop-shadow(0 4px 16px #2f8f3e66);margin-bottom:8px;font-size:52px;line-height:1}.lock-title{background:linear-gradient(135deg, var(--accent), var(--accent-light));-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:1.6rem;font-weight:800}.lock-sub{color:var(--text-2);margin-bottom:28px;font-size:.88rem;line-height:1.5}.lock-form{text-align:left;flex-direction:column;gap:14px;display:flex}.lock-group{flex-direction:column;gap:6px;display:flex}.lock-lbl{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700}.lock-field{background:var(--bg-input);border:1.5px solid var(--border-subtle);border-radius:var(--r-md);width:100%;color:var(--text-1);-webkit-appearance:none;outline:none;padding:14px 16px;font-family:inherit;font-size:1rem;font-weight:500;transition:all .3s}.lock-field::placeholder{color:var(--text-3)}.lock-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--bg-secondary)}.lock-code-input{letter-spacing:.06em;text-align:center;text-transform:uppercase;font-family:Menlo,Monaco,Courier New,monospace;font-size:1rem;font-weight:700}.lock-btn{background:var(--grad-accent);border-radius:var(--r-md);color:#fff;cursor:pointer;text-shadow:0 1px 2px #0003;border:none;margin-top:6px;padding:15px 20px;font-family:inherit;font-size:.98rem;font-weight:800;transition:all .25s;box-shadow:0 4px 20px #2f8f3e4d}.lock-btn:hover:not(:disabled){box-shadow:0 8px 32px #2f8f3e73}.lock-btn:active:not(:disabled){transform:scale(.97)}.lock-btn:disabled{opacity:.65;cursor:wait}.lock-btn-ghost{border:1.5px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-2);cursor:pointer;background:0 0;padding:12px 18px;font-family:inherit;font-size:.88rem;font-weight:600;transition:all .2s}.lock-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.lock-btn-ghost:active{transform:scale(.97)}.lock-error{min-height:22px;color:var(--red);text-align:center;font-size:.82rem;font-weight:600;line-height:1.4}.lock-divider{color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:12px;margin:22px 0 16px;font-size:.74rem;display:flex}.lock-divider:before,.lock-divider:after{content:"";background:var(--border-subtle);flex:1;height:1px}.lock-help{text-align:center;color:var(--text-3);margin-top:22px;font-size:.82rem;line-height:1.5}.lock-help a{color:var(--accent);border-bottom:1px solid var(--accent-dim);font-weight:700;text-decoration:none}.lock-help a:hover{border-bottom-color:var(--accent)}.lock-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1100;background:#000000bf;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.lock-modal-overlay.open{animation:.2s fadeIn;display:flex}.lock-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:420px;animation:.3s cubic-bezier(.175,.885,.32,1.275) modalSlideUp;overflow:hidden;box-shadow:0 24px 64px #0009}.lock-modal-head{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:18px 20px 14px;display:flex}.lock-modal-ico{font-size:22px}.lock-modal-title{color:var(--text-1);letter-spacing:-.02em;flex:1;font-size:1.1rem;font-weight:800}.lock-modal-close{background:var(--red-dim);width:32px;height:32px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.lock-modal-close:active{transform:scale(.9)}.lock-modal-body{padding:18px 20px 22px}.lock-modal-sub{color:var(--text-2);margin-bottom:16px;font-size:.82rem;line-height:1.55}.lock-result{margin-top:8px}.recover-success{background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--r-md);text-align:center;color:var(--text-1);padding:14px 16px;font-size:.88rem;line-height:1.6}.recover-code{background:var(--bg-input);border:1.5px solid var(--accent);border-radius:var(--r-sm);color:var(--accent);letter-spacing:.05em;-webkit-user-select:all;user-select:all;margin-top:6px;padding:10px 16px;font-family:Menlo,Monaco,Courier New,monospace;font-size:1rem;font-weight:700;display:inline-block}.header-logout{border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-2);cursor:pointer;background:#ffffff0a;border-radius:50%;justify-content:center;align-items:center;margin-left:8px;transition:all .2s;display:flex}.header-logout:hover{background:var(--red-dim);color:var(--red);border-color:#f871714d}.header-logout:active{transform:scale(.92)}.btn-materials{color:#fff;text-shadow:0 1px 2px #0003;background:linear-gradient(135deg,#6366f1,#4f46e5);min-height:64px;padding:12px 20px;box-shadow:0 4px 20px #6366f14d}.btn-materials:hover{box-shadow:0 8px 32px #6366f166}.btn-stack{text-align:left;flex-direction:column;flex:1;align-items:flex-start;gap:2px;line-height:1.2;display:flex}.btn-main{font-size:.95rem;font-weight:700}.btn-sub{opacity:.88;letter-spacing:.01em;font-size:.7rem;font-weight:500;line-height:1.25}.materials-modal-overlay{z-index:600;-webkit-backdrop-filter:blur(10px);background:#000000bf;justify-content:center;align-items:flex-end;display:none;position:fixed;inset:0}.materials-modal-overlay.open{animation:.25s fadeIn;display:flex}@media (width>=640px){.materials-modal-overlay{align-items:center;padding:24px}}.materials-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl) var(--r-xl) 0 0;flex-direction:column;width:100%;max-width:540px;max-height:92vh;animation:.35s cubic-bezier(.25,.46,.45,.94) slideUp;display:flex;overflow:hidden;box-shadow:0 -8px 48px #0009}@media (width>=640px){.materials-modal{border-radius:var(--r-xl);max-height:88vh}}.materials-modal-head{border-bottom:1px solid var(--border-subtle);background:var(--bg-card-solid);flex-shrink:0;align-items:center;gap:12px;padding:18px 20px 14px;display:flex}.materials-modal-ico{filter:drop-shadow(0 2px 6px #2f8f3e66);font-size:24px}.materials-modal-title{color:var(--text-1);letter-spacing:-.02em;flex:1;font-size:1.15rem;font-weight:800}.materials-modal-close{background:var(--red-dim);width:32px;height:32px;color:var(--red);cursor:pointer;border:1px solid #f8717133;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.materials-modal-close:active{transform:scale(.9)}.materials-modal-body{-webkit-overflow-scrolling:touch;flex:1;padding:16px 18px 4px;overflow-y:auto}.materials-warning{border-radius:var(--r-md);color:var(--text-2);background:#fb923c14;border:1px solid #fb923c4d;gap:10px;margin-bottom:14px;padding:12px 14px;font-size:.78rem;line-height:1.5;display:flex}.materials-warning strong{color:var(--orange);font-weight:700}.materials-warning-ico{flex-shrink:0;font-size:18px}.materials-warning-list{color:var(--text-3);font-size:.72rem}.materials-empty{text-align:center;color:var(--text-3);padding:48px 20px}.materials-empty-ico{opacity:.5;margin-bottom:14px;font-size:56px}.materials-empty-title{color:var(--text-2);margin-bottom:8px;font-size:1rem;font-weight:700}.materials-empty-sub{font-size:.85rem;line-height:1.55}.materials-cat{margin-bottom:18px}.materials-cat-head{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:8px;padding:8px 0 6px;display:flex;position:relative}.materials-cat-head:after{content:"";background:var(--grad-accent);border-radius:1px;width:50px;height:2px;position:absolute;bottom:-1px;left:0}.materials-cat-ico{font-size:18px}.materials-cat-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-size:.74rem;font-weight:800}.material-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-md);margin-bottom:8px;padding:12px 14px;transition:all .25s;position:relative;overflow:hidden}.material-card.have{opacity:.55;background:#34d3990a;border-color:#34d3992e}.material-card.have .material-name,.material-card.have .material-qty-input,.material-card.have .material-subtotal{text-decoration:line-through;-webkit-text-decoration-color:var(--green);text-decoration-color:var(--green)}.material-card-head{align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.material-icon{flex-shrink:0;font-size:22px;line-height:1}.material-info{flex:1;min-width:0}.material-name{color:var(--text-1);margin-bottom:2px;font-size:.92rem;font-weight:700;line-height:1.3}.material-price{color:var(--text-3);font-size:.72rem;font-weight:500}.material-controls{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.material-qty{align-items:center;gap:6px;display:flex}.material-qty-lbl{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.material-qty-input{background:var(--bg-input);border:1.5px solid var(--border-subtle);border-radius:var(--r-sm);width:64px;color:var(--text-1);text-align:center;-webkit-appearance:none;-moz-appearance:textfield;outline:none;padding:6px 8px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .2s}.material-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.material-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.material-qty-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.material-qty-unit{color:var(--text-3);font-size:.78rem;font-weight:600}.material-subtotal{color:var(--accent);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:1rem;font-weight:800}.materials-disclaimer{border-radius:var(--r-md);background:#2f8f3e12;border:1px solid #2f8f3e38;flex-direction:column;gap:8px;margin-bottom:14px;padding:12px 14px;display:flex}.materials-disclaimer .disclaimer-line{color:var(--text-2);gap:9px;font-size:.78rem;line-height:1.5;display:flex}.materials-disclaimer .disclaimer-line strong{color:var(--text-1);font-weight:700}.materials-disclaimer .disclaimer-ico{flex-shrink:0;font-size:16px;line-height:1.35}.material-actions-row{gap:8px;display:flex}.material-mode-btn{background:var(--bg-input);border:1.5px solid var(--border-subtle);border-radius:var(--r-sm);color:var(--text-3);cursor:pointer;text-align:center;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 10px;font-family:inherit;font-size:.76rem;font-weight:700;line-height:1.2;transition:all .2s;display:flex}.material-mode-btn:active{transform:scale(.97)}.material-mode-btn.add.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 2px #2f8f3e14}.material-mode-btn.have.active{background:var(--green-dim);border-color:var(--green);color:var(--green);box-shadow:0 0 0 2px #34d39914}.material-mode-ico{flex-shrink:0;font-size:13px}.material-mode-lbl{font-weight:700}.materials-modal-foot{border-top:1px solid var(--border-subtle);padding:14px 18px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0));background:var(--bg-card-solid);flex-direction:column;flex-shrink:0;gap:10px;display:flex}.materials-total-bar{background:var(--grad-accent-soft);border:1.5px solid var(--accent);border-radius:var(--r-md);justify-content:space-between;align-items:center;margin-bottom:4px;padding:12px 16px;display:flex}.materials-total-lbl{color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;font-weight:700}.materials-total-val{color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1.4rem;font-weight:900}.materials-btn-pedir{margin-bottom:0}.budget-mat-badge{background:var(--accent-dim);color:var(--accent);letter-spacing:.06em;text-transform:uppercase;vertical-align:middle;border:1px solid #2f8f3e40;border-radius:4px;margin-right:6px;padding:2px 6px;font-size:.6rem;font-weight:800;display:inline-block}.budget-item.is-material{background:linear-gradient(90deg, #2f8f3e0a, var(--bg-card));border-left:3px solid var(--accent);padding-left:13px}.type-toggle{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);gap:6px;margin:0 0 20px;padding:5px;display:flex}.type-toggle-btn{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;padding:12px 10px;font-family:inherit;font-size:.95rem;font-weight:700;transition:background .18s,color .18s,box-shadow .18s}.type-toggle-btn.active{background:var(--grad-accent);color:#fff;text-shadow:0 1px 2px #0003;box-shadow:0 4px 16px #2f8f3e4d}.upsell-banner{top:var(--header-h);z-index:90;background:linear-gradient(135deg,#3ad156 0%,#2f9e42 50%,#1f7a32 100%);border-bottom:3px solid #ffd23f;padding:14px;transition:transform .42s cubic-bezier(.2,.9,.25,1);position:fixed;left:0;right:0;transform:translateY(-150%);box-shadow:0 14px 36px #00000073,0 6px 22px #2f8f3e80}.upsell-banner.show{animation:2.6s ease-in-out .5s 3 upsell-attention;transform:translateY(0)}@keyframes upsell-attention{0%,to{box-shadow:0 14px 36px #00000073,0 0 #ffd23f00}50%{box-shadow:0 14px 36px #00000073,0 6px 30px #ffd23fa6}}.upsell-content{align-items:center;gap:12px;max-width:640px;margin:0 auto;display:flex}.upsell-emoji{filter:drop-shadow(0 2px 5px #00000059);flex-shrink:0;font-size:2rem;line-height:1}.upsell-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.upsell-title{color:#fff;letter-spacing:-.01em;text-shadow:0 1px 2px #0000004d;font-size:1rem;font-weight:900}.upsell-sub{color:#f1fff4;font-size:.8rem;font-weight:500;line-height:1.25}.upsell-cta{cursor:pointer;color:#1f7a32;white-space:nowrap;background:#fff;border:none;border-radius:12px;flex-shrink:0;padding:11px 17px;font-family:inherit;font-size:.85rem;font-weight:800;animation:1.7s ease-in-out infinite upsell-cta-pulse;box-shadow:0 6px 18px #0000004d}.upsell-cta:active{animation:none;transform:scale(.95)}@keyframes upsell-cta-pulse{0%,to{transform:scale(1);box-shadow:0 6px 18px #0000004d}50%{transform:scale(1.06);box-shadow:0 9px 26px #0000006b}}.upsell-close{cursor:pointer;color:#fff;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:1.1rem;line-height:1}.upsell-bell{cursor:pointer;color:#fff;background:#1c6e2c;border:1px solid #ffffff8c;border-radius:10px;width:100%;max-width:640px;margin:10px auto 0;padding:10px;font-family:inherit;font-size:.8rem;font-weight:700;display:block}.upsell-bell:active{background:#16591f}
