.portal-login-wrap,.portal-shell{--p-topbar-bg:#0d1e38;--p-topbar-h:62px;--p-bg:#f0f3f8;--p-surface:#ffffff;--p-border:rgba(10,22,40,0.09);--p-ink:#05080f;--p-muted:#6a7d99;--p-orange:#e85500;--p-success:#16a34a;--p-warning:#d97706;--p-danger:#dc2626}.portal-shell{min-height:100vh;background:var(--p-bg);display:flex;flex-direction:column}.portal-topbar{height:var(--p-topbar-h);background:#0d1e38;display:flex;align-items:center;padding:0 32px;gap:4px;position:-webkit-sticky;position:sticky;top:0;z-index:50;flex-shrink:0}.portal-topbar-logo{font-family:Barlow,sans-serif;font-weight:700;font-size:15px;letter-spacing:.08em;text-transform:uppercase;color:#fff;text-decoration:none;white-space:nowrap;margin-right:20px}.portal-topbar-logo em{color:#e85500;font-style:normal}.portal-topbar-nav{display:flex;align-items:center;gap:2px;flex:1 1}.portal-topbar-link{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:rgba(255,255,255,.78);text-decoration:none;padding:7px 13px;border-radius:5px;transition:color .15s,background .15s;white-space:nowrap}.portal-topbar-link:hover{color:#fff;background:rgba(255,255,255,.09)}.portal-topbar-link.active{color:#fff;background:rgba(255,255,255,.14)}.portal-topbar-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.portal-topbar-user{font-size:13px;color:rgba(255,255,255,.58);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-topbar-logout{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.85);background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.2);padding:6px 14px;border-radius:5px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.portal-topbar-logout:hover{background:rgba(255,255,255,.17);color:#fff}.portal-topbar-divider{width:1px;height:18px;background:rgba(255,255,255,.15);margin:0 6px;flex-shrink:0}.company-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:.03em;padding:0 4px 0 12px;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.company-label,.company-switcher{border-left:1px solid rgba(255,255,255,.15);margin-left:8px}.company-switcher{position:relative;padding-left:12px}.company-switcher-btn{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:rgba(255,255,255,.82);background:none;border:none;cursor:pointer;padding:5px 8px;border-radius:5px;transition:background .15s,color .15s;white-space:nowrap;max-width:200px}.company-switcher-btn:hover{background:rgba(255,255,255,.09);color:#fff}.company-switcher-btn span{overflow:hidden;text-overflow:ellipsis}.company-switcher-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:#0d1e38;border:1px solid rgba(255,255,255,.14);border-radius:7px;box-shadow:0 8px 24px rgba(0,0,0,.35);z-index:200;overflow:hidden;padding:4px}.company-switcher-option{display:block;width:100%;text-align:left;padding:9px 14px;font-size:13px;font-weight:500;color:rgba(255,255,255,.78);background:none;border:none;border-radius:5px;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.company-switcher-option:hover{background:rgba(255,255,255,.08);color:#fff}.company-switcher-option.active{color:#fff;font-weight:700;background:rgba(232,85,0,.18)}.portal-lang-toggle{display:flex;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.2);border-radius:5px;overflow:hidden}.portal-lang-toggle button{padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.07em;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.65);transition:background .15s,color .15s}.portal-lang-toggle button.active{background:#e85500;color:#fff}.portal-content{flex:1 1;padding:36px 40px}.portal-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:8px;padding:24px}.portal-card-title{font-weight:700;letter-spacing:.12em;color:var(--p-muted);margin:0 0 16px}.badge,.portal-card-title{font-size:11px;text-transform:uppercase}.badge{display:inline-flex;align-items:center;font-weight:600;padding:3px 10px;border-radius:100px;letter-spacing:.08em}.badge-active,.badge-paid{background:#dcfce7;color:#15803d}.badge-pending{background:#fef9c3;color:#a16207}.badge-expired,.badge-overdue{background:#fee2e2;color:#b91c1c}.badge-new{background:#dbeafe;color:#1d4ed8}.badge-in-progress,.badge-open{background:#ede9fe;color:#7c3aed}.badge-closed,.badge-resolved{background:#f1f5f9;color:#475569}.badge-waiting{background:#ffedd5;color:#c2410c}.badge-low{background:#f1f5f9;color:#475569}.badge-medium{background:#dbeafe;color:#1d4ed8}.badge-high{background:#ffedd5;color:#c2410c}.badge-urgent{background:#fee2e2;color:#b91c1c}.admin-dropdown{position:relative}.admin-dropdown-btn{display:flex;align-items:center;gap:6px;cursor:pointer;background:none;border:none;padding:0}.admin-dropdown-chevron{display:flex;align-items:center;transition:transform .2s;margin-left:1px;opacity:.6}.admin-dropdown-chevron.rotated{transform:rotate(180deg)}.admin-dropdown-menu{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);background:var(--p-surface,#fff);border:1px solid var(--p-border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.1);min-width:180px;z-index:200;padding:6px;display:flex;flex-direction:column;gap:2px}.admin-dropdown-item{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:7px;font-size:13px;color:var(--p-ink);text-decoration:none;white-space:nowrap;transition:background .12s}.admin-dropdown-item:hover{background:var(--p-bg,#f6f7fa)}.admin-dropdown-item.active{color:var(--p-orange,#e8621a);font-weight:600}.admin-dropdown-item svg{opacity:.65;flex-shrink:0}.admin-dropdown-item.active svg{opacity:1}.auth-lang-toggle{display:flex;justify-content:center;gap:6px;margin-bottom:24px}.auth-lang-btn{padding:4px 14px;font-size:12px;font-weight:600;border:1px solid var(--p-border);border-radius:4px;background:transparent;cursor:pointer;color:var(--p-muted);transition:background .15s,color .15s,border-color .15s}.auth-lang-btn.active{background:var(--p-ink);color:#fff;border-color:var(--p-ink)}.auth-lang-btn:hover:not(.active){background:var(--p-border)}.portal-login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--p-topbar-bg);padding:24px}.portal-login-box{width:100%;max-width:400px;background:var(--p-surface);border-radius:12px;padding:40px}.portal-login-logo{font-family:Barlow,sans-serif;font-weight:700;font-size:18px;letter-spacing:.08em;text-transform:uppercase;color:var(--p-ink);margin-bottom:32px;display:block}.portal-login-logo em{color:var(--p-orange);font-style:normal}.portal-login-title{font-size:22px;font-weight:700;color:var(--p-ink);margin:0 0 6px}.portal-login-sub{font-size:14px;color:var(--p-muted);margin:0 0 28px}.form-group{margin-bottom:18px}.form-label{display:block;margin-bottom:6px;letter-spacing:.04em}.form-input{padding:10px 14px;border-radius:6px;font-size:14px;background:#fff}.form-input:focus{border-color:var(--p-orange)}.form-error{font-size:12px;color:var(--p-danger);margin-top:4px}.btn-portal{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:background .15s,opacity .15s;text-decoration:none}.btn-portal:disabled{opacity:.55;cursor:not-allowed}.btn-portal-primary{background:var(--p-orange);color:#fff;width:100%;padding:12px;font-size:14px}.btn-portal-primary:hover:not(:disabled){background:#ff6515}.btn-portal-ghost{color:var(--p-muted)}.btn-portal-ghost:hover{background:var(--p-bg);color:var(--p-ink)}.dashboard-grid{display:grid;grid-template-columns:1fr 340px;grid-gap:24px;gap:24px;align-items:start}@media (max-width:900px){.dashboard-grid{grid-template-columns:1fr}}.dash-ticket-table{width:100%;border-collapse:collapse;font-size:13px}.dash-ticket-table th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);padding:0 24px 10px;border-bottom:1px solid var(--p-border)}.dash-ticket-table td{padding:12px 24px;border-bottom:1px solid var(--p-border);color:var(--p-ink);vertical-align:middle}.dash-ticket-table tr:last-child td{border-bottom:none}.dash-ticket-table tr:hover td{background:#f7f9fc}.dash-announcements{display:flex;flex-direction:column}.dash-announcement-item{padding:16px 24px;border-bottom:1px solid var(--p-border)}.dash-announcement-item:last-child{border-bottom:none}.dash-announcement-title{font-size:13px;font-weight:600;color:var(--p-ink);margin:0 0 2px}.dash-announcement-date{font-size:11px;color:var(--p-muted);margin:0 0 6px}.dash-announcement-body{font-size:13px;color:var(--p-muted);margin:0;line-height:1.5}.billing-page-title{font-size:22px;font-weight:700;color:var(--p-ink);margin:0 0 24px}.billing-contract-card{margin-bottom:0}.billing-contract-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.billing-plan-name{font-size:18px;font-weight:700;color:var(--p-ink)}.billing-amount{font-size:17px;font-weight:700;color:var(--p-ink)}.billing-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:16px 24px;gap:16px 24px;margin:0 0 20px;padding:20px;background:var(--p-bg);border-radius:6px;border:1px solid var(--p-border)}.billing-detail-item dt{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);margin-bottom:4px}.billing-detail-item dd{font-size:14px;font-weight:500;color:var(--p-ink);margin:0}.billing-summary-block{margin-top:14px;padding-top:14px;border-top:1px solid var(--p-border)}.billing-summary-block dt{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);margin-bottom:4px}.billing-summary-block dd{font-size:13px;color:var(--p-ink);line-height:1.6;margin:0}.billing-history-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid var(--p-border)}.billing-table{width:100%;border-collapse:collapse;font-size:13px}.billing-table th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);padding:10px 20px;white-space:nowrap}.billing-table td,.billing-table th{border-bottom:1px solid var(--p-border)}.billing-table td{padding:12px 20px;color:var(--p-ink);vertical-align:middle}.billing-table tr:last-child td{border-bottom:none}.billing-table tr:hover td{background:#f7f9fc}.billing-period{font-weight:600;font-family:monospace}.billing-cell-amount{font-weight:600}.portal-table{width:100%;border-collapse:collapse;font-size:13px}.portal-table th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);padding:10px 20px;white-space:nowrap}.portal-table td,.portal-table th{border-bottom:1px solid var(--p-border)}.portal-table td{padding:12px 20px;color:var(--p-ink);vertical-align:middle}.portal-table tr:last-child td{border-bottom:none}.portal-table tr:hover td{background:#f7f9fc}.ticket-num{font-family:monospace;white-space:nowrap}.cell-muted,.ticket-num{font-size:12px;color:var(--p-muted)}.portal-form{gap:18px}.form-field,.portal-form{display:flex;flex-direction:column}.form-field{gap:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.form-label{font-size:12px;font-weight:600;color:var(--p-ink);letter-spacing:.02em}.req{color:#dc2626;font-weight:700;margin-left:2px}.form-input{padding:9px 12px;font-size:13px;color:var(--p-ink);background:var(--p-surface);border:1px solid var(--p-border);border-radius:5px;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box;font-family:inherit}.form-input:focus{border-color:#0d1e38}.form-textarea{resize:vertical;min-height:120px}select.form-input{cursor:pointer}@media (max-width:600px){.form-row{grid-template-columns:1fr}}.portal-alert-info{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}.ticket-detail-header{margin-bottom:0}.ticket-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:12px 20px;gap:12px 20px;margin:0}.ticket-meta-grid dt{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p-muted);margin-bottom:3px}.ticket-meta-grid dd{margin:0;font-size:13px;color:var(--p-ink)}.ticket-messages{display:flex;flex-direction:column;gap:12px}.ticket-message{border-radius:8px;padding:16px 20px}.message-client{background:var(--p-surface);border:1px solid var(--p-border)}.message-internal{background:#f0f4ff;border:1px solid #c7d4f0}.message-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:12px}.message-author{font-size:12px;font-weight:700;color:var(--p-ink)}.message-date{font-size:11px;color:var(--p-muted);white-space:nowrap}.message-body{font-size:14px;color:var(--p-ink);line-height:1.65;white-space:pre-wrap;margin:0}.text-link{color:var(--p-orange);font-size:13px;text-decoration:none}.text-link:hover{text-decoration:underline}.portal-alert{padding:12px 16px;border-radius:6px;font-size:13px;margin-bottom:16px}.portal-alert-error{background:#fee2e2;color:#b91c1c;border:1px solid #fca5a5}.portal-alert-success{background:#dcfce7;color:#15803d;border:1px solid #86efac}.portal-scaffold-msg{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--p-muted);font-size:14px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:22px;font-weight:700;color:var(--p-ink);margin:0}.btn-portal-ghost{background:transparent;border:1px solid var(--p-border);color:var(--p-ink);padding:7px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:background .15s}.btn-portal-ghost:hover{background:var(--p-border)}.mode-toggle{display:flex;border:1px solid var(--p-border);border-radius:7px;overflow:hidden;margin-bottom:20px}.mode-toggle-btn{flex:1 1;padding:9px 12px;font-size:13px;font-weight:500;background:transparent;border:none;cursor:pointer;color:var(--p-muted);transition:background .15s,color .15s}.mode-toggle-btn.active{background:var(--p-ink);color:#fff}.pw-strength-bar{height:4px;border-radius:2px;background:var(--p-border);margin-top:6px;overflow:hidden}.pw-strength-fill{height:100%;border-radius:2px;transition:width .2s,background .2s}.pw-strength-label{font-size:11px;color:var(--p-muted);margin-top:4px}.pw-reqs{display:flex;flex-direction:column;gap:3px;margin-top:8px}.pw-req{font-size:11px;display:flex;align-items:center;gap:5px}.pw-req.ok{color:#15803d}.pw-req.fail{color:var(--p-muted)}.pw-input-wrap{position:relative}.pw-input-wrap .form-input{padding-right:100px}.pw-input-actions{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:flex;gap:4px}.pw-action-btn{padding:3px 8px;font-size:11px;font-weight:600;border:1px solid var(--p-border);border-radius:4px;background:var(--p-surface);color:var(--p-ink);cursor:pointer;white-space:nowrap}.pw-action-btn:hover{background:var(--p-border)}.table-action-link{font-size:12px;color:var(--p-orange);text-decoration:none;white-space:nowrap}.table-action-link:hover{text-decoration:underline}.form-check-row{display:flex;align-items:center;gap:8px}.form-check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--p-ink);cursor:pointer}.attach-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px dashed var(--p-border);border-radius:6px;font-size:12px;color:var(--p-muted);background:none;cursor:pointer;transition:border-color .15s,color .15s}.attach-btn:hover{border-color:var(--p-ink);color:var(--p-ink)}.attach-preview{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--p-surface);border:1px solid var(--p-border);border-radius:6px;font-size:12px;color:var(--p-ink);margin-top:8px}.attach-preview-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-preview-size{color:var(--p-muted);white-space:nowrap}.attach-preview-remove{background:none;border:none;cursor:pointer;color:var(--p-muted);font-size:14px;padding:0 2px;line-height:1}.attach-preview-remove:hover{color:#dc2626}.attachment-list{display:flex;flex-direction:column;gap:4px;margin-top:10px;padding-top:10px;border-top:1px solid var(--p-border)}.attachment-item{display:flex;align-items:center;gap:8px;font-size:12px}.attachment-icon{font-size:14px}.attachment-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--p-ink)}.attachment-size{color:var(--p-muted);white-space:nowrap}.attachment-download{color:var(--p-orange);font-size:12px;text-decoration:none;white-space:nowrap}.attachment-download:hover{text-decoration:underline}