﻿:root{
  --red:#da3b30;
  --orange:#ff6f3d;
  --amber:#f4a14b;
  --bg:#fdf9f7;
  --surface:#ffffff;
  --surface-soft:#fff5f1;
  --border:rgba(218,59,48,.18);
  --border-strong:rgba(218,59,48,.32);
  --text:#2f2a27;
  --muted:#7b746f;
  --radius-lg:18px;
  --radius-md:14px;
  --radius-sm:10px;
  --shadow-soft:0 1px 2px rgba(0,0,0,.04);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Inter","Segoe UI",Roboto,Arial,sans-serif;
  font-size:14px;
  line-height:1.45;
}
a{color:var(--red);text-decoration:none}
a:hover{color:var(--orange)}

/* Layout */
.topbar{
  background:linear-gradient(110deg,var(--red),var(--orange));
  color:#fff;
  padding:12px 18px;
  display:flex;
  align-items:center;
  gap:16px;
  position:relative;
  z-index:1000;
}
.topbar img{height:38px}
.topbar strong{font-size:16px;text-transform:uppercase;letter-spacing:.12em}
.wrap{max-width:1180px;margin:26px auto;padding:0 20px 48px}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:18px}

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:20px 22px;
  box-shadow:var(--shadow-soft);
}
.card.caution-card{
  border-color:rgba(244,161,75,.46);
  background:rgba(244,161,75,.14);
}
.card.caution-card h3{
  margin:0 0 6px;
  font-size:15px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--orange);
}
.card.caution-card p{
  margin:4px 0 0;
  color:var(--muted);
}
.module-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 26px;margin-bottom:22px}
.module-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.module-header h2{margin:0;font-size:17px;text-transform:uppercase;letter-spacing:.12em;color:var(--red)}
.card.sec h2{margin:0 0 12px;font-size:16px;text-transform:uppercase;letter-spacing:.1em;color:var(--red)}

/* Buttons */
.btn,
.btn-secondary,
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:600;
  font-size:13px;
  letter-spacing:.1em;
  text-transform:uppercase;
  border-radius:999px;
  padding:10px 18px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .2s ease;
}
.btn,
.btn-primary{background:linear-gradient(110deg,var(--red),var(--orange));color:#fff}
.btn:hover,
.btn-primary:hover{filter:brightness(1.05)}
.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--red)}
.btn-secondary:hover{border-color:var(--border-strong);background:var(--surface-soft)}
.btn-link{background:none;border:0;padding:0;margin:0;color:var(--red);cursor:pointer}
.btn-link:hover{text-decoration:underline}

/* Flash messages */
.flash-msg{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 18px;
  margin:0 0 18px;
  border-radius:var(--radius-md);
  border:1px solid var(--border);
  background:var(--surface-soft);
  color:var(--text);
  font-weight:500;
  box-shadow:var(--shadow-soft);
  transition:opacity .3s ease,transform .3s ease;
}
.flash-icon{
  width:30px;
  height:30px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:700;
  flex-shrink:0;
  color:#fff;
  margin-top:2px;
}
.flash-text{flex:1;min-width:0;}
.flash-msg.flash-success{
  border-color:rgba(46,204,113,.32);
  background:rgba(46,204,113,.14);
  color:#1f5d38;
}
.flash-msg.flash-success .flash-icon{background:#2ecc71;}
.flash-msg.flash-error{
  border-color:rgba(218,59,48,.4);
  background:rgba(218,59,48,.12);
  color:#7f1d1d;
}
.flash-msg.flash-error .flash-icon{background:#da3b30;}
.flash-msg.flash-warning{
  border-color:rgba(244,161,75,.42);
  background:rgba(244,161,75,.14);
  color:#6b3c12;
}
.flash-msg.flash-warning .flash-icon{background:#f4a14b;}
.flash-text ul{
  margin:0;
  padding-left:18px;
}
.flash-text li+li{margin-top:4px}
.flash-msg.is-leaving{
  opacity:0;
  transform:translateY(-6px);
  pointer-events:none;
}

/* Notifications */
.notice-board{
  position:relative;
  background:linear-gradient(135deg, rgba(255,111,61,.08), rgba(218,59,48,.05));
  border:1px solid rgba(218,59,48,.15);
  border-radius:var(--radius-lg);
  padding:22px 24px;
  margin-bottom:26px;
  box-shadow:var(--shadow-soft);
}
.notice-board::after{
  content:'';
  position:absolute;
  inset:14px 16px;
  border-radius:calc(var(--radius-lg) - 10px);
  pointer-events:none;
  border:1px dashed rgba(255,111,61,.14);
}
.notice-board > *{position:relative;z-index:1}
.notice-board-grid{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:16px;
}
.notice-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:18px 20px;
  border-left:4px solid var(--orange);
  box-shadow:0 14px 30px rgba(218,59,48,.12);
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.notice-icon{
  width:36px;
  height:36px;
  border-radius:50%;
  background:rgba(255,111,61,.12);
  color:var(--orange);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.notice-icon svg{width:18px;height:18px;display:block}
.notice-content{flex:1;min-width:0;}
.notice-number{
  display:block;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange);
  font-weight:700;
  margin-bottom:4px;
}
.notice-heading{
  margin:0;
  font-size:16px;
  font-weight:700;
  color:var(--red);
}
.notice-message{
  margin:8px 0 12px;
  color:var(--text);
  line-height:1.5;
  white-space:pre-wrap;
}
.notice-meta{
  font-size:12px;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.notice-meta .separator{color:rgba(0,0,0,.22);}
.notice-board--empty{
  text-align:center;
}
.notice-board--empty .notice-empty{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}
.notice-board--empty::after{display:none;}
.notice-board--empty .notice-icon{
  width:48px;
  height:48px;
  font-size:20px;
}
.notice-board--empty p{
  margin:0;
  color:var(--muted);
  font-weight:500;
}

/* KPI cards */
.kpi{
  position:relative;
  border-radius:var(--radius-lg);
  padding:18px 20px;
  color:#fff;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
}
.kpi::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  mix-blend-mode:soft-light;
  border-radius:inherit;
}
.kpi h3{margin:0 0 8px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.85}
.kpi .v{font-size:26px;font-weight:800;letter-spacing:.4px}
.kpi[data-tone="totali"]{background:linear-gradient(180deg,var(--red),#d62828);}
.kpi[data-tone="tarifa"]{background:linear-gradient(180deg,var(--orange),#f4511e);}
.kpi[data-tone="net"]{background:linear-gradient(180deg,#f3a000,var(--orange));}
.kpi[data-tone="expenses"]{background:#f3a000;}
.kpi[data-tone="real"]{background:linear-gradient(180deg,#546e7a,#37474f);}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;align-items:flex-start}
.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.form-grid input,
.form-grid select,
.form-grid textarea,
.user-form .form-grid input,
.user-form .form-grid select,
.user-form .form-grid textarea{
  width:100%;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:11px 12px;
  font-size:14px;
  background:var(--surface);
  color:var(--text);
  transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;
}
.form-grid input:focus,
.form-grid select:focus,
.form-grid textarea:focus{
  outline:none;
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,111,61,.2);
  background:#fff;
}
.section-card{
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:var(--surface);
  padding:24px 26px;
  margin-bottom:20px;
}
.section-header{display:flex;align-items:center;gap:12px;font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;color:var(--red)}
.section-header .icon{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--red),var(--orange));color:#fff;font-weight:700}
.ticket-notice{display:flex;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-soft);margin-bottom:12px}
.ticket-notice .notice-icon{width:32px;height:32px;border-radius:12px;background:linear-gradient(135deg,var(--red),var(--orange));color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.submit-zone{display:flex;justify-content:center;margin-top:16px}
.submit-zone .btn-primary{padding:12px 28px;border-radius:999px;font-size:13px;letter-spacing:.12em}

.filter-form{display:flex;flex-direction:column;gap:18px;margin-bottom:18px}
.filter-form .form-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}

textarea{font-family:inherit;width:100%;min-height:110px;resize:vertical;border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 12px;font-size:14px;background:var(--surface);color:var(--text);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,111,61,.2);background:#fff}

/* Line items */
.line-items{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-top:24px}
.line-items header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.line-items header h3{margin:0;font-size:15px;text-transform:uppercase;letter-spacing:.12em;color:var(--red)}
.line-table-wrapper{margin:-6px -6px 0;padding:6px;overflow-x:auto}
.lines-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-md);overflow:hidden;min-width:680px}
.lines-table th,
.lines-table td{padding:10px;border-bottom:1px solid rgba(0,0,0,.06);text-align:left;font-size:13px}
.lines-table th{text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--muted)}
.lines-table input{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 10px;font-size:13px}
.lines-table input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,111,61,.16);outline:none}
.line-summary{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:18px;margin-top:14px;padding-top:12px;border-top:1px dashed var(--border);font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.line-summary strong{font-size:15px;color:var(--red);letter-spacing:.14em}

/* Tables */
table{width:100%;border-collapse:collapse;background:var(--surface)}
thead{background:rgba(222,99,65,.08)}
th,td{padding:12px 10px;border-bottom:1px solid rgba(0,0,0,.06);text-align:left}
th{font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
tbody tr:hover{background:rgba(255,111,61,.05)}
.pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:rgba(218,59,48,.09);color:var(--red);font-size:12px;font-weight:600}
.pill.subtle{background:rgba(47,42,39,.14);color:var(--text)}
.sortable{cursor:pointer;position:relative;padding-right:18px}
.sortable::after{content:'\2195';position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:12px;color:rgba(0,0,0,.25)}
.sort-asc::after{content:'\2191';color:var(--red)}
.sort-desc::after{content:'\2193';color:var(--red)}
.sortable:focus{outline:2px solid rgba(255,111,61,.45);outline-offset:2px}
.muted{color:var(--muted)}
.line-debit{background:rgba(218,59,48,.06)}
.line-credit{background:rgba(62,107,105,.06)}
.line-debit:hover{background:rgba(218,59,48,.12)}
.line-credit:hover{background:rgba(62,107,105,.12)}
.table-responsive{width:100%;overflow-x:auto;margin:0 -6px;padding:0 6px; /* removed scrollbar-width for better cross-browser compatibility; use ::-webkit-scrollbar for WebKit browsers */ }
.table-responsive::-webkit-scrollbar{height:6px}
.table-responsive::-webkit-scrollbar-thumb{background:rgba(218,59,48,.25);border-radius:999px}
.table-responsive table{min-width:640px}
.checkin-alert{margin-bottom:18px}
.checkin-alert-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.checkin-alert-list li{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:13px}
.checkin-alert .checkin-code{font-weight:700;color:var(--red);letter-spacing:.14em;text-transform:uppercase}
.checkin-alert .checkin-client{color:var(--muted)}
.checkin-alert-list form{margin-left:auto;display:flex;align-items:center}
.checkin-alert-list li{border-bottom: 0.5px solid rgba(218,59,48,.25);}
.checkin-mark{display:inline-flex;align-items:center;gap:8px;padding:2px 10px;margin-bottom:2px;border-radius:var(--radius-sm);color:var(--red);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s ease,border-color .2s ease}
.checkin-mark:hover{background:rgba(218,59,48,.16);border-color:rgba(218,59,48,.55)}
.checkin-mark input[type="checkbox"]{background: var(--red);accent-color:var(--red);cursor:pointer;box-shadow: inset 0 0 10px var(--red);border-radius: 2px;}

.table-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.table-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:7px 16px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  cursor:pointer;
  transition:background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;
}
.table-action:hover{
  background:linear-gradient(110deg,var(--red),var(--orange));
  border-color:transparent;
  color:#fff;
  box-shadow:0 6px 16px rgba(218,59,48,.18);
}
.table-action--primary{color:var(--red);border-color:rgba(218,59,48,.45)}
.table-action--primary:hover{color:#fff}
.table-action--danger{color:#b71c1c;border-color:rgba(183,28,28,.45);background:rgba(183,28,28,.08)}
.table-action--danger:hover{background:linear-gradient(110deg,#b71c1c,#da3b30);color:#fff}
.table-actions form{display:inline}

/* Responsive tables */
@media (max-width:720px){
  .table-responsive{padding-bottom:12px}
  table.responsive-stack thead{display:none}
  table.responsive-stack tbody{display:block}
  table.responsive-stack tr{display:grid;grid-template-columns:minmax(120px,40%) 1fr;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.08)}
  table.responsive-stack td{display:flex;align-items:flex-start;gap:12px;padding:6px 10px;border:0;border-bottom:0}
  table.responsive-stack td::before{content:attr(data-label);flex:0 0 120px;font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.1em}
}

/* Navigation */
.main-nav{margin-left:auto;display:flex;align-items:center;gap:24px;z-index:999}
.nav-item{position:relative;display:flex;align-items:center}
.nav-link,
.nav-parent{color:#fff;text-transform:uppercase;font-size:12px;font-weight:600;letter-spacing:.14em;padding:8px 0;border:0;background:none;display:inline-flex;align-items:center;gap:8px;opacity:.82;cursor:pointer;transition:opacity .2s ease,color .2s ease}
.nav-link:hover,
.nav-link.is-current,
.nav-parent:hover,
.nav-parent.is-current{opacity:1;color:#fff}
.nav-item.has-children .nav-children{position:absolute;top:100%;left:-50px;display:none;flex-direction:column;gap:4px;padding:12px 16px;border-radius:var(--radius-md);min-width:220px;background:#ff6f3d;border:1px solid rgba(255,255,255,.26);box-shadow:0 12px 30px rgba(0,0,0,.22);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.nav-item.has-children:hover .nav-children,
.nav-item.has-children:focus-within .nav-children{display:flex}
.dropdown-link{display:flex;align-items:center;gap:10px;color:#fff;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:8px 12px;border-radius:var(--radius-sm);transition:background .2s ease,color .2s ease}
.dropdown-link:hover{background:rgb(255, 255, 255)}
.dropdown-link.is-current{background:rgba(255,255,255,.2);color:#fff;font-weight:600}
.caret{margin-left:4px;border:solid #fff;border-width:0 2px 2px 0;display:inline-block;padding:3px;transform:rotate(45deg);transition:transform .2s ease}
.nav-item.has-children:hover .caret,
.nav-item.has-children.open .caret{transform:rotate(-135deg)}
.nav-toggle{display:none;margin-left:auto;background:transparent;border:0;padding:6px;cursor:pointer}
.nav-toggle span{display:block;width:26px;height:2px;background:#fff;margin:5px 0;border-radius:3px}

@media (max-width:900px){
  .main-nav{position:fixed;inset:62px 0 0 0;background:linear-gradient(160deg,rgba(218,59,48,.98),rgba(255,111,61,.95));flex-direction:column;align-items:flex-start;padding:28px 22px;gap:6px;opacity:0;pointer-events:none;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease;overflow-y:auto;max-height:calc(100vh - 62px)}
  body.nav-open .main-nav{opacity:1;pointer-events:auto;transform:translateY(0)}
  .nav-toggle{display:block}
  .nav-item{width:100%;flex-direction:column;align-items:flex-start}
  .nav-link,
  .nav-parent{width:100%;justify-content:space-between;font-size:15px;letter-spacing:.2em;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.22)}
  .nav-item.has-children .nav-children{position:static;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);box-shadow:none;padding:10px 14px;margin:6px 0 0;width:100%;display:none;min-width:0;border-radius:var(--radius-md)}
  .nav-item.has-children.open .nav-children{display:flex}
  .dropdown-link{width:100%;padding:10px 6px;border-radius:var(--radius-sm);font-size:14px;letter-spacing:.14em}
}

.topbar .btn{background:#fff;color:var(--red);border-color:rgba(255,255,255,.6)}
.topbar .btn:hover{background:rgba(255,255,255,.85);color:var(--orange)}

body.nav-open{overflow:hidden;touch-action:none}

/* Login */
.login-bg{background:radial-gradient(900px 600px at 50% -10%,#ffe4dd 0%,#fff6f2 55%,#ffffff 100%);min-height:100vh}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:28px}
.login-card{width:520px;max-width:94vw;background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:38px 40px;box-shadow:var(--shadow-soft);text-align:center;position:relative}
.login-logo{width:80px;margin:0 auto 12px;border-radius:20px;background:#fff;display:grid;place-items:center;}
.login-logo img{width:80px;height:auto;display:block}
.login-title{margin:6px 0 4px;color:var(--red);font-size:34px;font-weight:800;letter-spacing:.04em}
.login-sub{margin:0 0 18px;color:var(--muted)}
.login-form .inp-group{position:relative;margin-bottom:16px}
.login-form .inp-group .inp-ico{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  color:var(--red);
  pointer-events:none;
}
.login-form .inp-group .inp-ico svg{width:18px;height:18px;display:block;fill:currentColor}
.login-form .inp{width:100%;padding:12px 14px 12px 48px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);font-size:14px}
.login-form .inp:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,111,61,.2);outline:none}

/* Demo modal */
.demo-modal{position:absolute;top:16px;right:-360px;width:260px;z-index:2}
.demo-modal.is-dismissed{display:none}
.demo-modal__backdrop{display:none}
.demo-modal__card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px 14px;box-shadow:0 18px 40px rgba(0,0,0,.18);text-align:left}
.demo-modal__pill{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);background:rgba(218,59,48,.08);border:1px solid rgba(218,59,48,.2);border-radius:999px;padding:4px 10px;margin-bottom:8px}
.demo-modal__title{margin:0 0 6px;font-size:16px;color:var(--red)}
.demo-modal__text{margin:0 0 12px;color:var(--muted);font-size:12px}
.demo-modal__cred{display:grid;gap:8px;margin:0 0 12px}
.demo-modal__row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 10px}
.demo-modal__label{text-transform:uppercase;letter-spacing:.14em;font-size:9px;color:var(--muted)}
.demo-modal__value{font-weight:700;color:var(--text);font-size:12px}
.demo-modal__actions{display:flex;justify-content:flex-end;gap:10px}
.demo-modal__close{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;font-weight:700;font-size:12px}
.demo-modal__close:hover{border-color:var(--border-strong);color:var(--red)}

@media (max-width:720px){
  .demo-modal{position:static;width:100%;margin-bottom:12px}
}

/* Footer */
.foot{margin:48px auto 24px;background:var(--surface);border-top:5px solid;border-image:linear-gradient(110deg,var(--red),var(--orange)) 1;padding:22px 26px;display:flex;flex-direction:column;gap:18px;color:var(--text)}
.foot-brand{display:flex;align-items:center;gap:14px}
.foot-brand img{height:46px;}
.foot-brand strong{display:block;font-size:15px;text-transform:uppercase;letter-spacing:.12em;color:var(--red)}
.foot-links{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.foot-dot{opacity:.4}

@media (max-width:720px){
  .wrap{padding:0 16px 40px}
  .module-card{padding:20px}
  .grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr}
  .line-summary{justify-content:flex-start}
  .foot{padding:20px 18px}
}
