:root{--sans:"Space Grotesk", "Inter", system-ui, -apple-system, sans-serif;--body:"Inter", system-ui, -apple-system, sans-serif;--bg:#f0f0f5;--card-bg:#fff;--text:#374151;--text-muted:#6b7280;--text-heading:#0f0d1a;--border:#e2e4ea;--radius:16px;--radius-sm:10px;--shadow-card:0 1px 3px #0000000a, 0 4px 16px #00000008;--shadow-card-hover:0 8px 30px #00000014, 0 2px 8px #0000000a;--gradient-brand:linear-gradient(135deg, #4f46e5, #7c3aed, #a855f7);--gradient-surface:linear-gradient(180deg, #fafaff 0%, #f0f0f5 100%)}[data-theme=dark]{--bg:#0f0f1a;--card-bg:#1a1a2e;--text:#d1d5db;--text-muted:#9ca3af;--text-heading:#f3f4f6;--border:#2d2d44;--shadow-card:0 1px 3px #0003, 0 4px 16px #00000026;--shadow-card-hover:0 8px 30px #0000004d, 0 2px 8px #0003;--gradient-surface:linear-gradient(180deg, #13132a 0%, #0f0f1a 100%)}*,:before,:after{box-sizing:border-box}body{font-family:var(--body);color:var(--text);background:var(--gradient-surface);-webkit-font-smoothing:antialiased;background-attachment:fixed;margin:0;font-size:14px;line-height:1.5}#root{min-height:100vh}.btn{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:var(--sans);cursor:pointer;background:var(--card-bg);color:var(--text);white-space:nowrap;align-items:center;gap:6px;padding:8px 16px;text-decoration:none;transition:all .2s;display:inline-flex}.btn:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}[data-theme=dark] .btn:hover{background:#2d2d44;border-color:#4d4d66}.btn-primary{background:var(--gradient-brand);color:#fff;border:none}.btn-primary:hover{background:var(--gradient-brand);opacity:.85;transform:translateY(-1px)}.btn-danger{color:#dc2626;background:#fef2f2;border-color:#fecaca}.btn-danger:hover{background:#fee2e2}.btn-ghost{background:0 0;border:none}.btn-ghost:hover{background:#f3f4f6;transform:none}[data-theme=dark] .btn-ghost:hover{background:#2d2d44}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:inline-flex}.btn-icon:hover{background:#f3f4f6}[data-theme=dark] .btn-icon:hover{background:#2d2d44}.btn-danger-ghost{color:#dc2626}.btn-danger-ghost:hover{background:#fef2f2}.input{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--body);color:var(--text-heading);background:var(--card-bg);width:100%;padding:8px 12px;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:#7c3aed;outline:none;box-shadow:0 0 0 3px #7c3aed1a}.input-sm{padding:5px 8px;font-size:12px}.input-narrow{text-align:center;max-width:70px}select.input{cursor:pointer}.progress-bar-track{background:#edeef3;border-radius:99px;width:100%;overflow:hidden}[data-theme=dark] .progress-bar-track{background:#2d2d44}.progress-bar-fill{border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1)}.status-badge{font-size:11px;font-weight:600;font-family:var(--sans);white-space:nowrap;letter-spacing:.01em;border-radius:99px;align-items:center;gap:5px;padding:3px 10px;display:inline-flex}.status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.status-dot-diamond{border-radius:1px;width:7px;height:7px;transform:rotate(45deg)}.status-dot-square{border-radius:1px}.status-dot-ring{border:1.5px solid;background:0 0!important}.status-dot-triangle{border-bottom:6px solid;border-left:3.5px solid #0000;border-right:3.5px solid #0000;border-radius:0;width:0;height:0;background:0 0!important}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--card-bg);border-radius:var(--radius);width:90%;max-width:400px;padding:28px;animation:.2s ease-out slideUp;box-shadow:0 20px 60px #0003}.confirm-dialog h3{font-family:var(--sans);color:var(--text-heading);margin:0 0 8px;font-size:16px;font-weight:700}.confirm-dialog p{color:var(--text-muted);margin:0 0 20px;font-size:13px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.theme-toggle{cursor:pointer;color:#ffffffb3;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:inline-flex}.theme-toggle:hover{color:#fff;background:#fff3}.skip-link{background:var(--gradient-brand);color:#fff;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--sans);z-index:999;padding:8px 16px;text-decoration:none;transition:top .2s;position:absolute;top:-100px;left:16px}.skip-link:focus{top:12px}.dashboard-utility-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.utility-actions{flex-shrink:0;gap:8px;display:flex}.utility-btn{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;width:32px;height:32px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.utility-btn:hover{color:#7c3aed;background:#faf5ff;border-color:#7c3aed}[data-theme=dark] .utility-btn:hover{background:#2d2044;border-color:#7c3aed}.dashboard{max-width:1320px;margin:0 auto;padding:0 32px 24px}.dashboard-hero{border-radius:0 0 var(--radius) var(--radius);background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#4f46e5 100%);margin:0 -32px 32px;padding:40px 40px 36px;position:relative;overflow:hidden}.dashboard-hero:before{content:"";pointer-events:none;background:radial-gradient(#a855f733 0%,#0000 70%);width:60%;height:200%;position:absolute;top:-50%;right:-20%}.dashboard-hero:after{content:"";pointer-events:none;background:radial-gradient(#4f46e54d 0%,#0000 70%);width:40%;height:150%;position:absolute;bottom:-30%;left:-10%}.dashboard-header{z-index:1;justify-content:space-between;align-items:flex-start;gap:32px;display:flex;position:relative}.dashboard-header-left{flex:1}.dashboard-branding{align-items:center;gap:12px;margin-bottom:20px;display:flex}.tm-logo{width:auto;height:36px}.pt-logo-white{filter:brightness(0)invert();width:auto;height:36px}.client-logo{object-fit:contain;width:auto;max-width:140px;height:32px}.client-logo-white{object-fit:contain;filter:brightness(0)invert();width:auto;max-width:140px;height:32px}.brand-separator{color:#ffffff4d;font-size:22px;font-weight:300}.brand-separator-dark{color:#d1d5db;font-size:22px;font-weight:300}.client-name-text{font-size:22px;font-weight:700;font-family:var(--sans);letter-spacing:-.3px;color:#fff}.dashboard-title{font-size:clamp(24px,4vw,36px);font-weight:700;font-family:var(--sans);color:#fff;letter-spacing:-.8px;margin:0 0 8px}.dashboard-subtitle{color:#ffffffa6;max-width:540px;font-size:clamp(13px,1.5vw,15px);line-height:1.6}.dashboard-stats{flex-shrink:0;align-items:flex-start;gap:12px;display:flex}.stat-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);text-align:center;background:#ffffff1a;border:1px solid #ffffff26;min-width:110px;padding:16px 24px;transition:transform .2s,background .2s}.stat-card:hover{background:#ffffff26;transform:translateY(-2px)}.stat-value{font-size:26px;font-weight:700;font-family:var(--sans);color:#fff;letter-spacing:-.5px;display:block}.stat-label{color:#ffffff8c;text-transform:uppercase;letter-spacing:.08em;margin-top:2px;font-size:10px;font-weight:500;display:block}.stat-card-ring{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);background:#ffffff1a;border:1px solid #ffffff26;align-items:center;gap:14px;padding:16px 20px;transition:transform .2s,background .2s;display:flex}.stat-card-ring:hover{background:#ffffff26;transform:translateY(-2px)}.progress-ring-container{flex-shrink:0;width:56px;height:56px;position:relative}.progress-ring-container svg{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:#ffffff26;stroke-width:5px}.progress-ring-fill{fill:none;stroke:url(#ringGradient);stroke-width:5px;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.progress-ring-text{font-size:14px;font-weight:700;font-family:var(--sans);color:#fff;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.stat-ring-labels{flex-direction:column;gap:2px;display:flex}.stat-ring-value{font-size:13px;font-weight:600;font-family:var(--sans);color:#fff}.stat-ring-label{color:#ffffff8c;text-transform:uppercase;letter-spacing:.06em;font-size:10px}.dashboard-toolbar{z-index:50;background:var(--bg);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;padding:12px 0;display:flex;position:sticky;top:0}.search-box{flex:1;min-width:200px;max-width:360px;position:relative}.search-box svg{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:13px;font-family:var(--body);color:var(--text-heading);background:var(--card-bg);padding:9px 12px 9px 36px;transition:border-color .2s,box-shadow .2s}.search-box input:focus{border-color:#7c3aed;outline:none;box-shadow:0 0 0 3px #7c3aed1a}.search-box input::placeholder{color:var(--text-muted)}.search-clear{cursor:pointer;color:#6b7280;background:#e5e7eb;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;transition:all .15s;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-clear:hover{color:#374151;background:#d1d5db}[data-theme=dark] .search-clear{color:#9ca3af;background:#374151}[data-theme=dark] .search-clear:hover{background:#4b5563}.filter-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-label{font-size:11px;font-weight:600;font-family:var(--sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.filter-pills{flex-wrap:wrap;gap:6px;display:flex}.filter-pill{border:1px solid var(--border);font-size:12px;font-weight:500;font-family:var(--sans);cursor:pointer;background:var(--card-bg);color:var(--text-muted);border-radius:99px;padding:5px 12px;transition:all .2s}.filter-pill:hover{color:#7c3aed;border-color:#7c3aed}.filter-pill.active{background:var(--gradient-brand);color:#fff;border-color:#0000}.search-result-count{font-size:12px;font-weight:500;font-family:var(--sans);color:var(--text-muted);white-space:nowrap}.product-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:20px;display:grid}@media (width<=1100px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.product-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column}.dashboard-stats{flex-wrap:wrap;justify-content:space-between;width:100%}.dashboard{padding:0 16px 24px}.dashboard-hero{margin:0 -16px 24px;padding:28px 20px}.dashboard-title{font-size:26px}.dashboard-toolbar{flex-direction:column;align-items:stretch}.search-box{max-width:none}.dashboard-utility-bar,.filter-row{flex-wrap:wrap}}.product-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);flex-direction:column;padding:24px;transition:box-shadow .3s,transform .3s;animation:.4s ease-out both cardFadeIn;display:flex;position:relative}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.product-card:first-child{animation-delay:0s}.product-card:nth-child(2){animation-delay:50ms}.product-card:nth-child(3){animation-delay:.1s}.product-card:nth-child(4){animation-delay:.15s}.product-card:nth-child(5){animation-delay:.2s}.product-card:nth-child(6){animation-delay:.25s}.product-card:before{content:"";background:var(--gradient-brand);opacity:0;border-radius:0 0 3px 3px;height:3px;transition:opacity .25s;position:absolute;top:0;left:24px;right:24px}.product-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.product-card:hover:before{opacity:1}.product-card-header{margin-bottom:16px}.product-title-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.product-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex;overflow:hidden}.product-icon img{object-fit:cover;border-radius:12px;width:100%;height:100%}.product-name{font-size:16px;font-weight:700;font-family:var(--sans);color:var(--text-heading);flex:1;min-width:0;margin:0}.product-progress-row{align-items:center;gap:10px;display:flex}.product-progress-label{font-size:13px;font-weight:700;font-family:var(--sans);color:var(--text-heading);text-align:right;flex-shrink:0;min-width:36px}.product-notes{margin:0 0 12px;padding:0;list-style:none}.product-notes li{color:var(--text);margin-bottom:6px;padding-left:14px;font-size:13px;line-height:1.55;position:relative}.product-notes li:before{content:"";background:#9ca3af;border-radius:50%;width:4px;height:4px;position:absolute;top:8px;left:0}.product-notes li.notes-show-more{cursor:pointer;color:#7c3aed;font-size:12px;font-weight:600;font-family:var(--sans)}.product-notes li.notes-show-more:before{display:none}.product-notes li.notes-show-more:hover{text-decoration:underline}.product-milestone{color:#ea580c;align-items:center;gap:6px;margin-bottom:14px;font-size:12px;font-weight:600;display:flex}.product-eta-pill{font-size:11px;font-weight:600;font-family:var(--sans);color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:99px;align-items:center;gap:5px;width:fit-content;margin-bottom:14px;padding:3px 10px;display:inline-flex}[data-theme=dark] .product-eta-pill{color:#a5b4fc;background:#1e1b4b;border-color:#4338ca}.product-eta-pill svg{flex-shrink:0}.features-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--text-muted);font-size:12px;font-weight:500;font-family:var(--sans);background:#f8f8fc;justify-content:space-between;align-items:center;margin-top:auto;padding:8px 12px;transition:all .2s;display:flex}[data-theme=dark] .features-toggle{background:#1f1f36}.features-toggle:hover{background:#eeeef6;border-color:#c7c8d4}[data-theme=dark] .features-toggle:hover{background:#2d2d44}.features-toggle-text{align-items:center;gap:4px;display:flex}.features-toggle-count{color:var(--text-heading);font-weight:700}.features-all-delivered{border-radius:var(--radius-sm);font-size:12px;font-weight:600;font-family:var(--sans);color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:1px solid #bbf7d0;justify-content:center;align-items:center;gap:6px;margin-top:auto;padding:8px 12px;display:flex}[data-theme=dark] .features-all-delivered{color:#34d399;background:linear-gradient(135deg,#052e16,#064e3b);border-color:#166534}.features-list-wrapper{transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s;overflow:hidden}.features-list-wrapper.collapsed{opacity:0;max-height:0}.features-list-wrapper.expanded{opacity:1}.features-list{flex-direction:column;gap:8px;margin-top:12px;padding-bottom:2px;display:flex}.feature-row{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fafafc;padding:10px 12px;transition:all .2s;animation:.25s ease-out both featureFadeIn}[data-theme=dark] .feature-row{background:#1f1f36}@keyframes featureFadeIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.feature-row:first-child{animation-delay:0s}.feature-row:nth-child(2){animation-delay:40ms}.feature-row:nth-child(3){animation-delay:80ms}.feature-row:nth-child(4){animation-delay:.12s}.feature-row:nth-child(5){animation-delay:.16s}.feature-row:nth-child(6){animation-delay:.2s}.feature-row.delivered{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-color:#bbf7d0}[data-theme=dark] .feature-row.delivered{background:linear-gradient(135deg,#052e16,#064e3b);border-color:#166534}.feature-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.feature-name-group{align-items:center;gap:8px;display:flex}.feature-check{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex;box-shadow:0 2px 6px #22c55e4d}.feature-dot{background:#d1d5db;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin:0 6px}[data-theme=dark] .feature-dot{background:#4d4d66}.feature-name{font-size:12px;font-weight:600;font-family:var(--sans);color:var(--text-heading)}.feature-progress-label{font-size:11px;font-weight:700;font-family:var(--sans);color:var(--text-muted);flex-shrink:0}.feature-row.delivered .feature-progress-label{color:#16a34a}.feature-eta-pill{font-size:10px;font-weight:600;font-family:var(--sans);color:#4f46e5;background:#eef2ff;border:1px solid #e0e7ff;border-radius:99px;align-items:center;gap:3px;margin-top:4px;padding:1px 7px;display:inline-flex}[data-theme=dark] .feature-eta-pill{color:#a5b4fc;background:#1e1b4b;border-color:#312e81}.feature-eta-pill svg{flex-shrink:0}.feature-delivered-date{font-size:10px;font-weight:600;font-family:var(--sans);color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:99px;align-items:center;gap:3px;margin-top:4px;padding:1px 7px;display:inline-flex}[data-theme=dark] .feature-delivered-date{color:#34d399;background:#052e16;border-color:#166534}.feature-delivered-date svg{flex-shrink:0}.dashboard-footer{text-align:center;color:#9ca3af;justify-content:center;align-items:center;gap:16px;padding:32px 0 16px;font-size:13px;display:flex}.dashboard-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;display:flex}.admin{background:var(--gradient-surface);background-attachment:fixed;min-height:100vh}.admin-header{background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#4f46e5 100%);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.admin-header>div{align-items:center;gap:16px;display:flex}.admin-header h1{font-size:18px;font-weight:700;font-family:var(--sans);color:#fff;margin:0}.admin-header-logo{object-fit:contain;filter:brightness(0)invert();max-width:180px;height:32px}.admin-portal-branding{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:16px}.admin-portal-branding h2{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:8px;font-size:11px}.admin-save-status{font-size:12px;font-weight:500;font-family:var(--sans);color:#ffffff80;transition:all .2s}.admin-save-saving{color:#ffffffe6;animation:.6s ease-in-out infinite alternate savePulse}@keyframes savePulse{0%{opacity:.6}to{opacity:1}}.admin-header-actions{align-items:center;gap:8px;display:flex}.admin-layout{min-height:calc(100vh - 65px);display:flex}.admin-sidebar{background:var(--card-bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:260px;padding:24px 16px;display:flex}.admin-sidebar h2{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:600;font-family:var(--sans);margin:0 0 12px}.admin-client-list{flex:1;margin:0 0 16px;padding:0;list-style:none;overflow-y:auto}.admin-client-item{border-radius:var(--radius-sm);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:2px;padding:10px 12px;transition:all .15s;display:flex}.admin-client-item:hover{background:#f3f4f6}[data-theme=dark] .admin-client-item:hover{background:#2d2d44}.admin-client-item.active{color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#f5f3ff);border:1px solid #c7d2fe}[data-theme=dark] .admin-client-item.active{background:linear-gradient(135deg,#1e1b4b,#312e81);border-color:#4338ca}.admin-client-item-name{font-size:13px;font-weight:600;font-family:var(--sans)}.admin-client-item-count{color:var(--text-muted);font-size:11px}.admin-client-item.active .admin-client-item-name{color:#4f46e5}[data-theme=dark] .admin-client-item.active .admin-client-item-name{color:#a5b4fc}.admin-add-client{gap:8px;display:flex}.admin-add-client .input{flex:1}.admin-main{flex:1;max-height:calc(100vh - 65px);padding:32px;overflow-y:auto}.admin-empty{height:300px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.admin-empty-text{color:var(--text-muted);text-align:center;padding:24px;font-size:13px}.admin-client-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.admin-client-header h2{font-size:22px;font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0}.admin-client-actions{flex-wrap:wrap;gap:8px;display:flex}.admin-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:20px;padding:24px}.admin-section h3{font-size:14px;font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0}.admin-section-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-section-header h3{margin:0}.admin-row{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.admin-field{flex:1;min-width:180px;margin-bottom:12px}.admin-field label{font-size:11px;font-weight:600;font-family:var(--sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:block}.admin-field-sm{flex:0 0 140px;min-width:100px}.color-picker-wrapper{align-items:center;gap:8px;display:flex}.color-picker-wrapper input[type=color]{border:1px solid var(--border);cursor:pointer;border-radius:8px;width:32px;height:32px;padding:2px}.color-picker-wrapper span{color:var(--text-muted);font-family:monospace;font-size:12px}.upload-area{align-items:center;gap:12px;display:flex}.upload-preview{border:1px solid var(--border);object-fit:contain;background:#f8f8fc;border-radius:10px;width:48px;height:48px;padding:4px}.upload-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);font-size:12px;font-family:var(--sans);background:#f8f8fc;border:1px dashed #c7c8d4;align-items:center;gap:6px;padding:6px 12px;transition:all .2s;display:inline-flex}.upload-btn:hover{color:#7c3aed;background:#faf5ff;border-color:#7c3aed}.upload-btn input[type=file]{display:none}.upload-or{color:#9ca3af;font-size:11px}.preset-selector{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.preset-selector select{flex:1;min-width:200px}.admin-product{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);margin-bottom:12px;overflow:hidden}.admin-product-header{cursor:pointer;border-bottom:1px solid var(--border);background:#f8f8fc;justify-content:space-between;align-items:center;padding:14px 16px;transition:background .15s;display:flex}[data-theme=dark] .admin-product-header{background:#1f1f36}.admin-product-header:hover{background:#eeeef6}[data-theme=dark] .admin-product-header:hover{background:#2d2d44}.admin-product-title{flex:1;align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.grip-icon{color:#d1d5db;flex-shrink:0}.admin-product-progress{font-size:13px;font-weight:700;font-family:var(--sans);color:var(--text-muted)}.admin-feature-count{color:var(--text-muted);font-size:11px}.admin-product-actions{color:var(--text-muted);align-items:center;gap:4px;display:flex}.admin-product-body{padding:20px 16px}.icon-field-row{align-items:center;gap:8px;display:flex}.icon-field-row select{flex:1}.icon-upload-mini{cursor:pointer;background:#f8f8fc;border:1px dashed #c7c8d4;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:inline-flex;overflow:hidden}.icon-upload-mini:hover{background:#faf5ff;border-color:#7c3aed}.icon-upload-mini input[type=file]{display:none}.icon-upload-mini img{object-fit:cover;width:100%;height:100%}.admin-note-row{gap:8px;margin-bottom:6px;display:flex}.admin-note-row .input{flex:1}.admin-feature-row{border:1px solid var(--border);border-radius:var(--radius-sm);background:#f8f8fc;margin-bottom:6px;padding:10px 12px}[data-theme=dark] .admin-feature-row{background:#1f1f36}.admin-feature-fields{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.admin-feature-fields .input:first-child{flex:2;min-width:140px}.admin-feature-fields .input:nth-child(2){flex:0 0 60px}.admin-feature-fields .input:last-of-type{flex:1;min-width:100px}.admin-check-label{color:#16a34a;cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:4px;font-size:11px;font-weight:600;display:inline-flex}.admin-check-label input[type=checkbox]{cursor:pointer;margin:0}.admin-delivered-date{align-items:center;gap:6px;margin-top:6px;display:flex}.admin-delivered-date label{color:var(--text-muted);white-space:nowrap;font-size:10px;font-weight:600}.admin-delivered-date input{border:1px solid var(--border);font-size:11px;font-family:var(--body);color:var(--text-heading);background:var(--card-bg);border-radius:6px;padding:3px 6px}.admin-io-bar{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:16px;padding:12px 0;display:flex}.admin-io-bar label{cursor:pointer}.admin-io-bar input[type=file]{display:none}.reorder-btns{flex-direction:column;flex-shrink:0;gap:1px;display:flex}.reorder-btns .btn-icon{color:#9ca3af;padding:2px}.reorder-btns .btn-icon:disabled{opacity:.3;cursor:default}.reorder-btns .btn-icon:not(:disabled):hover{color:#4f46e5}.admin-product-cat{font-size:10px;font-weight:600;font-family:var(--sans);color:#7c3aed;text-transform:uppercase;letter-spacing:.04em;background:#f5f3ff;border-radius:99px;padding:2px 8px}[data-theme=dark] .admin-product-cat{color:#a78bfa;background:#2d2044}.admin-features-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.admin-features-header label{margin-bottom:0}.display-toggles{flex-wrap:wrap;gap:8px;display:flex}.display-toggle-label{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:500;font-family:var(--sans);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:5px;padding:5px 12px;transition:all .15s;display:inline-flex}.display-toggle-label:has(input:checked){color:#4f46e5;background:#eef2ff;border-color:#c7d2fe}[data-theme=dark] .display-toggle-label:has(input:checked){color:#a5b4fc;background:#1e1b4b;border-color:#4338ca}.display-toggle-label input[type=checkbox]{display:none}.password-gate{background:var(--gradient-surface);background-attachment:fixed;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.password-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);text-align:center;width:100%;max-width:380px;padding:40px;box-shadow:0 8px 40px #00000014}.password-icon{background:var(--gradient-brand);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:20px;display:inline-flex}.password-card h2{font-size:20px;font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0 0 8px}.password-card p{color:var(--text-muted);margin:0 0 20px;font-size:13px}.password-card form{text-align:left}.password-error{color:#dc2626;margin-top:6px;font-size:12px;display:block}.product-description{color:var(--text-muted);margin:-4px 0 12px;font-size:12px;line-height:1.5}.product-custom-fields{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.product-custom-field{border:1px solid var(--border);background:#f3f4f6;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;display:inline-flex}[data-theme=dark] .product-custom-field{background:#1f1f36}.pcf-key{color:var(--text-muted);font-weight:600;font-family:var(--sans)}.pcf-value{color:var(--text-heading);font-family:var(--body)}.product-group{margin-bottom:28px}.product-group-header{cursor:pointer;width:100%;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:12px;margin-bottom:16px;padding:0;display:flex}.product-group-title{font-size:clamp(16px,2vw,18px);font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0}.product-group-progress{font-size:12px;font-weight:700;font-family:var(--sans);color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:99px;padding:2px 8px}[data-theme=dark] .product-group-progress{color:#a5b4fc;background:#1e1b4b;border-color:#4338ca}.product-group-count{color:var(--text-muted);flex:1;font-size:12px;font-weight:500}@media (width<=900px){.admin-sidebar{z-index:100;width:280px;transition:transform .25s;position:fixed;top:65px;bottom:0;left:0;transform:translate(0);box-shadow:4px 0 24px #00000026}.admin-sidebar.admin-sidebar-hidden{box-shadow:none;transform:translate(-100%)}.admin-sidebar-overlay{z-index:99;background:#0000004d;display:block;position:fixed;inset:65px 0 0}.admin-main{max-height:none}}@media (width>=901px){.admin-sidebar-overlay{display:none}.admin-sidebar.admin-sidebar-hidden{border-right:none;width:0;padding:0;overflow:hidden}}.status-select-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.status-select-row select{flex:1;min-width:130px}.custom-status-inline{border:1px dashed var(--border);border-radius:var(--radius-sm);background:#f8f8fc;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;padding:8px 10px;animation:.15s ease-out slideUp;display:flex}[data-theme=dark] .custom-status-inline{background:#1f1f36}.custom-status-inline .input{flex:1;min-width:100px}.admin-eta{align-items:center;gap:4px;margin-top:4px;display:flex}.admin-eta svg{color:var(--text-muted);flex-shrink:0}.admin-eta .input{max-width:160px}.admin-product-eta{font-size:11px;font-weight:600;font-family:var(--sans);color:#4f46e5;white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:3px;max-width:120px;display:inline-flex;overflow:hidden}[data-theme=dark] .admin-product-eta{color:#a5b4fc}.admin-product-name{font-size:14px;font-weight:700;font-family:var(--sans);color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:140px;overflow:hidden}.admin-product-meta{flex-shrink:1;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.business-lines-breakdown{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fafafc;margin-bottom:14px;padding:10px 12px}[data-theme=dark] .business-lines-breakdown{background:#1f1f36}.bl-header{font-size:10px;font-weight:700;font-family:var(--sans);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;margin-bottom:8px;display:flex}.business-line-row{align-items:center;gap:8px;margin-bottom:5px;display:flex}.business-line-row:last-child{margin-bottom:0}.bl-name{font-size:11px;font-weight:600;font-family:var(--sans);color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;flex:0 0 110px;min-width:0;overflow:hidden}.bl-bar-wrapper{flex:1;min-width:0}.bl-progress-label{font-size:11px;font-weight:700;font-family:var(--sans);color:var(--text-muted);text-align:right;flex:0 0 32px}.business-line-row.bl-complete{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-radius:6px;margin-left:-8px;margin-right:-8px;padding:3px 8px}[data-theme=dark] .business-line-row.bl-complete{background:linear-gradient(135deg,#052e16,#064e3b)}.bl-check{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex;box-shadow:0 1px 4px #22c55e4d}.bl-complete-label{font-size:10px;font-weight:700;font-family:var(--sans);color:#16a34a;text-transform:uppercase;letter-spacing:.03em;margin-left:auto}[data-theme=dark] .bl-complete-label{color:#4ade80}.bl-complete .bl-name{color:#16a34a}[data-theme=dark] .bl-complete .bl-name{color:#4ade80}.admin-undo-btn{color:#ea580c;background:#fff7ed;border-color:#fdba74;gap:4px;font-weight:600}.admin-undo-btn:hover{background:#fed7aa;border-color:#ea580c}[data-theme=dark] .admin-undo-btn{color:#fb923c;background:#431407;border-color:#9a3412}[data-theme=dark] .admin-undo-btn:hover{background:#7c2d12}.admin-bl-row{align-items:center}.admin-bl-hint{color:var(--text-muted);margin:6px 0 0;font-size:11px;font-style:italic}.input-computed{cursor:not-allowed;color:var(--text-muted)!important;background:#f3f4f6!important}[data-theme=dark] .input-computed{background:#2d2d44!important}.feature-notes{color:var(--text-muted);opacity:.85;margin:3px 0 0;font-size:10.5px}.export-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:24px;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.export-modal{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:100%;max-width:720px;max-height:85vh;animation:.2s ease-out slideUp;display:flex;box-shadow:0 24px 80px #00000040}.export-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.export-modal-header h2{font-size:18px;font-weight:700;font-family:var(--sans);color:var(--text-heading);align-items:center;gap:8px;margin:0;display:flex}.export-modal-header p{color:var(--text-muted);margin:4px 0 0;font-size:13px}.export-modal-body{background:var(--border);flex:1;gap:1px;min-height:0;display:flex;overflow:hidden}.export-col{background:var(--card-bg);flex-direction:column;flex:1;padding:16px;display:flex;overflow-y:auto}.export-col-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.export-col-header h3{font-size:11px;font-weight:700;font-family:var(--sans);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0}.export-product-list{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.export-product-check{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:8px 10px;font-size:13px;transition:all .15s;display:flex}.export-product-check:hover{background:#f8f8fc}[data-theme=dark] .export-product-check:hover{background:#1f1f36}.export-product-check:has(input:checked){background:#eef2ff;border-color:#c7d2fe}[data-theme=dark] .export-product-check:has(input:checked){background:#1e1b4b;border-color:#4338ca}.export-product-check input[type=checkbox]{accent-color:#4f46e5;flex-shrink:0;margin:0}.export-product-check-icon{width:24px;height:24px;color:var(--text-muted);background:#f3f4f6;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}[data-theme=dark] .export-product-check-icon{background:#2d2d44}.export-product-check-icon img{object-fit:cover;border-radius:6px;width:100%;height:100%}.export-product-check-name{font-weight:600;font-family:var(--sans);color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.export-selection-summary{color:var(--text-muted);text-align:center;border-top:1px solid var(--border);margin-top:10px;padding-top:10px;font-size:11px;font-weight:500}.export-section-list{flex-direction:column;gap:4px;display:flex}.export-section-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--sans);color:var(--text-muted);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:9px 12px;transition:all .15s;display:flex}.export-section-toggle:hover{background:#f8f8fc}[data-theme=dark] .export-section-toggle:hover{background:#1f1f36}.export-section-toggle:has(input:checked){color:#4f46e5;background:#eef2ff;border-color:#c7d2fe}[data-theme=dark] .export-section-toggle:has(input:checked){color:#a5b4fc;background:#1e1b4b;border-color:#4338ca}.export-section-toggle input[type=checkbox]{display:none}.export-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:16px 24px;display:flex}.export-btn{justify-content:center;min-width:160px}.export-spinner{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.export-orientation-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);margin-right:auto;display:flex;overflow:hidden}.export-orient-btn{font-size:12px;font-weight:600;font-family:var(--sans);background:var(--card-bg);color:var(--text-muted);cursor:pointer;border:none;align-items:center;gap:5px;padding:6px 12px;transition:all .15s;display:flex}.export-orient-btn:first-child{border-right:1px solid var(--border)}.export-orient-btn.active{color:#4f46e5;background:#eef2ff}[data-theme=dark] .export-orient-btn.active{color:#a5b4fc;background:#1e1b4b}.export-orient-btn:hover:not(.active){background:#f8f8fc}[data-theme=dark] .export-orient-btn:hover:not(.active){background:#1f1f36}.export-presets{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.export-preset{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);cursor:pointer;text-align:left;color:var(--text-muted);align-items:center;gap:12px;padding:12px 14px;transition:all .15s;display:flex}.export-preset div{flex-direction:column;display:flex}.export-preset strong{font-size:13px;font-weight:600;font-family:var(--sans);color:var(--text-heading)}.export-preset span{color:var(--text-muted);margin-top:1px;font-size:11px}.export-preset:hover{background:#fafaff;border-color:#c7d2fe}[data-theme=dark] .export-preset:hover{background:#1e1b4b;border-color:#4338ca}.export-preset-active{color:#4f46e5;background:#eef2ff!important;border-color:#4f46e5!important}[data-theme=dark] .export-preset-active{color:#a5b4fc;background:#1e1b4b!important;border-color:#6366f1!important}.export-preset-active strong{color:#4f46e5}[data-theme=dark] .export-preset-active strong{color:#a5b4fc}.export-custom-sections{border-top:1px solid var(--border);padding-top:12px}@media (width<=600px){.export-modal-body{flex-direction:column}.export-modal{max-height:92vh}}.pdf-render{color:#1a1a2e;-webkit-font-smoothing:antialiased;background:linear-gradient(#fff 0%,#f5f3ff 35%,#eef2ff 60%,#f8fafc 100%);width:794px;font-family:Inter,Helvetica Neue,Arial,sans-serif;font-size:12px;line-height:1.5;position:absolute;top:0;left:-9999px}.pdf-cover{color:#fff;box-sizing:border-box;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#4f46e5 100%);flex-direction:column;justify-content:center;height:1122px;max-height:1122px;padding:60px 56px 48px;display:flex;position:relative;overflow:hidden}.pdf-cover-has-template{background:0 0;padding:0}.pdf-cover-has-template:before,.pdf-cover-has-template:after{display:none!important}.pdf-cover-template-bg{object-fit:cover;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.pdf-cover-content{z-index:1;box-sizing:border-box;flex-direction:column;justify-content:center;height:100%;display:flex;position:relative}.pdf-cover-has-template .pdf-cover-content{background:0 0;padding:60px 56px 48px}.pdf-back-cover{page-break-before:always;height:1122px;max-height:1122px;position:relative;overflow:hidden}.pdf-back-cover-bg{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.pdf-landscape .pdf-back-cover{height:793px;max-height:793px}.pdf-cover:before{content:"";pointer-events:none;background:radial-gradient(#a855f740 0%,#0000 70%);width:55%;height:180%;position:absolute;top:-40%;right:-15%}.pdf-cover-brand{z-index:1;align-items:center;gap:12px;margin-bottom:40px;display:flex;position:relative}.pdf-logo{width:auto;height:28px}.pdf-logo-text{letter-spacing:.18em;color:#fff;text-transform:uppercase;font-family:Space Grotesk,Inter,sans-serif;font-size:18px;font-weight:800}.pdf-client-logo{object-fit:contain;filter:brightness(0)invert();max-width:120px;height:30px}.pdf-brand-sep{color:#ffffff59;font-size:20px;font-weight:300}.pdf-client-name{letter-spacing:-.3px;font-family:Space Grotesk,Inter,sans-serif;font-size:20px;font-weight:700}.pdf-cover-title{letter-spacing:-.8px;z-index:1;margin:0 0 12px;font-family:Space Grotesk,Inter,sans-serif;font-size:36px;font-weight:700;position:relative}.pdf-cover-subtitle{color:#ffffffa6;z-index:1;max-width:460px;margin:0 0 40px;font-size:14px;line-height:1.6;position:relative}.pdf-cover-stats{z-index:1;gap:16px;display:flex;position:relative}.pdf-stat{text-align:center;background:#ffffff1f;border:1px solid #ffffff26;border-radius:14px;min-width:120px;padding:20px 28px}.pdf-stat-value{letter-spacing:-.5px;margin-bottom:2px;font-family:Space Grotesk,Inter,sans-serif;font-size:28px;font-weight:700;display:block}.pdf-stat-label{color:#ffffff8c;text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:500;display:block}.pdf-cover-date{z-index:1;color:#ffffff73;margin-top:32px;font-size:12px;font-weight:500;position:relative}.pdf-category{padding:32px 56px 8px}.pdf-category-header{border-bottom:2px solid #e2e4ea;align-items:center;gap:12px;margin-bottom:16px;padding:24px 0 12px;display:flex}.pdf-category-header h2{color:#1a1a2e;margin:0;font-family:Space Grotesk,Inter,sans-serif;font-size:20px;font-weight:700}.pdf-category-progress{color:#4f46e5;background:#eef2ff;border-radius:99px;padding:3px 10px;font-family:Space Grotesk,Inter,sans-serif;font-size:12px;font-weight:700}.pdf-product{page-break-inside:avoid;break-inside:avoid;background:#fff;border:none;border-left:3px solid #c7d2fe;border-radius:0;margin-bottom:16px;padding:20px 24px 20px 27px}.pdf-product-header{margin-bottom:12px}.pdf-product-title-row{align-items:center;gap:10px;margin-bottom:6px;display:flex}.pdf-product-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex;overflow:hidden}.pdf-product-icon img{object-fit:cover;border-radius:10px;width:100%;height:100%}.pdf-product-name{color:#1a1a2e;flex:1;margin:0;font-family:Space Grotesk,Inter,sans-serif;font-size:16px;font-weight:700}.pdf-status{text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-flex}.pdf-status-green{color:#059669;background:#ecfdf5}.pdf-status-blue{color:#2563eb;background:#eff6ff}.pdf-status-orange{color:#ea580c;background:#fff7ed}.pdf-status-gray{color:#6b7280;background:#f3f4f6}.pdf-status-purple{color:#7c3aed;background:#f5f3ff}.pdf-status-red{color:#dc2626;background:#fef2f2}.pdf-product-desc{color:#6b7280;margin:0;font-size:12px;line-height:1.5}.pdf-progress-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.pdf-progress-track{background:#edeef3;border-radius:99px;flex:1;height:8px;overflow:hidden}.pdf-progress-fill{border-radius:99px;height:100%;transition:none}.pdf-progress-label{color:#1a1a2e;text-align:right;min-width:36px;font-family:Space Grotesk,Inter,sans-serif;font-size:14px;font-weight:700}.pdf-business-lines{background:#f8f9fb;border:1px solid #e2e4ea;border-radius:8px;margin-bottom:12px;padding:10px 14px}.pdf-bl-title{text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;margin-bottom:6px;font-size:9px;font-weight:700}.pdf-bl-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.pdf-bl-row:last-child{margin-bottom:0}.pdf-bl-name{color:#374151;text-overflow:ellipsis;white-space:nowrap;flex:0 0 100px;font-size:11px;font-weight:600;overflow:hidden}.pdf-bl-track{background:#e2e4ea;border-radius:99px;flex:1;height:5px;overflow:hidden}.pdf-bl-fill{border-radius:99px;height:100%}.pdf-bl-pct{color:#6b7280;text-align:right;min-width:28px;font-size:11px;font-weight:700}.pdf-bl-complete{background:#f0fdf4;border-radius:4px;margin-left:-6px;margin-right:-6px;padding:2px 6px}.pdf-bl-check{color:#fff;background:#22c55e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;font-size:8px;font-weight:700;display:inline-flex}.pdf-bl-complete .pdf-bl-name{color:#16a34a}.pdf-bl-complete-label{color:#16a34a;text-transform:uppercase;letter-spacing:.03em;margin-left:auto;font-size:10px;font-weight:700}.pdf-custom-fields{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.pdf-cf{color:#374151;background:#f3f4f6;border-radius:4px;padding:2px 8px;font-size:10px}.pdf-cf strong{color:#6b7280;font-weight:600}.pdf-notes{margin:0 0 10px;padding:0;list-style:none}.pdf-notes li{color:#374151;margin-bottom:3px;padding-left:12px;font-size:11px;line-height:1.6;position:relative}.pdf-notes li:before{content:"";background:#9ca3af;border-radius:50%;width:4px;height:4px;position:absolute;top:7px;left:0}.pdf-meta-row{flex-wrap:wrap;gap:12px;margin-bottom:10px;display:flex}.pdf-milestone{color:#ea580c;font-size:11px;font-weight:600}.pdf-eta{color:#4f46e5;background:#eef2ff;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600}.pdf-features{margin-top:8px}.pdf-features-header{text-transform:uppercase;letter-spacing:.04em;color:#9ca3af;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:10px;font-weight:700;display:flex}.pdf-features-count{color:#4f46e5;text-transform:none;letter-spacing:0;font-weight:600}.pdf-features-table{border-collapse:collapse;width:100%;font-size:11px}.pdf-features-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;border-bottom:1px solid #e2e4ea;padding:6px 8px;font-size:9px;font-weight:700}.pdf-features-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:6px 8px}.pdf-features-table tr:last-child td{border-bottom:none}.pdf-feature-delivered td{background:#f0fdf4}.pdf-feature-delivered td:first-child{border-radius:4px 0 0 4px}.pdf-feature-delivered td:last-child{border-radius:0 4px 4px 0}.pdf-feature-bar-cell{align-items:center;gap:6px;display:flex}.pdf-feature-bar-track{background:#edeef3;border-radius:99px;flex-shrink:0;width:60px;height:4px;overflow:hidden}.pdf-feature-bar-fill{border-radius:99px;height:100%}.pdf-feature-bar-cell span{color:#6b7280;min-width:28px;font-size:10px;font-weight:700}.pdf-footer{color:#9ca3af;page-break-inside:avoid;break-inside:avoid;border-top:1px solid #e2e4ea;justify-content:space-between;align-items:center;margin-top:16px;padding:12px 56px;font-size:10px;display:flex}.pdf-landscape .pdf-cover{height:793px;max-height:793px}.pdf-landscape .pdf-category{padding:24px 64px 0}.pdf-landscape .pdf-product{padding:20px 28px}.tooltip-content{background:var(--text-heading);color:#fff;font-size:12px;font-family:var(--body);z-index:9999;-webkit-user-select:none;user-select:none;border-radius:8px;padding:6px 12px;font-weight:500;line-height:1;animation:.15s ease-out tooltipFadeIn;box-shadow:0 4px 12px #00000026}[data-theme=dark] .tooltip-content{color:#1a1a2e;background:#e5e7eb}.tooltip-arrow{fill:var(--text-heading)}[data-theme=dark] .tooltip-arrow{fill:#e5e7eb}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@media print{body{font-size:11px;color:#000!important;background:#fff!important}.dashboard{max-width:none;padding:0}.dashboard-hero{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#1e1b4b!important;border-radius:0!important;margin:0!important;padding:24px!important}.dashboard-toolbar,.dashboard-utility-bar,.theme-toggle,.skip-link{display:none}.product-grid{gap:12px;grid-template-columns:repeat(2,1fr)!important}.product-card{page-break-inside:avoid;break-inside:avoid;border:1px solid #ddd;padding:16px;box-shadow:none!important}.product-card:hover{box-shadow:none;transform:none}.product-card:before{display:none}.product-card,.feature-row{animation:none!important}.features-list-wrapper{opacity:1!important;max-height:none!important;overflow:visible!important}.features-toggle{display:none}.progress-bar-fill,.status-badge,.feature-check,.stat-card,.stat-card-ring{-webkit-print-color-adjust:exact;print-color-adjust:exact}.dashboard-footer{font-size:10px}.password-gate{display:none}.product-group-header{cursor:default}.dashboard-toolbar{background:0 0;position:static}.category-nav,.logout-btn{display:none}}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:var(--sans);pointer-events:auto;align-items:center;gap:8px;padding:10px 18px;animation:.25s ease-out toastIn;display:flex;box-shadow:0 4px 16px #0000001f,0 1px 3px #0000000f}.toast-success{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0}[data-theme=dark] .toast-success{color:#34d399;background:#052e16;border-color:#166534}.toast-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.toast-icon{font-size:14px;font-weight:700}.toast-exit{animation:.3s ease-in forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(.95)}}.search-highlight{color:#92400e;background:#fef9c3;border-radius:2px;padding:0 2px}[data-theme=dark] .search-highlight{color:#fde68a;background:#713f12}.no-results{text-align:center;color:var(--text-muted);flex-direction:column;grid-column:1/-1;align-items:center;gap:12px;padding:48px 24px;display:flex}.no-results p{margin:0;font-size:14px}.clear-filters-btn{color:#dc2626}.category-nav{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.category-nav-btn{border:1px solid var(--border);font-size:12px;font-weight:600;font-family:var(--sans);color:var(--text-muted);background:var(--card-bg);cursor:pointer;border-radius:99px;align-items:center;gap:6px;padding:5px 14px;transition:all .2s;display:inline-flex}.category-nav-btn:hover{color:#7c3aed;border-color:#7c3aed}.category-nav-count{width:18px;height:18px;color:var(--text-muted);background:#f3f4f6;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}[data-theme=dark] .category-nav-count{background:#2d2d44}.logout-btn{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;font-weight:500;font-family:var(--sans);color:var(--text-muted);background:var(--card-bg);cursor:pointer;align-items:center;gap:4px;padding:4px 10px;transition:all .15s;display:inline-flex}.logout-btn:hover{color:#dc2626;border-color:#dc2626}.admin-section-toggle{cursor:pointer;width:100%;color:var(--text-muted);background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;display:flex}.admin-section-toggle-left{align-items:center;gap:8px;display:flex}.admin-section-toggle h3{font-size:14px;font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0}.admin-section-body{margin-top:16px}.admin-section-badge{min-width:20px;height:20px;font-size:10px;font-weight:700;font-family:var(--sans);color:#4f46e5;background:#eef2ff;border-radius:99px;justify-content:center;align-items:center;padding:0 6px;display:inline-flex}[data-theme=dark] .admin-section-badge{color:#a5b4fc;background:#1e1b4b}.sidebar-toggle{cursor:pointer;color:#ffffffb3;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:inline-flex}.sidebar-toggle:hover{color:#fff;background:#fff3}.admin-save-status{color:#ffffff80;font-size:11px;font-family:var(--sans);font-weight:500}.help-tip-wrapper{cursor:help;align-items:center;margin-left:4px;display:inline-flex;position:relative}.help-tip-icon{color:#9ca3af;transition:color .15s}.help-tip-wrapper:hover .help-tip-icon{color:#7c3aed}.help-tip-bubble{color:#f3f4f6;font-size:11px;font-weight:400;font-family:var(--body);text-transform:none;letter-spacing:0;z-index:100;pointer-events:none;background:#1f2937;border-radius:8px;width:240px;padding:8px 12px;line-height:1.5;animation:.15s ease-out fadeIn;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.help-tip-bubble:after{content:"";border:5px solid #0000;border-top-color:#1f2937;position:absolute;top:100%;left:50%;transform:translate(-50%)}.status-select-row{flex-direction:column;gap:6px;display:flex}.status-select-row .status-badge{align-self:flex-start}.admin-empty-content{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;display:flex}.admin-empty-content h3{font-size:16px;font-weight:700;font-family:var(--sans);color:var(--text-heading);margin:0}.admin-empty-content p{max-width:320px;margin:0;font-size:13px}.admin-empty-products{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:32px;display:flex}.admin-empty-products p{margin:0;font-size:14px;font-weight:600}.admin-empty-hint{font-size:12px!important;font-weight:400!important}.login-page{background:var(--gradient-surface);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);text-align:center;width:100%;max-width:420px;padding:40px 36px}.login-icon{background:var(--gradient-brand);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:20px;display:inline-flex}.login-title{font-family:var(--sans);color:var(--text-heading);margin:0 0 8px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-muted);margin:0 0 28px;font-size:13px;line-height:1.5}.login-form{text-align:left}.login-field{margin-bottom:16px}.login-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.login-field .input{width:100%}.login-error{color:#991b1b;border-radius:var(--radius-sm);background:#fee2e2;margin-bottom:16px;padding:10px 14px;font-size:13px}[data-theme=dark] .login-error{color:#fca5a5;background:#3b1111}.login-submit{justify-content:center;gap:8px;width:100%;margin-top:8px;padding:12px 20px;font-size:14px;font-weight:600}.login-loading{color:var(--text-muted);padding:40px 0;font-size:14px}.admin-user-info{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.admin-role-badge{text-transform:uppercase;letter-spacing:.5px;color:#7c3aed;background:#7c3aed26;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}[data-theme=dark] .admin-role-badge{color:#c4b5fd;background:#7c3aed40}.admin-sidebar-team{border-top:1px solid var(--border);margin-top:8px;padding:12px 16px}.admin-sidebar-team-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);cursor:pointer;background:0 0;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.admin-sidebar-team-btn:hover{background:#4f46e50f;border-color:#4f46e54d}.admin-sidebar-team-btn.active{color:#4f46e5;background:#4f46e51a;border-color:#4f46e5}[data-theme=dark] .admin-sidebar-team-btn.active{color:#a5b4fc;background:#4f46e533;border-color:#4f46e5}.team-management{padding:4px 0}.team-member-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);justify-content:space-between;align-items:flex-start;margin-bottom:8px;padding:14px 16px;display:flex}.team-member-info{flex:1}.team-member-name{color:var(--text-heading);align-items:center;gap:6px;margin-bottom:2px;font-size:14px;font-weight:600;display:flex}.team-member-email{color:var(--text-muted);margin-bottom:6px;font-size:12px}.team-member-projects{flex-wrap:wrap;gap:4px;display:flex}.team-project-tag{color:#4f46e5;background:#4f46e51a;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}[data-theme=dark] .team-project-tag{color:#a5b4fc;background:#4f46e533}.team-member-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.team-form{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);margin-top:12px;padding:20px}.team-form h4{color:var(--text-heading);margin:0 0 16px;font-size:15px;font-weight:600}.team-slug-checkboxes{flex-wrap:wrap;gap:8px 16px;margin-top:4px;display:flex}.team-slug-checkbox{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.team-slug-checkbox input[type=checkbox]{accent-color:#4f46e5}.team-form-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.activity-log-list{flex-direction:column;gap:6px;display:flex}.activity-log-entry{border-bottom:1px solid var(--border);align-items:baseline;gap:6px;padding:6px 0;font-size:13px;line-height:1.5;display:flex}.activity-log-entry:last-child{border-bottom:none}.activity-log-date{color:var(--text-muted);white-space:nowrap;font-size:12px;font-weight:600}.activity-log-separator{color:var(--text-muted)}.activity-log-user{color:#4f46e5;white-space:nowrap;font-size:12px;font-weight:600}[data-theme=dark] .activity-log-user{color:#a5b4fc}.activity-log-action{color:var(--text)}.activity-log-details{color:var(--text-muted);font-size:11px;font-style:italic}.export-label{white-space:nowrap;margin-left:6px;font-size:13px;font-weight:500}.utility-btn:has(.export-label){gap:0;width:auto;padding:0 12px}@media (width<=700px){.export-label{display:none}.utility-btn:has(.export-label){width:32px;padding:0}}
