:root{color:#1d2430;font-synthesis:none;text-rendering:optimizelegibility;--color-brand:#0f766e;--color-brand-soft:#f0fdfa;--color-surface:#fff;--color-canvas:#eef2f7;--color-border:#e2e8f0;--color-border-strong:#d8e0ea;--color-text:#1e293b;--color-text-muted:#64748b;--sidebar-width:236px;--header-height:52px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--radius-sm:6px;--radius-md:10px;--radius-lg:12px;--shadow-card:0 1px 2px #0f172a0d, 0 4px 16px #0f172a0f;--shadow-card-hover:0 6px 20px #0f172a14;background:#eef2f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}.auth-shell,.session-shell{grid-template-columns:minmax(320px,480px) minmax(260px,420px);justify-content:center;align-items:center;gap:40px;min-height:100vh;padding:32px;display:grid}.auth-panel,.summary-panel,.session-panel{background:#fff;border:1px solid #d8e0ea;border-radius:8px;box-shadow:0 18px 60px #1c29381f}.auth-panel,.session-panel{padding:32px}.summary-panel{color:#eef5ff;background:#152033;padding:28px}.brand-mark{justify-content:center;width:100%;max-width:180px;height:auto;margin:0 auto 24px;display:flex}.brand-mark img{object-fit:contain;max-width:100%;height:auto}.brand-mark.sidebar-brand{justify-content:flex-start;max-width:140px;margin:0 auto 28px 0}.auth-header{text-align:center}.eyebrow{color:var(--color-brand);text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px;font-size:.78rem;font-weight:800}h1,h2{color:#172033;letter-spacing:0;margin:0}.summary-panel h2{color:#fff}.supporting-text{color:#5d6b7d;margin:12px 0 0;line-height:1.55}.dashboard-container .supporting-text{margin-top:4px}.mode-switch{background:#edf2f7;border-radius:8px;grid-template-columns:1fr 1fr;gap:8px;margin:28px 0 22px;padding:4px;display:grid}.mode-switch button,.btn,.submit-button,.secondary-button,.btn-primary,.btn-secondary,.btn-danger,.btn-success,.btn-ghost{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:0 14px;font-size:.875rem;font-weight:700;line-height:1.2;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;display:inline-flex}.btn-block{width:100%}.submit-button,.btn-primary{color:#fff;background:var(--color-brand);margin-top:8px;box-shadow:0 1px 2px #0f766e33}.submit-button:hover:not(:disabled),.btn-primary:hover:not(:disabled){background:#0d6b64}.secondary-button,.btn-secondary{color:#152033;background:#e7edf4;border-color:#dbe3ed;width:100%;margin-top:22px}.secondary-button:hover:not(:disabled),.btn-secondary:hover:not(:disabled){background:#dde5ef}.btn-danger{color:#991b1b;background:#fee2e2;border-color:#fecaca}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-success{color:#14532d;background:#dcfce7;border-color:#bbf7d0}.btn-success:hover:not(:disabled){background:#bbf7d0}.btn-ghost{color:var(--color-text-muted);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){color:var(--color-brand);background:var(--color-brand-soft)}.submit-button:disabled,.btn-primary:disabled,.secondary-button:disabled,.btn:disabled{cursor:not-allowed;opacity:.65}.page-header-actions .submit-button,.page-header-actions .secondary-button,.page-header-actions .btn-primary,.page-header-actions .btn-secondary,.dashboard-panel-header .secondary-button,.dashboard-quick-actions .submit-button,.dashboard-quick-actions .secondary-button,.btn-inline{width:auto;margin-top:0}.icon-button.danger,.btn-danger.icon-button{width:38px;height:38px;padding:0}.mode-switch button{color:#536174;background:0 0}.mode-switch .active{color:#102036;background:#fff;box-shadow:0 1px 6px #1824341f}.auth-form{gap:14px;display:grid}label{color:#445166;gap:7px;font-size:.9rem;font-weight:700;display:grid}input,select,textarea{border-radius:var(--radius-sm);color:#111827;background:#fff;border:1px solid #cbd5e1;width:100%;min-height:38px;padding:0 12px;transition:border-color .15s,box-shadow .15s}textarea{resize:vertical;min-height:88px;padding:10px 12px;line-height:1.45}input:disabled,select:disabled,textarea:disabled{opacity:.65;cursor:not-allowed;color:#64748b;background:#f8fafc}input::placeholder,textarea::placeholder{color:#94a3b8}input:focus,select:focus,textarea:focus{border-color:#0f766e;outline:3px solid #0f766e2e}.submit-button:disabled{cursor:wait;opacity:.7}.signed-user .secondary-button.compact{margin-top:var(--space-2)}.empty-state{text-align:center;padding:var(--space-5) var(--space-4);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);background:linear-gradient(#fafbfc 0%,#f8fafc 100%);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:56px;height:56px;margin-bottom:var(--space-3);background:var(--color-brand-soft);color:var(--color-brand);border-radius:999px;place-items:center;display:grid}.empty-state-title{color:var(--color-text);margin-bottom:6px;font-size:.95rem;font-weight:700;display:block}.empty-state-description{max-width:360px;color:var(--color-text-muted);margin:0;font-size:.875rem;line-height:1.5}.empty-state-action{margin-top:var(--space-4)}.empty-state-action .submit-button,.empty-state-action .secondary-button,.empty-state-action .btn-primary,.empty-state-action .btn-secondary{width:auto;margin-top:0}.form-error{color:#991b1b;background:#fee2e2;border-radius:6px;padding:12px;font-weight:700}.form-success{color:#14532d;background:#dcfce7;border-radius:6px;margin-bottom:14px;padding:12px;font-weight:700}.password-wrapper{align-items:center;display:flex;position:relative}.password-wrapper input{padding-right:40px}.password-toggle{cursor:pointer;color:#64748b;background:0 0;border:none;justify-content:center;align-items:center;height:100%;min-height:auto;padding:0;display:flex;position:absolute;right:12px}.password-toggle:hover{color:#0f766e}.portal-auth-tabs{gap:.5rem;margin-bottom:1.25rem;display:flex}.portal-auth-tab{color:#334155;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.65rem .75rem;font-weight:600;display:inline-flex}.portal-auth-tab-active{color:#fff;background:#0f766e;border-color:#0f766e}.forgot-password-link{color:#64748b;text-align:right;cursor:pointer;background:0 0;border:none;justify-content:flex-end;min-height:auto;margin-top:-6px;padding:0;font-size:.8rem;font-weight:600}.forgot-password-link:hover{color:#0f766e;text-decoration:underline}.auth-institutional-shell{background:#f4f7fb;min-height:100vh;display:flex;overflow-x:hidden}.auth-institutional-brand{color:#e8f0ff;background:linear-gradient(165deg,#071525 0%,#0f2744 42%,#0a2e28 100%);flex:0 0 44%;max-width:560px;min-height:100vh;position:relative;overflow:hidden}.auth-institutional-brand__inner{z-index:1;flex-direction:column;gap:20px;height:100%;min-height:100vh;padding:clamp(28px,4vh,48px) clamp(24px,3vw,48px) clamp(28px,4vh,40px);display:flex;position:relative;overflow-y:auto}.auth-institutional-brand__slant{background:inherit;clip-path:polygon(100% 0,0 0,100% 100%);pointer-events:none;width:56px;height:100%;position:absolute;top:0;right:-1px;box-shadow:inset -2px 0 #34d39959}.auth-institutional-brand__logo{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.auth-institutional-brand__logo img{object-fit:contain;max-width:148px;height:auto}.auth-institutional-brand__logo span{letter-spacing:.14em;text-transform:uppercase;color:#e8f0ffb8;font-size:.72rem;font-weight:800}.auth-institutional-brand__title{color:#fff;margin:0;font-size:clamp(1.35rem,2.2vw,1.85rem);font-weight:800;line-height:1.25}.auth-institutional-brand__title span{color:#34d399}.auth-institutional-brand__lead{color:#e8f0ffd1;max-width:36ch;margin:0;font-size:.95rem;line-height:1.55}.auth-institutional-benefits{gap:14px;margin:8px 0 0;padding:0;list-style:none;display:grid}.auth-institutional-benefits li{grid-template-columns:auto 1fr;align-items:start;gap:12px;display:grid}.auth-institutional-benefits__icon{color:#6ee7b7;background:#0f766e2e;border:1px solid #34d39973;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.auth-institutional-benefits strong{color:#fff;margin-bottom:2px;font-size:.88rem;display:block}.auth-institutional-benefits p{color:#e8f0ffb8;margin:0;font-size:.82rem;line-height:1.45}.auth-contact-links{border-top:1px solid #ffffff1a;margin-top:auto;padding-top:16px}.auth-contact-links__heading{letter-spacing:.1em;text-transform:uppercase;color:#34d399;margin:0 0 10px;font-size:.72rem;font-weight:800}.auth-contact-links__list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.auth-contact-links__list a{color:#e8f0ffeb;align-items:center;gap:10px;font-size:.88rem;font-weight:600;text-decoration:none;transition:color .15s;display:inline-flex}.auth-contact-links__list a:hover{color:#6ee7b7}.auth-contact-links__tagline{color:#e8f0ffad;align-items:flex-start;gap:8px;margin:16px 0 0;font-size:.8rem;line-height:1.5;display:flex}.auth-contact-links--compact{border-top:none;margin-top:0;padding-top:0}.auth-contact-links--compact .auth-contact-links__heading{text-align:center;color:var(--color-brand)}.auth-contact-links--compact .auth-contact-links__list a{color:var(--color-text)}.auth-institutional-form-area{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-width:0;padding:clamp(20px,3vw,40px);display:flex}.auth-institutional-panel{background:#fff;border:1px solid #dbe3ed;border-radius:12px;width:100%;max-width:440px;padding:clamp(24px,3vw,36px);box-shadow:0 16px 48px #0f172a14}.auth-institutional-panel .auth-form{margin-top:4px}.auth-institutional-panel input,.auth-institutional-panel select,.auth-institutional-panel textarea{min-height:44px;font-size:16px}.auth-institutional-panel .submit-button,.auth-institutional-panel .secondary-button{min-height:44px}.auth-form-header{text-align:center;margin-bottom:20px}.auth-form-header__icon{width:52px;height:52px;color:var(--color-brand);background:var(--color-brand-soft);border:2px solid #0f766e59;border-radius:999px;justify-content:center;align-items:center;margin:0 auto 14px;display:inline-flex}.auth-form-header h1{font-size:clamp(1.25rem,2vw,1.5rem)}.auth-whatsapp-cta{text-align:center;color:var(--color-text-muted);margin:20px 0 0;font-size:.88rem}.auth-whatsapp-cta a{color:var(--color-brand);font-weight:700;text-decoration:none}.auth-whatsapp-cta a:hover{text-decoration:underline}.auth-institutional-mobile-contacts{background:#fff;border:1px solid #dbe3ed;border-radius:12px;width:100%;max-width:440px;padding:16px 18px;display:none}@media (width<=1024px){.auth-institutional-brand{flex-basis:40%;max-width:480px}.auth-institutional-brand__inner{padding-right:36px}.auth-institutional-benefits{gap:10px}}@media (width<=900px){.auth-institutional-shell{background:#eef2f7;flex-direction:column;min-height:100vh}.auth-institutional-brand{display:none}.auth-institutional-form-area{flex:1;justify-content:flex-start;padding:18px 16px 24px}.auth-institutional-panel{max-width:100%;box-shadow:0 8px 28px #0f172a0f}.auth-institutional-mobile-contacts{display:block}}@media (height<=760px) and (width>=901px){.auth-institutional-brand__inner{gap:14px;padding-top:24px;padding-bottom:24px}.auth-institutional-benefits{gap:10px}.auth-institutional-benefits p{font-size:.78rem}}.summary-panel ul{color:#d7e4f4;margin:18px 0 0;padding-left:20px;line-height:1.8}.session-shell{grid-template-columns:minmax(320px,560px)}.session-panel dl{gap:12px;margin:24px 0 0;display:grid}.session-panel dl div{background:#f4f7fb;border-radius:6px;gap:4px;padding:12px;display:grid}dt{color:#64748b;text-transform:uppercase;font-size:.82rem;font-weight:800}dd{overflow-wrap:anywhere;margin:0}.loading-screen{color:#334155;place-items:center;min-height:100vh;font-weight:800;display:grid}@media (width<=860px){.auth-shell{grid-template-columns:1fr;gap:20px;padding:18px}.auth-panel,.summary-panel,.session-panel{padding:22px}}.admin-shell{grid-template-columns:var(--sidebar-width) 1fr;background:var(--color-canvas);min-height:100vh;display:grid}.admin-sidebar{min-height:100vh;padding:var(--space-4) var(--space-3);background:var(--color-surface);border-right:1px solid var(--color-border-strong);flex-direction:column;display:flex}.admin-content{padding:var(--space-4) var(--space-5);max-width:100%}.admin-nav{margin:var(--space-3) 0;flex:1;align-content:start;gap:4px;display:grid}.admin-nav button{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);color:#445166;cursor:pointer;background:0 0;border:0;min-height:36px;padding:0 10px;font-size:.875rem;font-weight:600;transition:background .15s,color .15s;display:flex}.admin-nav button:hover{background:#f1f5f9}.admin-nav button.active{color:#fff;background:var(--color-brand)}.admin-collapsible-trigger{border-top:1px solid #f1f5f9;margin-top:var(--space-3)!important;padding-top:var(--space-3)!important;font-weight:700!important}.admin-collapsible-trigger svg:last-child{margin-left:auto}.admin-collapsible-content{gap:2px;margin-top:4px;padding-left:10px;display:grid}.admin-nav-sub{min-height:34px!important;padding-left:8px!important;font-size:.8125rem!important}.admin-nav-sub.active{color:#fff;background:var(--color-brand)}.signed-user{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#f8fafc;gap:4px;margin-top:auto;padding:10px;display:grid}.signed-user .eyebrow{font-size:.68rem;margin-top:var(--space-2)!important}.signed-user-label{margin-top:var(--space-3)!important}.brand-mark.sidebar-brand{margin:0 0 var(--space-3) 0;max-width:120px}.signed-user span{font-weight:800}.signed-user small{color:#64748b;overflow-wrap:anywhere}.admin-grid{grid-template-columns:minmax(280px,360px) minmax(360px,1fr);align-items:start;gap:20px;display:grid}.admin-form,.data-panel,.loading-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-card)}.data-panel h1{color:var(--color-text);letter-spacing:-.01em;margin:0;font-size:1.25rem}.data-panel h2,.admin-form h2{color:var(--color-text);font-size:1rem;font-weight:700}.admin-form{gap:14px;display:grid}.stacked-form{gap:14px;margin-top:16px;display:grid}.supporting-text{color:var(--color-text-muted);margin:6px 0 0;font-size:.875rem;line-height:1.45}.data-list{gap:10px;margin-top:16px;display:grid}.data-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;grid-template-columns:1fr 38px;align-items:center;gap:12px;padding:12px;display:grid}.data-row div{gap:4px;min-width:0;display:grid}.data-row strong,.data-row span,.data-row small{overflow-wrap:anywhere}.data-row span{color:#526173}.data-row small{color:#64748b}.icon-button{cursor:pointer;color:#334155;background:#e7edf4;border:0;border-radius:6px;place-items:center;width:38px;height:38px;display:grid}.icon-button.danger{color:#991b1b;background:#fee2e2}.icon-button:disabled{cursor:not-allowed;opacity:.45}.icon-button.wide,.secondary-button.compact{width:100%;min-height:40px;margin-top:14px}.icon-button.wide{gap:8px;display:inline-flex}.action-strip{grid-template-columns:1fr 44px;align-items:center;gap:10px;display:grid}.pending-filters{grid-template-columns:minmax(220px,1fr) minmax(140px,180px) minmax(140px,180px) minmax(110px,130px)}.ticket-material-form-grid{grid-template-columns:minmax(220px,1fr) 120px 160px;gap:12px;display:grid}.table-scroll{width:100%;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th,.admin-table td{padding:10px var(--space-3);border-bottom:1px solid var(--color-border);text-align:left;vertical-align:middle}.admin-table th{color:#475569;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;font-size:.72rem;font-weight:700}.admin-table tr:hover td{background:#f8fafc}.status-badge{text-transform:uppercase;border-radius:999px;align-items:center;min-height:24px;padding:3px 9px;font-weight:800;display:inline-flex}.status-badge.open{color:#dc2626;background:#fee2e2}.status-badge.in_progress{color:#d97706;background:#fef3c7}.status-badge.blocked,.status-badge.cancelled{color:#475569;background:#e2e8f0}.status-badge.completed,.status-badge.resolved,.status-badge.closed{color:#16a34a;background:#dcfce7}.status-badge.waiting_customer{color:#2563eb;background:#dbeafe}.checkbox-list{border:1px solid #cbd5e1;border-radius:6px;gap:8px;max-height:260px;margin:0;padding:12px;display:grid;overflow:auto}.checkbox-list legend{color:#445166;padding:0 6px;font-size:.9rem;font-weight:800}.checkbox-list label{grid-template-columns:18px 1fr;align-items:center;gap:8px;font-weight:600;display:grid}.checkbox-list input{width:16px;height:16px;min-height:auto}.dashboard-container{gap:var(--space-4);flex-direction:column;display:flex}.dashboard-header{margin-bottom:0}.dashboard-header h1{letter-spacing:-.02em;font-size:1.35rem}.dashboard-grid{gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.dashboard-metrics-row-1,.dashboard-metrics-row-2{margin-bottom:0!important}.metric-card{padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);transition:box-shadow .15s,border-color .15s}.metric-card:hover{box-shadow:var(--shadow-card-hover);border-color:#cbd5e1;transform:none}.metric-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--color-text-muted);font-size:.8125rem;font-weight:600;display:flex}.metric-value{color:var(--color-text);font-size:1.75rem;font-weight:800;line-height:1.1}.metric-subtitle{color:#94a3b8;margin-top:6px;font-size:.72rem;line-height:1.35}.metric-card-compact{padding:var(--space-3) 14px}.metric-card-compact .metric-value{font-size:1.5rem}.metric-card-compact .metric-header{margin-bottom:6px}.billing-kpi-grid{margin-bottom:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr))}.metric-card-success{background:#f0fdf4;border-color:#bbf7d0}.metric-value-success{color:#14532d}.billing-module-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.billing-module-header-main{align-items:center;gap:var(--space-3);display:flex}.billing-module-header h1{margin:0 0 4px;font-size:1.5rem;font-weight:800}.billing-back-button{width:auto;margin-top:0;padding:.5rem}.billing-export-button{gap:8px;width:auto;margin-top:0;display:inline-flex}.billing-filters{align-items:flex-end;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.billing-filter-field{flex:1;min-width:200px}.billing-filter-field-narrow{flex:0 0 180px;min-width:160px}.billing-refresh-button{width:auto;min-height:38px;margin-top:0}.billing-error{margin-bottom:var(--space-4)}.billing-list{gap:var(--space-4);flex-direction:column;display:flex}.billing-customer-panel{padding:0;overflow:hidden}.billing-customer-header{justify-content:space-between;align-items:center;gap:var(--space-3);border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;background:#f8fafc;width:100%;padding:16px 20px;display:flex}.billing-customer-header-main{align-items:center;gap:12px;display:flex}.billing-customer-header h2{margin:0;font-size:1.1rem}.billing-customer-header-total{text-align:right}.billing-customer-header-total small{color:var(--color-text-muted);font-size:.7rem;font-weight:800;display:block}.billing-customer-header-total strong{color:var(--color-brand);font-size:1.1rem}.billing-customer-body{padding:20px}.billing-month-block{margin-bottom:var(--space-4)}.billing-month-block:last-child{margin-bottom:0}.billing-month-header{border-radius:var(--radius-sm);text-transform:capitalize;color:#475569;background:#f1f5f9;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 12px;font-weight:800;display:flex}.billing-col-qty{text-align:center}.billing-col-actions{text-align:right}.billing-ticket-subject{color:var(--color-text-muted);font-size:.75rem}.billing-date-cell{color:var(--color-text-muted)}.billing-price-edit,.billing-price-display,.billing-row-actions{align-items:center;gap:8px;display:flex}.billing-price-edit input{width:90px;padding:4px 8px}.billing-row-actions{justify-content:flex-end}.billing-awaiting-price{color:#f59e0b;text-transform:uppercase;background:#fffbeb;border:1px solid #fef3c7;border-radius:4px;padding:4px 8px;font-size:.7rem;font-weight:800}.billing-mark-billed{padding:6px 12px;font-size:.75rem}.billing-save-price{color:#22c55e}.billing-cancel-price{color:#ef4444}.dashboard-recent-panel h2{font-size:1.125rem}.dashboard-recent-table th,.dashboard-recent-table td{padding:10px 12px;font-size:.85rem}.loading-state{color:#64748b;place-items:center;padding:48px;font-weight:600;display:grid}@media (width<=920px){.admin-shell,.admin-grid{grid-template-columns:1fr}.master-detail-grid.has-detail .master-detail-list,.master-detail-grid:not(.has-detail) .master-detail-panel{display:none}.master-detail-back{width:auto;margin-top:0;margin-bottom:12px}.pending-filters,.ticket-material-form-grid{grid-template-columns:1fr}.admin-sidebar{border-bottom:1px solid #d8e0ea;border-right:0;min-height:auto}}.contact-action-link{color:#0f766e;word-break:break-all;box-sizing:border-box;background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px;align-items:center;gap:8px;min-height:44px;padding:10px 14px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.contact-action-link:hover{background:#ccfbf1}.customer-quick-contact{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.touch-target-button{min-width:44px;min-height:44px}.admin-main{flex-direction:column;width:100%;min-height:100vh;display:flex;overflow-x:hidden}.admin-header{padding:var(--space-2) var(--space-5);background:var(--color-surface);border-bottom:1px solid var(--color-border-strong);min-height:var(--header-height);flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}.notification-bell-container{display:inline-block;position:relative}.notification-mobile-backdrop{display:none}.notification-badge{color:#fff;background:#dc2626;border:2px solid #fff;border-radius:50%;padding:2px 6px;font-size:10px;font-weight:800;line-height:1;position:absolute;top:-4px;right:-4px}.notification-dropdown{z-index:1000;background:#fff;border:1px solid #d8e0ea;border-radius:8px;flex-direction:column;width:360px;max-height:520px;margin-top:12px;display:flex;position:absolute;top:100%;right:0;box-shadow:0 20px 50px #1c29382e}.notification-header{background:#f8fafc;border-bottom:1px solid #f1f5f9;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;padding:16px;display:flex}.notification-header h3{color:#1e293b;margin:0;font-size:.95rem;font-weight:800}.notification-list{flex:1;overflow-y:auto}.notification-item{cursor:pointer;border-bottom:1px solid #f1f5f9;padding:16px;transition:all .2s;position:relative}.notification-item:hover{background:#f1f5f9}.notification-item.unread{background:#f0f9ff;border-left:3px solid #0ea5e9}.notification-item.unread:hover{background:#e0f2fe}.notification-item-title{color:#1e293b;margin-bottom:4px;font-size:.88rem;font-weight:700}.notification-item-message{color:#475569;margin-bottom:6px;font-size:.82rem;line-height:1.4}.notification-item-time{color:#94a3b8;font-size:.75rem;font-weight:500}.notification-empty{text-align:center;color:#64748b;flex-direction:column;align-items:center;padding:48px 24px;display:flex}.notification-empty p{color:#334155;margin:0;font-size:.9rem;font-weight:600}.notification-empty-description{color:#94a3b8;max-width:260px;margin-top:8px;font-size:.8rem;font-weight:400;line-height:1.45}.portal-shell{background:var(--color-canvas);flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.portal-header{background:var(--color-surface);border-bottom:1px solid var(--color-border-strong);padding:10px var(--space-4);justify-content:space-between;align-items:center;gap:var(--space-3);min-height:var(--header-height);flex-shrink:0;display:flex}.portal-header-brand{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.portal-header-brand img{flex-shrink:0;height:32px}.portal-header-brand>div{flex-direction:column;align-items:flex-start;gap:2px;min-width:0;line-height:1.25;display:flex}.portal-header-title{color:#0f766e;white-space:nowrap;display:block}.portal-header-user{color:#64748b}.portal-header-logout{flex:none;width:auto;margin-top:0}.portal-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.portal-notification-bell{position:relative}.portal-pending-section{margin-top:20px}.portal-pending-section h2{color:#0f172a;margin:0 0 12px;font-size:1rem}.portal-pending-empty{color:#64748b;margin:0;font-size:.9rem}.portal-pending-list{flex-direction:column;gap:10px;display:flex}.portal-pending-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}.portal-pending-card-header{color:#0f172a;align-items:center;gap:8px;margin-bottom:8px;display:flex}.portal-pending-card-meta{color:#475569;flex-direction:column;gap:4px;font-size:.85rem;display:flex}.portal-header .secondary-button.portal-header-logout{width:auto;margin-top:0}.portal-page{margin:0}.portal-page-title{color:#0f172a;margin:0 0 4px;font-size:1.35rem}.portal-profile-card{margin-top:16px}.portal-profile-card-header{color:#0f766e;align-items:center;gap:8px;margin-bottom:16px;display:flex}.portal-profile-card-header h2{color:#0f172a;margin:0;font-size:1.05rem}.portal-profile-form{max-width:520px}.portal-profile-form input:disabled{color:#64748b;cursor:not-allowed;background:#f1f5f9}.portal-back-button{width:auto;margin-top:0;margin-bottom:16px}.portal-empty-state{text-align:center;color:#64748b;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;margin-top:24px;padding:32px 20px}.portal-empty-state strong{color:#334155;margin-bottom:6px;font-size:1rem;display:block}.portal-asset-list{gap:10px;margin-top:16px;display:grid}.portal-asset-card{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.portal-asset-card:hover{border-color:#99f6e4;transform:translateY(-1px);box-shadow:0 4px 14px #0f766e1a}.portal-asset-card-main{flex:1;min-width:0}.portal-asset-code{color:#0f766e;letter-spacing:.02em;font-size:.95rem;font-weight:800;display:block}.portal-asset-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-weight:600;display:block;overflow:hidden}.portal-asset-category{color:#64748b;margin-top:4px;font-size:.8rem;display:block}.portal-asset-card-aside{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.portal-ticket-list{margin-top:16px}.portal-tickets-toolbar{gap:12px;margin-top:16px;display:grid}.portal-tickets-search{color:#64748b;background:#fff;border:1px solid #cbd5e1;border-radius:10px;align-items:center;gap:10px;padding:0 14px;display:flex}.portal-tickets-search:focus-within{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f}.portal-tickets-search input{min-width:0;font:inherit;color:#1e293b;background:0 0;border:0;flex:1;padding:12px 0}.portal-tickets-search input:focus{outline:none}.portal-tickets-filters{flex-wrap:wrap;gap:8px;display:flex}.portal-tickets-filter{color:#475569;font:inherit;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:999px;margin-top:0;padding:8px 14px;font-size:.88rem;font-weight:600;transition:border-color .15s,background-color .15s,color .15s}.portal-tickets-filter:hover{color:#0f766e;border-color:#99f6e4}.portal-tickets-filter.is-active{color:#0f766e;background:#ecfdf5;border-color:#0f766e}.portal-tickets-counters{color:#64748b;flex-wrap:wrap;gap:16px;font-size:.88rem;display:flex}.portal-tickets-counters strong{color:#0f766e;font-weight:800}.portal-tickets-table tbody tr.portal-ticket-row{cursor:pointer;transition:background-color .12s}.portal-tickets-table tbody tr.portal-ticket-row:hover td{background:#ecfdf5}.portal-ticket-number{color:#0f766e;font-size:.92rem;font-weight:800}.portal-ticket-subject{color:#1e293b;font-weight:600;line-height:1.35}.portal-ticket-card{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:10px;padding:14px 16px;transition:border-color .15s,box-shadow .15s;display:block}.portal-ticket-card:hover{border-color:#99f6e4;box-shadow:0 4px 14px #0f766e14}.portal-ticket-card-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.portal-ticket-card-subject{color:#1e293b;margin-top:8px;font-weight:600;line-height:1.4}.portal-ticket-card-badges{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.portal-ticket-card-footer{color:#94a3b8;margin-top:10px;font-size:.78rem}.portal-badge-group{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.portal-status-hint{border-radius:var(--radius-sm);color:#0f766e;background:#f0fdfa;border:1px solid #99f6e4;margin:0;padding:10px 12px;font-size:.85rem;line-height:1.45}.portal-create-ticket-form{gap:var(--space-3);margin-top:0;display:grid}.portal-create-ticket-title{color:#0f172a;margin:0;font-size:1rem}.portal-detail-page{gap:14px;display:grid}.portal-detail-hero{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.portal-detail-hero h1{color:#0f766e;margin:0;font-size:1.35rem}.portal-detail-hero-subject{color:#334155;margin:6px 0 0;font-weight:600;line-height:1.4}.portal-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.portal-info-card--highlight{background:linear-gradient(#f0fdfa 0%,#fff 100%);border-color:#99f6e4}.portal-info-card-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:.75rem;font-weight:700;display:block}.portal-info-card-value{color:#1e293b;font-weight:700;line-height:1.35}.portal-description-box{white-space:pre-wrap;color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;font-size:.92rem;line-height:1.5}.portal-detail-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.portal-chat-section{margin-top:4px}.portal-chat-section h2{color:#0f172a;margin:0 0 12px;font-size:1rem}.portal-chat-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.portal-chat-messages{background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);flex-direction:column;gap:16px;height:440px;padding:16px;display:flex;overflow-y:auto}.portal-chat-empty{text-align:center;color:#64748b;max-width:280px;margin:auto;font-size:.9rem;line-height:1.5}.portal-chat-empty strong{color:#475569;margin-bottom:6px;display:block}.portal-chat-row{align-items:flex-end;gap:10px;max-width:88%;display:flex}.portal-chat-row.is-customer{flex-direction:row-reverse;align-self:flex-end}.portal-chat-row.is-staff{align-self:flex-start}.portal-chat-avatar{color:#fff;background:#64748b;border-radius:50%;flex-shrink:0;place-items:center;width:34px;height:34px;font-size:.82rem;font-weight:800;display:grid}.portal-chat-row.is-customer .portal-chat-avatar{background:#0f766e}.portal-chat-content{flex-direction:column;gap:4px;min-width:0;display:flex}.portal-chat-row.is-customer .portal-chat-content{align-items:flex-end}.portal-chat-author{color:#475569;font-size:.75rem;font-weight:700}.portal-chat-bubble{white-space:pre-wrap;word-break:break-word;border-radius:14px;padding:10px 14px;font-size:.92rem;line-height:1.45;box-shadow:0 1px 2px #0f172a0f}.portal-chat-row.is-staff .portal-chat-bubble{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-bottom-left-radius:4px}.portal-chat-row.is-customer .portal-chat-bubble{color:#fff;background:#0f766e;border-bottom-right-radius:4px}.portal-chat-time{color:#94a3b8;font-size:.68rem}.portal-chat-composer{background:#fff;border-top:1px solid #e2e8f0;align-items:flex-end;gap:10px;padding:12px;display:flex}.portal-chat-composer-main{flex:1;gap:8px;min-width:0;display:grid}.portal-chat-attach{cursor:pointer;color:#475569;background:#f8fafc;border:1px solid #cbd5e1;border-radius:50%;flex-shrink:0;place-items:center;width:44px;height:44px;margin-top:0;transition:border-color .15s,color .15s,background-color .15s;display:grid}.portal-chat-attach:hover{color:#0f766e;background:#ecfdf5;border-color:#0f766e}.portal-chat-attach input{display:none}.portal-chat-pending-file{color:#0f766e;background:#ecfdf5;border:1px solid #99f6e4;border-radius:10px;align-items:center;gap:8px;padding:8px 12px;font-size:.82rem;display:flex}.portal-chat-pending-file span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.portal-chat-pending-file-remove{color:#0f766e;font:inherit;cursor:pointer;background:0 0;border:0;margin-top:0;padding:0;font-size:.78rem;font-weight:700;text-decoration:underline}.portal-chat-upload-status{color:#64748b;margin:0;padding:0 12px 12px;font-size:.82rem}.portal-chat-attachments{gap:8px;margin-top:10px;display:grid}.portal-chat-attachment{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:#ffffff1f;border:1px solid #94a3b859;border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-size:.82rem;transition:background-color .15s,border-color .15s,transform .15s;display:flex}.portal-chat-row.is-staff .portal-chat-attachment{color:#1e293b;background:#f8fafc}.portal-chat-row.is-customer .portal-chat-attachment{background:#ffffff24;border-color:#ffffff40}.portal-chat-attachment:hover:not(:disabled){border-color:#99f6e4;transform:translateY(-1px)}.portal-chat-row.is-staff .portal-chat-attachment:hover:not(:disabled){background:#ecfdf5}.portal-chat-attachment:disabled{opacity:.7;cursor:wait}.portal-chat-attachment-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.portal-chat-attachment-size{opacity:.85;flex-shrink:0;font-size:.72rem}.portal-chat-input{resize:none;min-height:42px;max-height:120px;line-height:1.4;font:inherit;color:#1e293b;background:#f8fafc;border:1px solid #cbd5e1;border-radius:20px;flex:1;padding:10px 14px}.portal-chat-input:focus{background:#fff;border-color:#0f766e;outline:3px solid #0f766e26}.portal-chat-send{cursor:pointer;color:#fff;background:#0f766e;border:0;border-radius:50%;flex-shrink:0;place-items:center;width:44px;height:44px;margin-top:0;padding:0;display:grid}.portal-chat-send:disabled{opacity:.5;cursor:not-allowed}.portal-body{flex:1;min-height:0;display:flex}.portal-sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-shrink:0;width:240px;padding:20px 12px}.portal-sidebar-nav{gap:8px;display:grid}.portal-sidebar-nav button{justify-content:flex-start;gap:8px}.portal-main{padding:var(--space-4);flex:1;min-width:0}.portal-main-inner{width:100%;min-width:0;max-width:1040px;margin:0 auto}.portal-page{gap:var(--space-4);flex-direction:column;display:flex}.portal-detail-page{gap:var(--space-4)}.portal-detail-hero{margin-bottom:0}.portal-detail-grid-compact{gap:var(--space-2)}.portal-info-card{padding:var(--space-3)}.portal-description-box{padding:var(--space-3);font-size:.9rem;line-height:1.5}.portal-ticket-card,.portal-asset-card{box-shadow:var(--shadow-card)}.portal-pending-card{padding:var(--space-3)}.portal-bottom-nav{display:none}.portal-detail-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.portal-detail-grid--spaced{margin-bottom:18px}.portal-field small{color:#64748b}.portal-field div{color:#1e293b;font-weight:600}.portal-page-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.portal-page-header-action{flex-shrink:0;width:auto;margin-top:0}.portal-form-actions{gap:10px;display:flex}.portal-form-actions .secondary-button{margin-top:0}.portal-tickets-desktop{display:block}.portal-tickets-mobile{display:none}.portal-ticket-card strong{color:#0f766e}.portal-ticket-card-meta{color:#64748b;flex-wrap:wrap;gap:6px 12px;margin-top:8px;font-size:.85rem;display:flex}@media (width<=767px){.portal-header{padding:12px 16px}.portal-header-user{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.portal-sidebar{display:none}.portal-main{padding:16px;padding-bottom:calc(16px + 64px + env(safe-area-inset-bottom,0px))}.portal-bottom-nav{padding:8px 12px calc(8px + env(safe-area-inset-bottom,0px));z-index:100;background:#fff;border-top:1px solid #e2e8f0;gap:8px;display:flex;position:fixed;bottom:0;left:0;right:0}.portal-bottom-nav button{flex:1;min-height:48px;margin-top:0}.portal-detail-grid{grid-template-columns:1fr}.portal-page-header{flex-direction:column;align-items:stretch}.portal-page-header-action{width:100%}.portal-form-actions{flex-direction:column}.portal-form-actions .submit-button,.portal-form-actions .secondary-button{width:100%}.portal-tickets-desktop{display:none}.portal-tickets-mobile{display:block}.portal-chat-messages{height:min(420px,55vh)}.portal-detail-grid-compact{grid-template-columns:1fr}.portal-asset-card{padding:11px 12px}.portal-asset-name{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.portal-tickets-filters{gap:6px}.portal-tickets-filter{text-align:center;flex:calc(33.333% - 6px);min-width:0;padding-inline:10px}.portal-tickets-counters{flex-wrap:wrap;gap:8px 16px}.portal-detail-hero h1{word-break:break-word;font-size:1.15rem}.portal-badge-group{width:100%}.portal-chat-composer{gap:6px}.portal-chat-send{width:42px;height:42px}.portal-header-title{font-size:.9rem}.portal-header-brand img{height:28px}}@media (width<=430px){.portal-main{padding:12px;padding-bottom:calc(12px + 64px + env(safe-area-inset-bottom,0px))}.portal-page-title{font-size:1.2rem}.portal-tickets-search input,.portal-chat-input{font-size:16px}.portal-form-actions .submit-button,.portal-form-actions .secondary-button{min-height:44px}}@media (width<=1440px) and (width>=1025px){:root{--sidebar-width:220px}.admin-content{padding:var(--space-3) var(--space-4)}.dashboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric-card-compact{padding:10px 12px}.metric-card-compact .metric-value{font-size:1.35rem}.metric-card-compact .metric-header{font-size:.75rem}.metric-card-compact .metric-subtitle{display:none}.dashboard-content-grid{gap:var(--space-3);grid-template-columns:minmax(0,1fr) 248px}.dashboard-recent-table th,.dashboard-recent-table td{padding:8px 10px;font-size:.8125rem}.data-panel,.admin-form{padding:var(--space-3)}.admin-table th,.admin-table td{padding:8px 10px;font-size:.8125rem}.portal-main-inner{padding:var(--space-3)}.portal-chat-messages{max-height:min(42vh,360px)}}@media (width<=1280px) and (width>=1025px){.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-metrics-row-1,.dashboard-metrics-row-2{display:contents}.dashboard-metrics-wrapper{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.dashboard-metrics-wrapper .dashboard-grid{display:contents}}.dashboard-content-grid{gap:var(--space-4);grid-template-columns:minmax(0,1fr) 272px;align-items:start;display:grid}.page-header-row,.module-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.page-header-row h1,.module-header h1{margin:0;font-size:1.25rem}.page-header-actions{gap:var(--space-2);flex-wrap:wrap;flex-shrink:0;display:flex}.page-header-actions .submit-button,.page-header-actions .secondary-button{width:auto;min-height:38px;margin-top:0;padding:0 14px;font-size:.875rem}.filters-panel{padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-top:var(--space-3);gap:var(--space-3);background:#f8fafc;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.filter-field label,.filters-panel>label,.filter-field{color:#475569;font-size:.78rem;font-weight:600}.filter-field-action{align-items:flex-end;display:flex}.filter-clear-button{width:100%;min-height:38px;margin-top:0;background:#fff!important}.collapsible-trigger{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);color:#445166;cursor:pointer;background:0 0;border:0;width:100%;min-height:36px;padding:0 10px;font-size:.875rem;font-weight:600;display:flex}.filter-badge{margin-left:var(--space-2);background:var(--color-brand);color:#fff;border-radius:50%;place-items:center;width:18px;height:18px;font-size:.65rem;display:grid}.master-detail-grid{grid-template-columns:minmax(260px,300px) minmax(0,1fr)!important}.dashboard-panel-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.dashboard-panel-header h2{margin:0}.dashboard-quick-actions{gap:var(--space-3);flex-direction:column;display:flex}.dashboard-quick-actions .submit-button,.dashboard-quick-actions .secondary-button{justify-content:space-between;margin-top:0}.tickets-layout{margin-top:var(--space-4)}.tickets-split-grid{gap:var(--space-4);display:grid}.tickets-split-grid.has-create-form{grid-template-columns:minmax(300px,360px) minmax(0,1fr)}.tickets-split-grid:not(.has-create-form){grid-template-columns:1fr}.tickets-list-panel{padding:var(--space-3)!important}.search-input-wrap{flex:1;min-width:0;position:relative}.search-input-icon{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{width:100%;padding-left:36px!important}.tickets-result-count{margin-bottom:var(--space-3);color:var(--color-text-muted);font-size:.8125rem}.tickets-result-count strong{color:var(--color-text)}.admin-list-desktop{display:block}.admin-list-mobile{display:none}.mobile-menu-toggle{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #d8e0ea;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:none}.mobile-nav-overlay{z-index:1050;cursor:pointer;background:#0f172a73;border:none;margin:0;padding:0;display:none;position:fixed;inset:0}.dashboard-extra-toggle,.ticket-client-compact{display:none}.ticket-compact-row{align-items:baseline;gap:6px;font-size:.85rem;line-height:1.35;display:flex}.ticket-compact-label{color:#64748b;flex-shrink:0;font-weight:600}.ticket-compact-value{color:#1e293b;word-break:break-word}.ticket-compact-value-inline{align-items:center;gap:6px;display:inline-flex}.ticket-compact-row-wrap{flex-wrap:wrap}.ticket-compact-actions{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.admin-shell{max-width:100vw;overflow-x:hidden}@media (width<=1024px){.mobile-menu-toggle{display:inline-flex}.mobile-nav-overlay{display:block}.admin-shell{grid-template-columns:1fr;overflow-x:hidden}.admin-main{max-width:100%;overflow-x:hidden}.admin-sidebar{z-index:1100;border-bottom:none;border-right:1px solid #d8e0ea;width:320px;max-width:min(320px,85vw);min-height:100vh;transition:transform .2s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:4px 0 24px #0f172a1f}.admin-sidebar.is-open{transform:translate(0)}.admin-header{z-index:1000;justify-content:space-between;padding:12px 16px;position:sticky;top:0}.admin-content{max-width:100%;padding:16px;overflow-x:hidden}.admin-main .admin-table,.admin-main .table-scroll .admin-table{display:none!important}.admin-main .table-scroll{overflow-x:hidden}.admin-grid{grid-template-columns:1fr!important}.action-strip{flex-direction:column;align-items:stretch}.action-strip .secondary-button,.action-strip .submit-button{width:100%;margin-top:0}.dashboard-metrics-wrapper{grid-template-columns:1fr;gap:12px;margin-bottom:0;display:grid}.dashboard-metrics-wrapper .dashboard-grid{display:contents}.dashboard-grid{grid-template-columns:1fr;gap:12px}.dashboard-metric-desktop-only,.dashboard-metric-pending,.dashboard-metric-billing{display:none!important}.dashboard-metrics-wrapper.is-extra-open .dashboard-metric-pending,.dashboard-metrics-wrapper.is-extra-open .dashboard-metric-billing{display:block!important}.dashboard-extra-toggle{color:#475569;width:100%;font:inherit;cursor:pointer;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;order:5;justify-content:center;align-items:center;gap:8px;margin:4px 0 0;padding:12px 16px;font-size:.875rem;font-weight:600;display:flex}.dashboard-extra-chevron-open{transform:rotate(180deg)}.dashboard-extra-toggle svg{flex-shrink:0;transition:transform .2s}.dashboard-metric-open{order:1}.dashboard-metric-in-progress{order:2}.dashboard-metric-sla{order:3}.dashboard-metric-unassigned{order:4}.dashboard-metric-pending{order:6}.dashboard-metric-billing{order:7}.dashboard-content-grid{display:none!important}.dashboard-header{margin-bottom:16px}.dashboard-header h1{font-size:1.35rem}.admin-list-desktop{display:none!important}.admin-list-mobile{display:block}.admin-mobile-card{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;box-sizing:border-box;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:10px;padding:12px 14px;transition:border-color .15s,box-shadow .15s;display:block}.admin-mobile-card:hover,.admin-mobile-card:focus-visible{border-color:#99f6e4;outline:none;box-shadow:0 4px 14px #0f766e14}.admin-mobile-card-static{cursor:default}.admin-mobile-card-header strong{color:#0f766e;font-size:.95rem}.admin-mobile-card-title{color:#1e293b;word-break:break-word;margin-top:6px;font-weight:600;line-height:1.4}.admin-mobile-card-meta{color:#64748b;word-break:break-word;flex-direction:column;gap:4px;margin-top:10px;font-size:.85rem;display:flex}.admin-mobile-card-meta strong{color:#475569}.admin-mobile-card-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.admin-mobile-card-actions .secondary-button{flex:auto;min-width:0;margin-top:0}.ticket-details-top-grid{grid-template-columns:1fr!important;gap:12px!important;margin-bottom:16px!important}.ticket-details-client-panel,.ticket-details-description-panel{padding:12px 14px!important}.ticket-details-client-panel h3,.ticket-details-description-panel h3{margin-bottom:8px;font-size:.95rem}.ticket-details-client-grid{display:none!important}.ticket-client-compact{flex-direction:column;gap:5px;display:flex}.ticket-description-box{max-height:72px!important;padding:8px 10px!important;font-size:.85rem!important}.ticket-details-main-layout{grid-template-columns:1fr!important}.ticket-details-view .data-panel{max-width:100%;overflow-x:hidden}.ticket-details-view h1{word-break:break-word;font-size:1.15rem}.billing-kpi-grid{grid-template-columns:1fr}.billing-module-header{flex-direction:column;align-items:stretch}.billing-export-button{width:100%}.billing-filters{flex-direction:column;align-items:stretch;gap:12px;display:flex}.billing-filters>div{flex:none!important;width:100%!important;min-width:0!important}.billing-filters select,.billing-filters input{box-sizing:border-box;width:100%}.billing-filters .secondary-button{width:100%;height:42px;margin-top:0}.billing-filters label{margin-bottom:4px;display:block}.dashboard-container .module-header{flex-direction:column;gap:12px;align-items:flex-start!important}.dashboard-container .module-header .secondary-button{width:100%}.page-header-row{flex-direction:column;align-items:stretch!important}.page-header-row>div:last-child{gap:10px;display:flex}.page-header-row .submit-button,.page-header-row .secondary-button{flex:1;margin-top:0}.admin-form-row-2col,.admin-form [style*="grid-template-columns: 1fr 1fr"],.admin-form [style*="gridTemplateColumns: '1fr 1fr'"]{grid-template-columns:1fr!important}.table-scroll{max-width:100%;overflow-x:hidden}.pending-filters{grid-template-columns:1fr}.metric-card:hover{transform:none}.metric-card-compact{padding:14px 16px}.metric-card-compact .metric-value{font-size:1.5rem}.mobile-stack-grid,.mobile-address-row,.mobile-card-grid{grid-template-columns:1fr!important}.master-detail-panel .mobile-stack-grid,.master-detail-panel .mobile-address-row{gap:12px!important}.asset-detail-header{gap:12px;flex-direction:column!important;align-items:stretch!important}.asset-detail-header .submit-button{width:100%;margin-top:0}.asset-qr-card-header{flex-direction:column!important;align-items:stretch!important}.asset-qr-card-header .secondary-button{width:100%;margin-top:0}.asset-qr-card-inner{flex-direction:column!important;align-items:stretch!important}.asset-qr-card-inner>div:first-child{align-self:center}.section-header-row{gap:10px;flex-direction:column!important;align-items:stretch!important}.section-header-row .secondary-button{width:100%;margin-top:0}.customer-detail-header{gap:12px;flex-direction:column!important;align-items:stretch!important}.customer-detail-actions{width:100%}.customer-detail-actions .submit-button{flex:1;margin-top:0}.customer-quick-contact{flex-direction:column}.contact-action-link:active{background:#ccfbf1}.contact-card-actions .icon-button{width:44px;height:44px}.notification-mobile-backdrop{z-index:1199;background:#0f172a73;display:block;position:fixed;inset:0}.notification-dropdown{z-index:1200;border-radius:16px 16px 0 0;width:100%;max-width:100%;max-height:85vh;margin:0;position:fixed;inset:auto 0 0;box-shadow:0 -8px 40px #0f172a2e}.notification-header .secondary-button.compact{min-height:36px;padding:6px 10px}.notification-item{min-height:44px;padding:14px 16px}.admin-mobile-card-actions .secondary-button.compact{flex:calc(50% - 4px);min-height:44px}}.asset-label-toolbar{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.asset-label-toolbar-help{color:var(--color-text-muted);margin:6px 0 0;font-size:.82rem;line-height:1.45}.asset-label-print-button{white-space:nowrap;width:auto;margin-top:0}.asset-label-selection-bar{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#f8fafc;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:10px 12px;display:flex}.asset-label-select-all{color:var(--color-text);cursor:pointer;align-items:center;gap:8px;font-size:.82rem;font-weight:700;display:inline-flex}.asset-label-select-all input{width:16px;height:16px;min-height:16px;accent-color:var(--color-brand)}.asset-label-selection-count{color:var(--color-text-muted);font-size:.8rem;font-weight:600}.asset-list-row-content{align-items:flex-start;gap:10px;display:flex}.asset-list-checkbox{cursor:pointer;align-items:center;padding-top:2px;display:inline-flex}.asset-list-checkbox input{width:16px;height:16px;min-height:16px;accent-color:var(--color-brand)}.asset-list-row--selected{box-shadow:inset 0 0 0 1px #0f766e2e}.asset-label-mobile-bar{display:none}.asset-label-modal-overlay{z-index:1300;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.asset-label-modal{border:1px solid var(--color-border-strong);background:#fff;border-radius:12px;flex-direction:column;width:min(960px,100%);max-height:min(90vh,900px);display:flex;box-shadow:0 20px 40px #0f172a2e}.asset-label-modal-header{justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 0;display:flex}.asset-label-modal-header h2{margin:0;font-size:1.2rem}.asset-label-modal-close{width:36px;height:36px;min-height:36px;padding:0}.asset-label-modal-empty{text-align:center;color:var(--color-text-muted);padding:24px 20px}.asset-label-modal-empty strong{color:var(--color-text);margin-bottom:6px;display:block}.asset-label-modal-preview{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding:20px;display:grid;overflow:auto}.asset-label-preview-item{text-align:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:16px 14px}.asset-label-preview-logo{object-fit:contain;max-width:120px;max-height:40px;margin:0 auto 10px;display:block}.asset-label-preview-code{color:var(--color-brand);letter-spacing:.03em;margin:0 0 4px;font-size:1rem;font-weight:800}.asset-label-preview-name{color:var(--color-text);margin:0 0 4px;font-size:.92rem;font-weight:700;line-height:1.3}.asset-label-preview-customer{color:var(--color-text-muted);margin:0 0 10px;font-size:.82rem}.asset-label-preview-qr{justify-content:center;margin-bottom:8px;line-height:0;display:flex}.asset-label-preview-hint{color:#475569;margin:0;font-size:.75rem;font-weight:700}.asset-label-modal-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:10px;margin-top:auto;padding:16px 20px 20px;display:flex}@media (width<=860px){.asset-label-toolbar{flex-direction:column;align-items:stretch}.asset-label-print-button{width:100%}.asset-label-selection-bar{flex-direction:column;align-items:flex-start}.asset-label-modal-preview{grid-template-columns:1fr}.asset-label-mobile-bar{z-index:1100;padding:12px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--color-border-strong);background:#fff;justify-content:space-between;align-items:center;gap:12px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 24px #0f172a1f}.asset-label-mobile-bar span{color:var(--color-text);font-size:.85rem;font-weight:700}}@media print{.admin-shell,.admin-sidebar,.admin-header,.asset-label-toolbar,.asset-label-selection-bar,.asset-label-mobile-bar,.asset-label-modal-overlay,.asset-label-modal-actions,.asset-label-modal-header,.master-detail-list,.master-detail-panel{display:none!important}}.dashboard-admin-section{margin:var(--space-4) 0}.dashboard-admin-section h2{margin:0 0 var(--space-3);letter-spacing:.06em;text-transform:uppercase;color:#64748b;font-size:.78rem;font-weight:700}.dashboard-admin-grid{grid-template-columns:repeat(auto-fit,minmax(220px,280px));max-width:320px}.portal-access-queue-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.portal-access-queue-header h1{letter-spacing:-.02em;margin:0;font-size:1.35rem}.portal-access-queue-header-actions{flex-wrap:wrap;gap:10px;display:flex}.portal-access-queue-panel,.portal-access-detail-panel{margin-bottom:var(--space-4)}.portal-access-detail-panel h2{margin:0}.portal-access-detail-grid{gap:var(--space-3);margin:var(--space-4) 0;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:#f8fafc;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.portal-access-detail-label{letter-spacing:.04em;text-transform:uppercase;color:#64748b;margin-bottom:4px;font-size:.72rem;font-weight:700;display:block}.portal-access-actions{margin-top:var(--space-3);flex-wrap:wrap;gap:12px;display:flex}.portal-access-actions .submit-button,.portal-access-actions .btn-danger,.portal-access-actions .secondary-button{align-items:center;gap:8px;width:auto;min-height:42px;margin-top:0;display:inline-flex}.admin-table td.table-actions,.admin-table th.table-actions{text-align:right;white-space:nowrap}.admin-table tr.is-selected td{background:#f5f3ff}.status-badge.pending_admin_approval,.status-badge.pending_email_verification{color:#7c3aed;background:#ede9fe}.status-badge.rejected{color:#b91c1c;background:#fee2e2}.status-badge.approved{color:#047857;background:#d1fae5}.portal-access-approve-form,.portal-access-reject-form{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}
