*{box-sizing:border-box}:root{--bg:#f4f7fb;--card:#fff;--text:#172033;--muted:#64748b;--border:#d8e0ec;--blue:#2563eb;--blue-dark:#1d4ed8;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-700:#334155}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(37,99,235,.10),transparent 30%),radial-gradient(circle at top right,rgba(14,165,233,.10),transparent 32%),var(--bg)}a{color:inherit}.portal-container{max-width:1180px;margin:0 auto;padding:0 18px}.portal-header{padding:28px 0 22px;background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;margin-bottom:22px}.header-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.eyebrow{color:#bfdbfe;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.portal-header h1{margin:6px 0 8px;font-size:30px}.portal-header p{margin:0;color:#dbeafe}.header-actions,.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.portal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding-bottom:40px}.full-width{grid-column:1/-1}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:0 10px 25px rgba(15,23,42,.07)}.danger-card{border-color:#fecaca;background:#fff7f7}.card h2{margin:0;font-size:19px}.card p{margin:4px 0 0;color:var(--muted);line-height:1.45}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.count-pill,.type-badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700;background:#e0f2fe;color:#075985;border:1px solid #bae6fd}.primary-btn,.secondary-btn{border:0;border-radius:10px;padding:9px 12px;text-decoration:none;cursor:pointer;font-size:13px;font-weight:700;display:inline-flex;justify-content:center;align-items:center;line-height:1.2}.primary-btn{background:var(--blue);color:#fff}.primary-btn:hover{background:var(--blue-dark)}.secondary-btn{background:var(--slate-100);color:var(--slate-700);border:1px solid var(--border)}.small{padding:7px 9px;font-size:12px}.invoice-list{display:grid;gap:8px}.invoice-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--slate-50)}.invoice-row strong,.invoice-row span{display:block}.invoice-row span{color:var(--muted);font-size:12px;margin-top:2px}.invoice-amount{font-weight:700;color:var(--slate-700)}.empty-state,.loading{padding:14px;border-radius:14px;border:1px dashed var(--border);background:var(--slate-50);color:var(--muted)}.button-grid{display:flex;flex-wrap:wrap;gap:8px}.downloads-grid,.tool-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.download-card,.tool-card{display:block;padding:13px;border-radius:14px;background:var(--slate-50);border:1px solid var(--border);text-decoration:none}.download-card:hover{border-color:#93c5fd;background:#eff6ff}.download-card strong,.download-card span,.tool-card strong,.tool-card span{display:block}.download-card span,.tool-card span{color:var(--muted);font-size:12px;margin-top:4px;word-break:break-all}.movie-card{position:relative;min-height:108px}.movie-card.movie-today{background:#f0fdf4;border-color:#bbf7d0}.movie-card.movie-today:hover{background:#dcfce7;border-color:#86efac}.movie-card.movie-yesterday{background:#fffbeb;border-color:#fde68a}.movie-card.movie-yesterday:hover{background:#fef3c7;border-color:#fcd34d}.movie-status-badge{display:inline-flex!important;align-items:center;width:max-content;border-radius:999px;padding:3px 8px;margin-bottom:8px;font-size:11px!important;font-weight:800;line-height:1;border:1px solid transparent}.movie-status-badge.today{background:#dcfce7;color:#166534;border-color:#86efac}.movie-status-badge.yesterday{background:#fef3c7;color:#92400e;border-color:#fcd34d}.tool-card .actions{margin-top:12px}.muted-card{opacity:.85}.inline-form{display:inline}.modal-backdrop{display:none;position:fixed;inset:0;z-index:2000;background:rgba(15,23,42,.62);padding:18px;align-items:center;justify-content:center}.modal-backdrop.active{display:flex}.portal-modal{width:min(1050px,100%);height:min(820px,calc(100vh - 36px));background:#fff;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.30)}.modal-head{flex:0 0 auto;padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.modal-body{flex:1;min-height:0;padding:24px}.modal-body iframe{width:100%;height:100%;border:0}.modal-body.text-body{padding:32px;overflow:auto}.forecast-modal-content h3{margin-top:0}.legacy-forecast-text{font-size:14px;line-height:1.55}.alert{padding:11px 12px;border-radius:12px;margin-bottom:12px;font-size:14px}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.muted{color:var(--muted)}.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px}.login-shell{width:min(440px,100%)}.login-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:24px;box-shadow:0 24px 60px rgba(15,23,42,.14)}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}.brand-mark{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,var(--blue),#0284c7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}.login-brand h1{margin:0;font-size:24px}.login-brand p,.login-footnote{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.45}.login-form{display:grid;gap:9px}.login-form label{font-size:12px;font-weight:700;color:var(--slate-700)}.login-form input{width:100%;border:1px solid var(--border);border-radius:12px;padding:11px 12px;font-size:14px}.login-form input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 4px rgba(96,165,250,.18)}.login-form button{margin-top:8px}.print-body{background:#fff}.print-shell{max-width:900px;margin:0 auto;padding:24px;color:#172033}@media print{body.print-body{background:#fff}.print-shell{padding:0;max-width:none}.modal-head,.portal-header,.header-actions{display:none!important}}@media(max-width:820px){.header-inner,.invoice-row{grid-template-columns:1fr;display:grid}.portal-grid,.downloads-grid,.tool-grid{grid-template-columns:1fr}.portal-header h1{font-size:24px}.modal-head{align-items:flex-start;flex-direction:column}.modal-actions{justify-content:flex-start}}

/* Meteo Desk forecast cards */
.meteo-forecast-section{
    border-color:#cbd5e1;
    background:
        radial-gradient(circle at top right, rgba(14,165,233,.08), transparent 32%),
        linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
    padding:22px;
}
.meteo-panel-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:18px;
    padding-bottom:16px;
    margin-bottom:16px;
    border-bottom:1px solid #e2e8f0;
}
.meteo-kicker{
    color:#2563eb;
    font-size:11px;
    font-weight:900;
    letter-spacing:.11em;
    text-transform:uppercase;
    margin-bottom:6px;
}
.meteo-title-line{
    display:flex;
    align-items:center;
    gap:9px;
    flex-wrap:wrap;
}
.meteo-title-line h2{
    margin:0;
    font-size:22px;
    letter-spacing:-.02em;
    color:#0f172a;
}
.meteo-head-main p{
    margin:5px 0 0;
    color:#64748b;
    font-size:14px;
    line-height:1.45;
}
.meteo-head-actions{
    display:flex;
    justify-content:flex-end;
    align-items:center;
    flex:0 0 auto;
}
.meteo-summary-row{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
    margin-top:12px;
}
.meteo-summary-row span{
    display:inline-flex;
    align-items:center;
    gap:4px;
    border:1px solid #d8e0ec;
    background:#f8fafc;
    border-radius:999px;
    padding:5px 10px;
    color:#475569;
    font-size:12px;
    font-weight:800;
}
.meteo-summary-row span.ok{
    background:#f0fdf4;
    border-color:#bbf7d0;
    color:#166534;
}
.meteo-summary-row span.warn{
    background:#fffbeb;
    border-color:#fde68a;
    color:#92400e;
}
.meteo-region-pills{
    display:flex;
    gap:7px;
    flex-wrap:wrap;
    margin:0 0 16px;
}
.meteo-region-pill{
    display:inline-flex;
    align-items:center;
    border:1px solid #bbf7d0;
    background:#f0fdf4;
    color:#166534;
    border-radius:999px;
    padding:5px 10px;
    font-size:12px;
    font-weight:900;
    line-height:1;
}
.meteo-region-pill.missing{
    border-color:#fde68a;
    background:#fffbeb;
    color:#92400e;
}
.meteo-region-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
}
.meteo-region-card{
    border:1px solid #dbe4ef;
    border-radius:18px;
    background:#ffffff;
    box-shadow:0 10px 28px rgba(15,23,42,.07);
    padding:16px;
    min-height:220px;
    display:flex;
    flex-direction:column;
}
.meteo-region-card.missing{
    background:#fffdf4;
    border-color:#fcd34d;
    border-style:dashed;
}
.meteo-region-head{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:flex-start;
    margin-bottom:14px;
}
.meteo-region-head h3{
    margin:0;
    font-size:18px;
    line-height:1.2;
    color:#0f172a;
    letter-spacing:-.01em;
}
.meteo-date-line{
    display:flex;
    gap:7px;
    flex-wrap:wrap;
    margin-top:6px;
    color:#64748b;
    font-size:12px;
    font-weight:700;
}
.meteo-date-line span{
    display:inline-flex;
}
.meteo-card-statuses{
    display:flex;
    gap:5px;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.meteo-status-badge{
    display:inline-flex;
    align-items:center;
    border-radius:999px;
    border:1px solid transparent;
    padding:4px 8px;
    font-size:11px;
    font-weight:900;
    line-height:1;
    white-space:nowrap;
}
.meteo-status-badge.today{
    background:#e0f2fe;
    color:#075985;
    border-color:#bae6fd;
}
.meteo-status-badge.available{
    background:#dcfce7;
    color:#166534;
    border-color:#86efac;
}
.meteo-status-badge.missing{
    background:#fef3c7;
    color:#92400e;
    border-color:#fcd34d;
}
.meteo-status-badge.alert{
    background:#ffedd5;
    color:#9a3412;
    border-color:#fdba74;
}
.meteo-content-label{
    margin-bottom:6px;
    color:#64748b;
    font-size:11px;
    font-weight:900;
    letter-spacing:.06em;
    text-transform:uppercase;
}
.meteo-alert{
    border:1px solid #fdba74;
    background:#fff7ed;
    color:#9a3412;
    border-radius:13px;
    padding:11px 12px;
    margin-bottom:12px;
    font-size:14px;
    line-height:1.5;
}
.meteo-content-block{
    margin-top:12px;
}
.meteo-content-block:first-of-type{
    margin-top:0;
}
.meteo-text,.meteo-extra{
    color:#172033;
    font-size:14px;
    line-height:1.6;
    white-space:normal;
}
.meteo-extra-block{
    margin-top:14px;
    padding-top:12px;
    border-top:1px solid #e2e8f0;
}
.meteo-extra{
    color:#334155;
}
.meteo-empty{
    border:1px dashed #fcd34d;
    background:#fffbeb;
    color:#92400e;
    border-radius:13px;
    padding:13px;
    font-size:13px;
    line-height:1.45;
}
.meteo-card-actions{
    display:flex;
    justify-content:flex-end;
    margin-top:auto;
    padding-top:14px;
    border-top:1px solid #e2e8f0;
}
@media(max-width:1100px){
    .meteo-region-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:820px){
    .meteo-forecast-section{padding:18px;}
    .meteo-panel-head{display:block;}
    .meteo-head-actions{justify-content:flex-start;margin-top:12px;}
    .meteo-region-grid{grid-template-columns:1fr;}
    .meteo-region-head{display:block;}
    .meteo-card-statuses{justify-content:flex-start;margin-top:10px;}
}
@media print{
    .meteo-forecast-section{box-shadow:none;border:0;padding:0;background:#fff;}
    .meteo-panel-head{border-bottom:1px solid #ddd;}
    .meteo-head-actions,.meteo-card-actions{display:none!important;}
    .meteo-region-grid{display:block;}
    .meteo-region-card{break-inside:avoid;margin:0 0 14px;box-shadow:none;}
}
