:root{
  --green:#0F5132;
  --green-2:#0B3D2A;
  --gold:#D4A017;
  --bg:#F5F7FA;
  --card:#FFFFFF;
  --text:#1F2937;
  --muted:#6B7280;
  --line:#E5E7EB;
  --danger:#DC2626;
  --success:#16A34A;
  --info:#0284C7;
  --warning:#D97706;
  --shadow:0 18px 45px rgba(15,81,50,.10);
  --radius:22px;
}
*{box-sizing:border-box}
html{width:100%;overflow-x:hidden}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);width:100%;overflow-x:hidden}
a{text-decoration:none;color:inherit}
input,select,textarea,button{max-width:100%;min-width:0}

.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}
.sidebar{background:linear-gradient(180deg,var(--green),var(--green-2));color:#fff;padding:24px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:24px}
.brand{display:flex;gap:12px;align-items:center}
.brand-mark{width:54px;height:54px;border-radius:18px;background:rgba(212,160,23,.95);display:grid;place-items:center;font-weight:900;color:#173322;box-shadow:0 10px 25px rgba(0,0,0,.18)}
.brand strong{display:block;font-size:1.15rem}.brand span{font-size:.85rem;opacity:.78}
.nav{display:grid;gap:8px}.nav a{padding:13px 14px;border-radius:14px;color:rgba(255,255,255,.86);font-weight:650;transition:.2s}.nav a:hover,.nav a.active{background:rgba(255,255,255,.13);color:#fff;transform:translateX(3px)}
.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.16);padding-top:18px}.user-pill{background:rgba(255,255,255,.12);border-radius:14px;padding:12px 14px;margin-bottom:10px}.logout{display:block;color:#FFE7A5;font-weight:700}
.content{padding:28px;max-width:1320px;width:100%;margin:0 auto;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.topbar h1{margin:0;font-size:1.7rem}.topbar p{margin:.25rem 0 0;color:var(--muted)}
.menu-toggle{display:none;border:0;background:#fff;border-radius:14px;padding:10px 13px;box-shadow:var(--shadow)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:20px;min-width:0}.card-title{margin:0 0 16px;font-size:1.05rem}
.grid{display:grid;gap:18px;min-width:0}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.proforma-form-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start}
.stat{padding:22px;border-radius:20px;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--line)}.stat span{color:var(--muted);font-size:.9rem}.stat strong{display:block;font-size:1.65rem;margin-top:7px;color:var(--green)}
.form-group{display:grid;gap:8px;margin-bottom:15px;min-width:0}label{font-weight:750;font-size:.92rem}input,select,textarea{width:100%;border:1px solid #D1D5DB;background:#fff;border-radius:14px;padding:12px 13px;font:inherit;outline:none;transition:.2s}input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(15,81,50,.12)}textarea{min-height:100px;resize:vertical}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;padding:12px 16px;font-weight:800;cursor:pointer;transition:.2s;font-size:.95rem;line-height:1.15;text-align:center}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--green);color:#fff}.btn-gold{background:var(--gold);color:#173322}.btn-light{background:#F3F4F6;color:var(--text);border:1px solid var(--line)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-info{background:var(--info);color:#fff}
.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.table-wrap{overflow-x:auto;overflow-y:hidden;border-radius:18px;border:1px solid var(--line);-webkit-overflow-scrolling:touch}.table-wrap table{min-width:720px}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#F9FAFB}td.actions{min-width:230px}.table-wrap .btn{white-space:nowrap}tr:last-child td{border-bottom:0}
.badge{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:800}.badge-success{background:#DCFCE7;color:#166534}.badge-danger{background:#FEE2E2;color:#991B1B}.badge-info{background:#E0F2FE;color:#075985}.badge-warning{background:#FEF3C7;color:#92400E}.badge-secondary{background:#E5E7EB;color:#374151}
.alert{border-radius:16px;padding:13px 16px;margin-bottom:16px;font-weight:650}.alert-success{background:#DCFCE7;color:#166534}.alert-danger{background:#FEE2E2;color:#991B1B}.alert-info{background:#E0F2FE;color:#075985}
.wizard{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:20px}.step{border-radius:18px;background:#fff;border:1px solid var(--line);padding:14px 16px;min-width:0}.step strong{display:block;color:var(--green)}.step span{color:var(--muted);font-size:.88rem}
.summary-box{background:linear-gradient(135deg,#0F5132,#0B3D2A);color:#fff;border-radius:24px;padding:22px;position:sticky;top:20px;min-width:0}.summary-box h3{margin:0 0 16px}.summary-line{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(255,255,255,.16);padding:10px 0}.summary-total{font-size:1.45rem;font-weight:900;color:#FFE7A5}
.auth-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(212,160,23,.22),transparent 34%),linear-gradient(135deg,#0F5132,#06291d);padding:20px}.auth-card{width:min(440px,100%);background:#fff;border-radius:28px;box-shadow:0 24px 70px rgba(0,0,0,.25);padding:32px}.auth-logo{width:74px;height:74px;border-radius:24px;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:900;margin-bottom:18px}
.muted{color:var(--muted)}.small{font-size:.86rem}.help{font-size:.86rem;color:var(--muted)}
.print-page{background:#fff}.proforma-sheet{max-width:920px;margin:30px auto;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}.proforma-header{display:flex;justify-content:space-between;gap:20px;background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;padding:28px}.proforma-header h1{margin:0;font-size:1.7rem}.proforma-body{padding:28px}.proforma-section{margin-bottom:24px}.proforma-section h3{color:var(--green);margin:0 0 12px}.kv{display:grid;grid-template-columns:190px minmax(0,1fr);gap:8px}.qr{max-width:140px;border:1px solid var(--line);border-radius:16px;padding:8px;background:#fff}.pill{background:#F3F4F6;border-radius:999px;padding:7px 11px;font-weight:750;display:inline-flex}.no-print{display:block}

@media(max-width:1100px){
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proforma-form-layout{grid-template-columns:minmax(0,1fr) 320px}
}
@media(max-width:940px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;z-index:30;left:-300px;transition:.2s;width:min(84vw,280px);box-shadow:18px 0 45px rgba(0,0,0,.22)}
  .sidebar.open{left:0}
  .content{padding:18px}
  .menu-toggle{display:inline-flex}
  .topbar{align-items:flex-start;flex-wrap:wrap}
  .topbar>a.btn{margin-left:auto}
  .grid-2,.grid-3,.grid-4,.wizard,.proforma-form-layout{grid-template-columns:1fr!important}
  .summary-box{position:relative;top:auto}
  .card{padding:18px}
  .proforma-header{flex-direction:column}
  .proforma-header>div:last-child{text-align:left!important}
  .proforma-sheet{margin:16px;border-radius:20px}
  .proforma-body{padding:22px}
  .kv{grid-template-columns:145px minmax(0,1fr)}
}
@media(max-width:620px){
  body{font-size:15px}
  .content{padding:14px}
  .topbar{gap:12px}
  .topbar h1{font-size:1.35rem}
  .topbar p{font-size:.9rem}
  .topbar .btn,.topbar>a.btn{width:100%;margin-left:0}
  .menu-toggle{order:-1}
  .card{padding:15px;border-radius:18px}
  .auth-card{padding:24px;border-radius:24px}
  .actions{width:100%}
  .actions>.btn,.actions>button,.actions>a{flex:1 1 100%;width:100%}
  .actions form,.actions input{width:100%;max-width:none!important}
  .wizard{gap:10px}
  .step{padding:12px}
  .summary-box{border-radius:20px;padding:18px}
  .summary-line{font-size:.95rem}
  .summary-total{font-size:1.25rem}
  .proforma-sheet{margin:10px;border-radius:16px}
  .proforma-header,.proforma-body{padding:18px}
  .proforma-header h1{font-size:1.35rem}
  .kv{grid-template-columns:1fr;gap:2px;margin-bottom:8px}
  .table-wrap{border-radius:14px}
  .table-wrap table{min-width:620px}
  th,td{padding:11px 12px}
  .qr{max-width:120px}
}
@media(max-width:420px){
  .content{padding:10px}
  .card{padding:13px}
  .btn{padding:11px 13px}
  .table-wrap table{min-width:560px}
  .summary-line{align-items:flex-start;flex-direction:column;gap:4px}
  .auth-logo{width:62px;height:62px;border-radius:20px}
  .proforma-header,.proforma-body{padding:15px}
}
@media print{
  body{background:#fff;overflow:visible}
  .no-print,.sidebar,.topbar,.actions,.btn{display:none!important}
  .app-shell,.content{display:block;padding:0;margin:0}
  .proforma-sheet{margin:0;border:0;box-shadow:none;border-radius:0}
  .proforma-header{border-radius:0;flex-direction:row}
  .card{box-shadow:none;border:0}
  .print-page{background:#fff}
  .table-wrap table{min-width:0}
}

/* Fase 2 */
.inline-input{display:flex;gap:8px;align-items:center}.inline-input input{flex:1}.inline-input .btn{padding:10px 12px;min-width:44px}
.check{display:flex;align-items:center;gap:8px;font-weight:750}.check input{width:auto}
.extra-row{border:1px dashed var(--line);padding:14px;border-radius:18px;margin-bottom:12px;background:#FCFCFD}
.alert-info{background:#E0F2FE;color:#075985}
.stat .badge{font-size:.88rem}
@media(max-width:620px){.inline-input{align-items:stretch}.inline-input .btn{flex:0 0 48px;width:48px}.extra-row{padding:12px}.grid-3{grid-template-columns:1fr!important}}
@media print{.grid-4.no-print,.grid-2.no-print{display:none!important}.proforma-section .table-wrap{overflow:visible;border:1px solid #ddd}.proforma-section table{min-width:0!important}}

/* Fase 3 - Operaciones y manifiestos */
.toggle-card{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);background:#fff;border-radius:18px;padding:14px;cursor:pointer;font-weight:600}
.toggle-card input{width:auto;margin-top:4px;accent-color:var(--green)}
.toggle-card strong{display:block;color:var(--green);margin-bottom:4px}.toggle-card small{display:block;color:var(--muted);line-height:1.35}
.manifest-sheet .table-wrap table{min-width:980px}.signature-grid{margin-top:34px}.signature-box{border-top:1px solid #111;text-align:center;padding-top:10px;min-height:58px;color:var(--muted)}
@media(max-width:620px){.toggle-card{padding:12px}.manifest-sheet .table-wrap table{min-width:860px}}
@media print{.manifest-sheet .table-wrap{overflow:visible}.manifest-sheet .table-wrap table{min-width:0!important;font-size:11px}.manifest-sheet th,.manifest-sheet td{padding:7px 8px}.signature-box{min-height:70px}.badge{border:1px solid #bbb;background:#fff!important;color:#111!important}}


/* Fase 4 - PDF premium, público, CRM, calendario y reportes */
.brochure-sheet{max-width:980px;margin:30px auto;background:#fff;border-radius:28px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.brochure-cover{min-height:380px;background:linear-gradient(120deg,#06291d,#0F5132);background-size:cover;background-position:center;color:#fff;padding:32px;display:flex;flex-direction:column;justify-content:space-between;position:relative}
.brochure-brand{display:flex;align-items:center;gap:14px}.brochure-brand img{width:64px;height:64px;object-fit:contain;background:#fff;border-radius:18px;padding:8px}.brochure-brand strong{display:block;font-size:1.25rem}.brochure-brand span{display:block;opacity:.85}
.cover-content{max-width:720px}.cover-content h1{font-size:3rem;line-height:1.05;margin:16px 0 8px}.cover-content p{font-size:1.25rem;opacity:.92}.cover-code{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:9px 13px;font-weight:800}
.pill-gold{background:var(--gold);color:#173322;border-radius:999px;padding:8px 13px;font-weight:900;letter-spacing:.04em}
.brochure-body{padding:30px}.mini-card{border:1px solid var(--line);border-radius:20px;background:linear-gradient(135deg,#fff,#F8FAFC);padding:18px}.mini-card span{display:block;color:var(--muted);font-size:.85rem}.mini-card strong{display:block;color:var(--green);font-size:1.15rem;margin:4px 0}.mini-card small{color:var(--muted)}
.timeline{display:grid;gap:13px}.timeline-item{display:grid;grid-template-columns:96px 1fr;gap:14px;border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}.timeline-item>span{background:#ECFDF5;color:#166534;border-radius:999px;align-self:start;text-align:center;padding:7px 8px;font-weight:900}.timeline-item p{margin:.35rem 0 0;color:var(--muted)}
.check-list{padding-left:20px}.check-list li{margin:7px 0}.tour-photo{width:100%;max-height:220px;object-fit:cover;border-radius:20px;border:1px solid var(--line);margin-top:12px}
.price-card{background:#0F5132;color:#fff;border-radius:24px;padding:22px}.price-card h3{color:#fff}.price-row,.price-total{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(255,255,255,.16);padding:11px 0}.price-total{display:grid;grid-template-columns:1fr auto;align-items:end}.price-total strong{font-size:1.8rem;color:#FFE7A5}.price-total small{grid-column:1/-1;color:rgba(255,255,255,.8)}.qr-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.brochure-footer{border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--muted)}.brochure-footer strong{color:var(--green)}
.public-actions-top{max-width:980px;margin:18px auto 0;padding:0 16px}.public-panel{max-width:980px;margin:0 auto 22px;padding:0 16px}
.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.calendar-head{font-weight:900;color:var(--green);text-align:center}.calendar-day{min-height:140px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:0 8px 20px rgba(15,81,50,.06)}.calendar-event{display:block;background:#ECFDF5;border:1px solid #BBF7D0;border-radius:12px;padding:8px;margin-top:8px}.calendar-event b{display:block;color:#166534}.calendar-event span,.calendar-event small{display:block;font-size:.82rem;color:#374151}
@media(max-width:940px){.cover-content h1{font-size:2.2rem}.brochure-cover{min-height:320px}.calendar-grid{grid-template-columns:1fr}.calendar-head{display:none}.calendar-day{min-height:auto}.timeline-item{grid-template-columns:1fr}.price-total{grid-template-columns:1fr}}
@media(max-width:620px){.brochure-sheet{margin:10px;border-radius:18px}.brochure-cover{padding:22px}.cover-content h1{font-size:1.8rem}.cover-content p{font-size:1rem}.brochure-body{padding:18px}.brochure-brand img{width:52px;height:52px}.mini-card{padding:14px}}
@media print{
  .brochure-sheet{margin:0;border:0;box-shadow:none;border-radius:0;max-width:none}
  .brochure-cover{min-height:300px;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .brochure-body{padding:20px}
  .price-card{background:#0F5132!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .calendar-grid,.public-panel{display:none!important}
}


/* FIX v4.1 - Calendario mensual elegante */
.dsm-calendar-wrap{display:block;width:100%;min-width:0}
.dsm-calendar-toolbar{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:16px!important;flex-wrap:wrap!important}
.dsm-calendar-title{text-align:center;flex:1;min-width:220px}
.dsm-calendar-title h2{margin:0;color:#0F172A;font-size:1.25rem}
.dsm-calendar-title span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}
.dsm-calendar-grid{display:grid!important;grid-template-columns:repeat(7,minmax(0,1fr))!important;gap:12px!important;width:100%!important;align-items:stretch!important}
.dsm-calendar-head{background:var(--green)!important;color:#fff!important;border-radius:14px!important;padding:12px 8px!important;text-align:center!important;font-weight:900!important;box-shadow:0 8px 22px rgba(15,81,50,.12)!important}
.dsm-calendar-day{display:flex!important;flex-direction:column!important;gap:8px!important;min-height:150px!important;background:#fff!important;border:1px solid var(--line)!important;border-radius:18px!important;padding:12px!important;box-shadow:0 10px 26px rgba(15,81,50,.06)!important;overflow:hidden!important}
.dsm-calendar-empty{background:rgba(255,255,255,.45)!important;border-style:dashed!important;box-shadow:none!important}
.dsm-calendar-date{display:flex!important;justify-content:space-between!important;align-items:center!important;gap:8px!important;font-weight:900!important;color:#111827!important}
.dsm-calendar-number{display:inline-grid!important;place-items:center!important;width:30px!important;height:30px!important;border-radius:999px!important;background:#F3F4F6!important}
.dsm-calendar-today .dsm-calendar-number{background:var(--gold)!important;color:#173322!important}
.dsm-calendar-count{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-width:24px!important;height:24px!important;border-radius:999px!important;padding:0 8px!important;background:#ECFDF5!important;color:#166534!important;font-size:.76rem!important;font-weight:900!important}
.dsm-calendar-event{display:block!important;background:linear-gradient(135deg,#ECFDF5,#F0FDFA)!important;border:1px solid #BBF7D0!important;border-left:5px solid var(--green)!important;border-radius:14px!important;padding:9px 10px!important;color:var(--text)!important;transition:.2s!important}
.dsm-calendar-event:hover{transform:translateY(-1px)!important;box-shadow:0 10px 20px rgba(15,81,50,.12)!important}
.dsm-calendar-event b{display:block!important;color:var(--green)!important;font-size:.86rem!important;margin-bottom:2px!important}
.dsm-calendar-event span{display:block!important;font-size:.84rem!important;font-weight:800!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
.dsm-calendar-event small{display:block!important;color:var(--muted)!important;font-size:.76rem!important;line-height:1.25!important;margin-top:2px!important}
.dsm-calendar-empty-text{margin:auto;color:#9CA3AF;font-size:.82rem;text-align:center}
@media(max-width:900px){.dsm-calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.dsm-calendar-head{display:none!important}.dsm-calendar-empty{display:none!important}.dsm-calendar-day{min-height:120px!important}}
@media(max-width:560px){.dsm-calendar-toolbar .btn{width:100%!important}.dsm-calendar-title{order:-1;flex-basis:100%!important}.dsm-calendar-grid{display:block!important}.dsm-calendar-day{margin-bottom:12px!important;min-height:auto!important}.dsm-calendar-date::before{content:attr(data-weekday);color:var(--green);font-size:.86rem;font-weight:900;margin-right:auto}}

/* =========================================================
   FIX MENÚ LATERAL CON SCROLL INTERNO - FASE 4.1
   Evita que el menú se salga del fondo verde cuando hay muchas opciones.
   ========================================================= */
.sidebar{
  height:100dvh !important;
  max-height:100dvh !important;
  min-height:0 !important;
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
  padding:20px 18px !important;
}
.sidebar .brand{
  flex:0 0 auto !important;
}
.sidebar .nav{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  display:grid !important;
  gap:7px !important;
  padding:4px 6px 10px 0 !important;
  margin-right:-6px !important;
  overscroll-behavior:contain;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.38) rgba(255,255,255,.08);
}
.sidebar .nav::-webkit-scrollbar{
  width:7px;
}
.sidebar .nav::-webkit-scrollbar-track{
  background:rgba(255,255,255,.08);
  border-radius:999px;
}
.sidebar .nav::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.38);
  border-radius:999px;
}
.sidebar .nav::-webkit-scrollbar-thumb:hover{
  background:rgba(255,255,255,.55);
}
.sidebar .nav a{
  display:flex !important;
  align-items:center;
  min-height:42px;
  padding:11px 13px !important;
  border-radius:14px !important;
  color:rgba(255,255,255,.88) !important;
  font-weight:750 !important;
  line-height:1.15;
  white-space:normal;
}
.sidebar .nav a:hover,
.sidebar .nav a.active{
  background:rgba(255,255,255,.15) !important;
  color:#fff !important;
  transform:none !important;
}
.sidebar .sidebar-footer{
  flex:0 0 auto !important;
  margin-top:0 !important;
  padding-top:14px !important;
  border-top:1px solid rgba(255,255,255,.16) !important;
}
.sidebar .user-pill{
  margin-bottom:9px !important;
}

/* Capa oscura para cerrar el menú en celular */
.sidebar-backdrop{
  display:none;
}

@media(max-width:940px){
  .sidebar{
    position:fixed !important;
    z-index:40 !important;
    left:-320px !important;
    top:0 !important;
    width:min(86vw,300px) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    padding:18px 16px !important;
    transition:left .22s ease !important;
    box-shadow:18px 0 45px rgba(0,0,0,.24) !important;
  }
  .sidebar.open{
    left:0 !important;
  }
  body.menu-open{
    overflow:hidden !important;
  }
  body.menu-open .sidebar-backdrop{
    display:block;
    position:fixed;
    inset:0;
    z-index:35;
    background:rgba(2,6,23,.45);
    backdrop-filter:blur(2px);
  }
  .sidebar .nav{
    padding-bottom:14px !important;
  }
}

@media(max-width:420px){
  .sidebar{
    width:min(90vw,292px) !important;
  }
  .sidebar .nav a{
    min-height:40px;
    padding:10px 12px !important;
    font-size:.94rem;
  }
}



/* Fase 5 - galería, pasajeros públicos, liquidaciones y mejoras visuales */
.nav-section{margin:10px 10px 3px;padding:8px 4px 4px;color:rgba(255,255,255,.55);font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;border-top:1px solid rgba(255,255,255,.10)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.gallery-card{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 8px 22px rgba(15,81,50,.06)}.gallery-card img{width:100%;height:160px;object-fit:cover;display:block}.gallery-card>div{padding:14px}.gallery-card p{color:var(--muted);font-size:.9rem;min-height:34px}.brochure-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.brochure-gallery figure{margin:0;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff}.brochure-gallery img{width:100%;height:150px;object-fit:cover;display:block}.brochure-gallery figcaption{padding:9px 10px;font-size:.86rem;color:var(--muted)}
.public-form-card{width:min(1080px,100%);background:#fff;border-radius:28px;box-shadow:0 24px 70px rgba(0,0,0,.25);padding:28px;margin:auto}.passenger-public-row{border:1px solid var(--line);border-radius:22px;background:#F8FAFC;padding:18px;margin:16px 0}.passenger-public-row h3{margin:0 0 12px;color:var(--green)}
.badge-success,.badge-info,.badge-warning,.badge-danger,.badge-secondary{white-space:nowrap}.badge-info{background:#E0F2FE;color:#075985}.badge-warning{background:#FEF3C7;color:#92400E}.badge-danger{background:#FEE2E2;color:#991B1B}.badge-secondary{background:#E5E7EB;color:#374151}
@media(max-width:940px){.brochure-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}.public-form-card{border-radius:22px;padding:20px}}
@media(max-width:620px){.brochure-gallery{grid-template-columns:1fr}.gallery-card img,.brochure-gallery img{height:180px}.public-form-card{padding:16px;border-radius:18px}.passenger-public-row{padding:14px}}
@media print{.brochure-gallery{grid-template-columns:repeat(3,1fr)}.brochure-gallery img{height:120px}.public-form-card{box-shadow:none}}

/* Fase 6 - Recordatorios WhatsApp */
.reminder-card{border-left:6px solid #25D366;background:linear-gradient(135deg,#ffffff,#f8fff9)}
.reminder-proforma_vencida{border-left-color:var(--danger)}
.reminder-saldo_pendiente,.reminder-proforma_por_vencer{border-left-color:var(--warning)}
.reminder-viaje_proximo{border-left-color:var(--info)}
.reminder-viaje_manana{border-left-color:var(--success)}
.reminder-message{min-height:170px;background:#fff;border-style:dashed;font-size:.94rem;line-height:1.45}
.code-box{background:#0B3D2A;color:#fff;padding:14px 16px;border-radius:16px;overflow-x:auto;white-space:pre-wrap}
@media(max-width:620px){.reminder-message{min-height:210px}.reminder-card .actions form{width:100%}}

/* Fase 8 - IA Itinerarios */
.ai-timeline{gap:16px}.ai-day-card{background:linear-gradient(135deg,#fff,#f8fafc);border-left:5px solid var(--gold)}
.ai-day-card .pill{margin-top:10px}.ai-config-note{border-left:4px solid var(--info);background:#EFF6FF;padding:12px 14px;border-radius:14px;color:#075985}
@media(max-width:620px){.ai-day-card{border-left:0;border-top:5px solid var(--gold)}}

/* =========================================================
   FASE 10 - Optimización visual del panel
   Iconos, menú agrupado, búsqueda rápida, modo oscuro,
   dashboard ejecutivo, botón flotante y mejor responsive.
   ========================================================= */
html[data-theme="dark"]{
  --bg:#07120E;
  --card:#0F1F19;
  --text:#E5E7EB;
  --muted:#9CA3AF;
  --line:#1F3A31;
  --green:#19A15F;
  --green-2:#0B3D2A;
  --gold:#F0BE35;
  --shadow:0 18px 45px rgba(0,0,0,.35);
}
html[data-theme="dark"] body{background:radial-gradient(circle at top right,rgba(25,161,95,.10),transparent 32%),var(--bg)}
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat,
html[data-theme="dark"] .mini-card,
html[data-theme="dark"] .gallery-card,
html[data-theme="dark"] .calendar-day,
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea,
html[data-theme="dark"] table{background:var(--card);color:var(--text);border-color:var(--line)}
html[data-theme="dark"] th{background:#10261F;color:#B7C7BE}
html[data-theme="dark"] .btn-light{background:#12261F;color:var(--text);border-color:var(--line)}
html[data-theme="dark"] .topbar-search,
html[data-theme="dark"] .global-search-results{background:#0F1F19;border-color:var(--line)}
html[data-theme="dark"] .table-wrap{border-color:var(--line)}
html[data-theme="dark"] .help,
html[data-theme="dark"] .muted{color:var(--muted)}
html[data-theme="dark"] .pill{background:#132E25;color:#D1FAE5}

.sidebar .brand{padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.10)}
.sidebar-search{flex:0 0 auto}
.sidebar-search input{width:100%;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:14px;padding:11px 13px;outline:none}
.sidebar-search input::placeholder{color:rgba(255,255,255,.62)}
.sidebar-search input:focus{background:rgba(255,255,255,.16);box-shadow:0 0 0 4px rgba(255,255,255,.10)}
.sidebar .nav-section{display:flex!important;align-items:center;gap:8px;margin:14px 8px 5px!important;padding:10px 4px 4px!important;color:rgba(255,255,255,.62)!important;font-size:.72rem!important;font-weight:950!important;text-transform:uppercase!important;letter-spacing:.09em!important;border-top:1px solid rgba(255,255,255,.10)!important}
.sidebar .nav-section:first-child{border-top:0!important;margin-top:2px!important}
.sidebar .nav a{gap:10px!important;position:relative;overflow:hidden}
.sidebar .nav a[hidden]{display:none!important}
.sidebar .nav a .nav-icon{width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.10);display:inline-grid;place-items:center;flex:0 0 28px;font-size:1rem}
.sidebar .nav a .nav-text{min-width:0;overflow:hidden;text-overflow:ellipsis}
.sidebar .nav a.active .nav-icon,.sidebar .nav a:hover .nav-icon{background:rgba(255,255,255,.20)}
.sidebar .nav a.active::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:4px;border-radius:999px;background:var(--gold)}
.sidebar .nav-empty{padding:14px;color:rgba(255,255,255,.65);font-size:.9rem;text-align:center;border:1px dashed rgba(255,255,255,.20);border-radius:14px}

.topbar{position:relative;align-items:center!important;background:rgba(255,255,255,.65);backdrop-filter:blur(10px);border:1px solid rgba(229,231,235,.70);border-radius:24px;padding:14px 16px;box-shadow:0 10px 30px rgba(15,81,50,.06)}
html[data-theme="dark"] .topbar{background:rgba(15,31,25,.78);border-color:var(--line)}
.topbar-title{min-width:200px;flex:1}
.topbar-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:0}
.global-search{position:relative;width:min(330px,34vw)}
.global-search input{border-radius:999px;padding:11px 14px 11px 40px;background:var(--card);border:1px solid var(--line)}
.global-search::before{content:"⌕";position:absolute;left:15px;top:50%;transform:translateY(-50%);z-index:1;color:var(--muted);font-weight:900}
.global-search-results{position:absolute;right:0;top:calc(100% + 8px);width:min(420px,90vw);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:8px;z-index:50;max-height:330px;overflow:auto}
.global-search-results a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;color:var(--text);font-weight:750}
.global-search-results a:hover{background:#F3F4F6}
html[data-theme="dark"] .global-search-results a:hover{background:#153327}
.theme-toggle{width:44px;height:44px;display:grid;place-items:center;border:1px solid var(--line);border-radius:15px;background:var(--card);cursor:pointer;box-shadow:0 8px 20px rgba(15,81,50,.08)}
.menu-toggle{height:44px;min-width:44px}

.floating-action{position:fixed;right:22px;bottom:22px;z-index:25;display:flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--gold),#FFE08A);color:#173322;border-radius:999px;padding:12px 17px;box-shadow:0 20px 45px rgba(15,81,50,.22);font-weight:950;border:1px solid rgba(255,255,255,.55)}
.floating-action span{width:30px;height:30px;border-radius:999px;background:#173322;color:#fff;display:grid;place-items:center;font-size:1.35rem;line-height:1}
.floating-action:hover{transform:translateY(-2px)}

.dashboard-hero{display:flex;align-items:stretch;justify-content:space-between;gap:24px;background:linear-gradient(135deg,#0F5132,#0B3D2A);color:#fff;overflow:hidden;position:relative}
.dashboard-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:230px;height:230px;border-radius:50%;background:rgba(212,160,23,.22)}
.dashboard-hero h2{font-size:2rem;line-height:1.1;margin:8px 0}.dashboard-hero p{margin:0;max-width:680px;color:rgba(255,255,255,.82)}
.hero-eyebrow{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:7px 11px;font-weight:900;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.hero-metrics{display:grid;grid-template-columns:repeat(3,minmax(110px,1fr));gap:12px;align-items:stretch;z-index:1;min-width:min(430px,100%)}
.hero-metrics div{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:16px;text-align:center}.hero-metrics strong{display:block;font-size:1.45rem;color:#FFE7A5}.hero-metrics span{font-size:.82rem;opacity:.82}
.dashboard-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.quick-action{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:0 10px 25px rgba(15,81,50,.06);display:grid;gap:5px;transition:.2s}.quick-action:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.quick-action span{font-size:1.45rem}.quick-action strong{color:var(--green)}.quick-action small{color:var(--muted)}
.executive-stats .stat{position:relative;overflow:hidden}.executive-stats .stat::after{content:"";position:absolute;right:-26px;bottom:-26px;width:90px;height:90px;border-radius:50%;background:rgba(212,160,23,.12)}.executive-stat small{display:block;color:var(--muted);margin-top:8px;font-weight:750}
.dashboard-timeline .timeline-item{color:inherit}.executive-checklist{display:grid;align-content:start;gap:10px}.check-row{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(135deg,var(--card),rgba(248,250,252,.55))}.check-row strong{flex:1}.check-row em{font-style:normal;font-weight:900;color:var(--green)}.dot{width:12px;height:12px;border-radius:50%;display:inline-block}.dot.success{background:var(--success)}.dot.warning{background:var(--warning)}.dot.info{background:var(--info)}.dot.danger{background:var(--danger)}

@media(max-width:1180px){.dashboard-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.global-search{width:min(280px,36vw)}.dashboard-hero{flex-direction:column}.hero-metrics{min-width:0}}
@media(max-width:940px){.topbar{align-items:flex-start!important}.topbar-title{order:2;flex-basis:100%}.topbar-tools{order:3;width:100%;justify-content:stretch}.global-search{width:100%;flex:1 1 100%}.topbar-new{flex:1}.theme-toggle{flex:0 0 44px}.floating-action{right:16px;bottom:16px}.sidebar-search{display:block}}
@media(max-width:620px){.topbar{border-radius:18px;padding:12px}.topbar-tools{gap:8px}.topbar-new{width:100%}.theme-toggle{order:-1}.dashboard-actions{grid-template-columns:1fr}.dashboard-hero{padding:18px}.dashboard-hero h2{font-size:1.45rem}.hero-metrics{grid-template-columns:1fr}.hero-metrics div{text-align:left}.floating-action{padding:11px 13px}.floating-action strong{display:none}.floating-action span{width:34px;height:34px}.sidebar .nav a .nav-icon{width:26px;height:26px}.global-search-results{left:0;right:auto;width:100%}}
@media print{.floating-action,.theme-toggle,.global-search,.sidebar-search{display:none!important}}


/* Fase 13 - CRM comercial avanzado */
.crm-timeline-item{border-left:4px solid var(--green);background:rgba(15,81,50,.04);border-radius:16px;padding:12px 14px;margin-bottom:12px}
.crm-timeline-item strong{display:block;color:var(--green)}
.crm-timeline-item span{display:block;color:var(--muted);font-size:.84rem;margin:3px 0 6px}
.crm-timeline-item p{margin:6px 0 8px}
.birthday-card textarea,.table-wrap textarea{width:100%;min-height:92px;border:1px solid var(--line);border-radius:14px;padding:10px;background:#fff;color:var(--text);font:inherit}
.birthday-card h3{margin:12px 0 6px;color:var(--green)}
.birthday-today{border-color:#86efac;background:linear-gradient(135deg,#fff,#f0fdf4)}
.crm-kpi{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}
.crm-kpi strong{font-size:1.4rem;color:var(--green)}
@media(max-width:720px){
  .birthday-card textarea,.table-wrap textarea{min-height:120px}
}

/* Fase 14 - Promociones, internacionales y postventa */
.mini-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px;margin:10px 0;box-shadow:0 8px 18px rgba(15,81,50,.05)}
hr{border:0;border-top:1px solid var(--line);margin:18px 0}
.check{display:inline-flex;gap:8px;align-items:center;font-weight:700}.check input{width:auto}.stat strong{word-break:break-word}
@media(max-width:620px){.mini-card{padding:12px}.grid-4{grid-template-columns:1fr!important}}

/* Fase 15 - PDF externo y 2FA TOTP */
.qr-setup-box{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow);max-width:100%}
.qr-setup-box img{width:min(320px,100%);height:auto;display:block}
.help-list{margin:0;padding-left:22px;color:var(--muted);line-height:1.65}.help-list li{margin:4px 0}
.external-pdf-frame{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#f8fafc;min-height:620px}.external-pdf-frame iframe{width:100%;height:720px;border:0;display:block;background:#fff}.external-pdf-sheet .proforma-header{border-radius:0}
@media(max-width:720px){.external-pdf-frame{min-height:480px}.external-pdf-frame iframe{height:520px}.qr-setup-box{width:100%}.qr-setup-box img{width:100%}}
@media print{.external-pdf-frame{display:none!important}.qr-setup-box{box-shadow:none}}


/* Parche final - Gauge / velocímetro funcional del tablero de mando */
.company-command-panel{align-items:stretch;margin-bottom:20px}
.executive-gauge-card{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--card),rgba(248,250,252,.78))}
.executive-gauge-card::after{content:"";position:absolute;right:-80px;top:-80px;width:190px;height:190px;border-radius:999px;background:rgba(212,160,23,.10);pointer-events:none}
.executive-gauge-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px;position:relative;z-index:1}
.executive-gauge-header h3{margin:10px 0 4px;font-size:1.25rem;color:var(--text)}
.executive-gauge-header p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.45}
.executive-gauge-badge{padding:8px 14px;border-radius:999px;font-weight:950;font-size:.88rem;white-space:nowrap;border:1px solid transparent}
.executive-gauge-badge.success{background:#DCFCE7;color:#166534;border-color:#BBF7D0}
.executive-gauge-badge.caution{background:#FEF9C3;color:#854D0E;border-color:#FEF08A}
.executive-gauge-badge.warning{background:#FFEDD5;color:#9A3412;border-color:#FED7AA}
.executive-gauge-badge.danger{background:#FEE2E2;color:#991B1B;border-color:#FECACA}
.gauge-widget{position:relative;max-width:460px;margin:0 auto;z-index:1}
.gauge-svg{width:100%;height:auto;display:block;filter:drop-shadow(0 14px 22px rgba(15,81,50,.08))}
.gauge-segment{fill:none;stroke-width:28;stroke-linecap:butt}
.seg-red{stroke:#F87171}.seg-orange{stroke:#FDBA74}.seg-yellow{stroke:#FEF34A}.seg-green{stroke:#4ADE80}
.gauge-tick-label{font-size:12px;fill:var(--muted);font-weight:950}
.gauge-needle-wrap{transform-origin:120px 120px;transition:transform .85s cubic-bezier(.2,.8,.2,1)}
.gauge-needle{stroke:#111827;stroke-width:4.5;stroke-linecap:round}
.gauge-center{fill:#111827}.gauge-center-light{fill:#fff;opacity:.82}
.gauge-score{margin-top:-12px;text-align:center}
.gauge-score-number{font-size:2.15rem;font-weight:950;color:var(--text);line-height:1}.gauge-score-label{color:var(--muted);margin-top:4px;font-size:.95rem;font-weight:750}
.gauge-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:13px;margin-top:16px;font-size:.9rem;color:var(--muted);font-weight:750}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px;vertical-align:middle}.legend-dot.red{background:#F87171}.legend-dot.orange{background:#FDBA74}.legend-dot.yellow{background:#FEF34A}.legend-dot.green{background:#4ADE80}
.company-signal-card{display:flex;flex-direction:column;gap:12px}.semaforo-list{display:grid;gap:10px}.semaforo-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:17px;padding:13px 14px;background:linear-gradient(135deg,var(--card),rgba(248,250,252,.62))}.semaforo-main{display:flex;align-items:flex-start;gap:11px;min-width:0}.semaforo-main strong{display:block;color:var(--text);font-size:.95rem}.semaforo-main small{display:block;color:var(--muted);font-size:.82rem;line-height:1.35;margin-top:2px}.semaforo-light{width:14px;height:14px;border-radius:999px;flex:0 0 14px;margin-top:3px;box-shadow:0 0 0 5px rgba(0,0,0,.04)}.semaforo-row.success .semaforo-light{background:var(--success);box-shadow:0 0 0 5px rgba(22,163,74,.12)}.semaforo-row.caution .semaforo-light{background:#EAB308;box-shadow:0 0 0 5px rgba(234,179,8,.14)}.semaforo-row.warning .semaforo-light{background:var(--warning);box-shadow:0 0 0 5px rgba(217,119,6,.13)}.semaforo-row.danger .semaforo-light{background:var(--danger);box-shadow:0 0 0 5px rgba(220,38,38,.12)}.semaforo-value{text-align:right;flex:0 0 auto}.semaforo-value strong{display:block;color:var(--green);font-size:.96rem}.semaforo-value span{display:block;color:var(--muted);font-size:.78rem;font-weight:850;margin-top:2px}
.company-real-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:auto}.company-real-summary div{border:1px solid var(--line);border-radius:16px;padding:12px;background:rgba(15,81,50,.03)}.company-real-summary span{display:block;color:var(--muted);font-size:.78rem;font-weight:850}.company-real-summary strong{display:block;color:var(--green);font-size:1rem;margin-top:4px;word-break:break-word}.company-real-summary small{display:block;color:var(--muted);font-size:.75rem;margin-top:2px}
html[data-theme="dark"] .gauge-needle{stroke:#F9FAFB}html[data-theme="dark"] .gauge-center{fill:#F9FAFB}html[data-theme="dark"] .gauge-center-light{fill:#111827}html[data-theme="dark"] .executive-gauge-card,html[data-theme="dark"] .semaforo-row,html[data-theme="dark"] .company-real-summary div{background:linear-gradient(135deg,var(--card),rgba(16,38,31,.70))}
@media(max-width:1180px){.company-real-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:940px){.executive-gauge-header{flex-direction:column}.executive-gauge-badge{align-self:flex-start}.company-command-panel{grid-template-columns:1fr!important}}
@media(max-width:620px){.gauge-score-number{font-size:1.75rem}.gauge-legend{justify-content:flex-start}.semaforo-row{align-items:flex-start;flex-direction:column}.semaforo-value{text-align:left}.company-real-summary{grid-template-columns:1fr}}
@media print{.executive-gauge-card,.company-signal-card{break-inside:avoid}.gauge-svg{filter:none}.gauge-needle-wrap{transition:none}}


/* HOTFIX 2FA QR - mayor margen/tamaño para escaneo */
.qr-setup-box{background:#fff!important;padding:22px!important}
.qr-setup-box img{width:min(380px,100%)!important;height:auto!important;display:block!important;image-rendering:auto!important}
