/* ═══════════════════════ RESET & VARIABLES ═══════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue-900:#0a1628;--blue-800:#0f2240;--blue-700:#143a6b;--blue-600:#1a5296;
  --blue-500:#2563eb;--blue-400:#4a8af5;--blue-300:#7cb0ff;--blue-200:#b8d4ff;--blue-100:#dbeafe;--blue-50:#eff6ff;
  --green-700:#065f46;--green-600:#059669;--green-500:#10b981;--green-400:#34d399;--green-300:#6ee7b7;--green-100:#d1fae5;
  --gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;
  --gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;
  --radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 16px rgba(0,0,0,.08);--shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --shadow-glow:0 0 30px rgba(37,99,235,.12);
  --transition:0.3s cubic-bezier(.4,0,.2,1);
  --font:'Inter',system-ui,-apple-system,sans-serif;
}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font);background:#ffffff;color:var(--gray-800);line-height:1.6;overflow-x:hidden}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}

/* ═══════════════════════ HEADER ═══════════════════════ */
#header{position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-200);transition:var(--transition)}
#header.scrolled{background:rgba(255,255,255,.95);box-shadow:var(--shadow-md)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.logo-group{display:flex;align-items:center;gap:14px}
.logo-icon{width:44px;height:44px;color:var(--blue-500);flex-shrink:0}
.logo-group h1{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--blue-600),var(--green-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tagline{font-size:.75rem;color:var(--gray-500);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.header-nav{display:flex;gap:8px}
.header-nav a{padding:8px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--gray-600);transition:var(--transition)}
.header-nav a:hover{background:var(--blue-50);color:var(--blue-600)}
.mobile-menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.mobile-menu-btn span{width:24px;height:2px;background:var(--gray-600);border-radius:2px;transition:var(--transition)}
.mobile-nav{display:none;position:fixed;top:72px;left:0;right:0;background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);flex-direction:column;padding:16px 24px;gap:4px;z-index:99;border-bottom:1px solid var(--gray-200)}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:14px 16px;border-radius:var(--radius-sm);font-weight:500;color:var(--gray-700);transition:var(--transition)}
.mobile-nav a:hover{background:var(--blue-50)}

/* ═══════════════════════ STATUS BANNER ═══════════════════════ */
.status-banner{padding:100px 0 32px;background:linear-gradient(180deg,var(--blue-50) 0%,#ffffff 100%)}
.section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);font-weight:600;margin-bottom:16px;text-align:center}
.status-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.status-card{display:flex;align-items:center;gap:16px;padding:20px 24px;border-radius:var(--radius-md);
  background:#ffffff;border:1px solid var(--gray-200);transition:var(--transition);box-shadow:var(--shadow-sm)}
.status-card:hover{background:var(--gray-50);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.status-boat-icon{width:40px;height:40px;background:var(--blue-50);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.status-boat-icon svg{width:22px;height:22px;color:var(--blue-500)}
.status-indicator{position:relative;width:14px;height:14px;border-radius:50%;flex-shrink:0}
.status-indicator.online{background:var(--green-500)}
.status-indicator.offline{background:#ef4444}
.pulse{position:absolute;inset:-4px;border-radius:50%;animation:pulse 2s ease-in-out infinite}
.status-indicator.online .pulse{background:rgba(16,185,129,.3)}
.status-indicator.offline .pulse{background:rgba(239,68,68,.3)}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.6);opacity:0}}
.status-info{flex:1}
.status-info strong{font-size:.95rem;display:block;margin-bottom:2px;color:var(--gray-800)}
.status-text{font-size:.8rem;color:var(--green-600);font-weight:500}
.status-indicator.offline+.status-info .status-text{color:#ef4444}
.status-weather{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:.78rem;color:var(--gray-500);
  padding:4px 10px;background:var(--blue-50);border-radius:var(--radius-sm);width:fit-content}
.status-weather svg{width:14px;height:14px;color:var(--blue-400)}
.status-next{display:flex;align-items:center;gap:4px;margin-top:6px;font-size:.78rem;color:var(--gray-600);background:var(--gray-50);padding:4px 10px;border-radius:var(--radius-sm);width:fit-content}
.next-label{font-weight:600;color:var(--gray-500)}
.status-next strong{color:var(--blue-600)}

/* Language Toggle */
.lang-toggle{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);
  background:var(--blue-50);border:1px solid var(--blue-100);cursor:pointer;transition:var(--transition);margin-left:8px}
.lang-toggle:hover{background:var(--blue-100);border-color:var(--blue-200)}
.lang-flag{font-size:1.1rem;line-height:1}
.lang-label{font-size:.8rem;font-weight:700;color:var(--blue-600);font-family:var(--font)}

/* Weather Animations (SVG Based) */
.status-card{position:relative;overflow:hidden}
.weather-anim{position:absolute;top:0;right:0;width:120px;height:100%;pointer-events:none;overflow:hidden;opacity:.6;z-index:0;
  display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.status-card:hover .weather-anim{opacity:.9;transform:scale(1.05)}
.weather-icon{width:80px;height:80px;filter:drop-shadow(0 0 8px rgba(0,0,0,0.05))}

/* Sun */
.sun-body{fill:#fbbf24;animation:pulseSun 4s ease-in-out infinite}
.sun-rays{stroke:#fbbf24;stroke-width:6;stroke-linecap:round;animation:spinRays 12s linear infinite;transform-origin:50px 50px}
@keyframes pulseSun{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}
@keyframes spinRays{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Clouds */
.cloud-path{fill:#cbd5e1;animation:floatCloud 6s ease-in-out infinite}
.cloud-path.secondary{fill:#94a3b8;opacity:.6;animation:floatCloud 8s ease-in-out 1s infinite;transform:scale(.8) translate(10px, -10px)}
@keyframes floatCloud{0%,100%{transform:translateX(0) translateY(0)}50%{transform:translateX(-10px) translateY(5px)}}

/* Rain */
.rain-drops line{stroke:#38bdf8;stroke-width:4;stroke-linecap:round;animation:fallRain .8s linear infinite}
.rain-drops line:nth-child(2){animation-delay:.2s}
.rain-drops line:nth-child(3){animation-delay:.4s}
@keyframes fallRain{0%{transform:translateY(-10px);opacity:0}30%{opacity:1}100%{transform:translateY(20px);opacity:0}}

/* Weather-specific Card Styles */
.status-card.weather-sunny {
  background: linear-gradient(135deg, #fffcf0 0%, #fff7d6 100%);
  border-color: #fde68a;
}
.status-card.weather-sunny:hover {
  background: linear-gradient(135deg, #fff7d6 0%, #fef3c7 100%);
}

.status-card.weather-cloudy {
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  border-color: #e2e8f0;
}
.status-card.weather-cloudy:hover {
  background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
}

.status-card.weather-rainy {
  background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
  border-color: #bae6fd;
}
.status-card.weather-rainy:hover {
  background: linear-gradient(135deg, #e0f2fe 0%, #d1edff 100%);
}

.status-card.weather-sunny .status-weather { background: rgba(251,191,36,.1); color: #b45309; }
.status-card.weather-cloudy .status-weather { background: rgba(100,116,139,.1); color: #475569; }
.status-card.weather-rainy .status-weather { background: rgba(14,165,233,.1); color: #0369a1; }


/* ═══════════════════════ CROSSING CARDS ═══════════════════════ */
.crossings-section{padding:48px 0 64px}
.section-title{font-size:1.8rem;font-weight:800;text-align:center;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--gray-800),var(--gray-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-subtitle{text-align:center;color:var(--gray-500);font-size:.95rem;margin-top:8px;margin-bottom:40px}
.crossing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px}
.crossing-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;
  background:#ffffff;border:2px solid var(--gray-200);transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}
.crossing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.crossing-card.active{border-color:var(--blue-500);box-shadow:var(--shadow-glow)}
.card-image{height:220px;background-size:cover;background-position:center;position:relative}
.card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,40,.05) 0%,rgba(10,22,40,.7) 100%)}
.card-badge{position:absolute;top:16px;right:16px;background:rgba(5,150,105,.9);backdrop-filter:blur(8px);
  color:#fff;padding:6px 14px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:6px}
.badge-dot{width:7px;height:7px;background:#6ee7b7;border-radius:50%;display:inline-block;animation:pulse 2s infinite}
.card-content{padding:24px}
.card-content h3{font-size:1.25rem;font-weight:700;margin-bottom:14px;color:var(--gray-800)}
.card-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:14px}
.meta-item{display:flex;align-items:center;gap:7px;font-size:.85rem;color:var(--gray-600)}
.meta-item svg{width:16px;height:16px;flex-shrink:0;color:var(--blue-500)}
.card-desc{font-size:.85rem;color:var(--gray-500);line-height:1.5}
.card-select-indicator{position:absolute;bottom:20px;right:20px;width:36px;height:36px;border-radius:50%;
  background:var(--blue-50);border:2px solid var(--blue-200);display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.7);transition:var(--transition)}
.card-select-indicator svg{width:18px;height:18px;color:var(--blue-400)}
.crossing-card.active .card-select-indicator{opacity:1;transform:scale(1);background:var(--blue-500);border-color:var(--blue-400)}
.crossing-card.active .card-select-indicator svg{color:#fff}

/* ═══════════════════════ DETAILS SECTION ═══════════════════════ */
.details-section{padding:64px 0 80px;background:linear-gradient(180deg,#ffffff 0%,var(--gray-50) 50%,#ffffff 100%)}
.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.detail-card{background:#ffffff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);
  overflow:hidden;transition:var(--transition);animation:fadeInUp .5s ease both;box-shadow:var(--shadow-sm)}
.detail-card:nth-child(1){animation-delay:.05s}.detail-card:nth-child(2){animation-delay:.1s}
.detail-card:nth-child(3){animation-delay:.15s}.detail-card:nth-child(4){animation-delay:.2s}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.detail-card:hover{border-color:var(--blue-200);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.detail-card-header{display:flex;align-items:center;gap:14px;padding:24px 24px 0}
.detail-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.detail-icon svg{width:22px;height:22px}
.schedule-icon{background:var(--blue-100);color:var(--blue-500)}
.price-icon{background:var(--green-100);color:var(--green-600)}
.duration-icon{background:var(--blue-50);color:var(--blue-500)}
.map-icon{background:var(--green-100);color:var(--green-600)}
.detail-card-header h3{font-size:1.05rem;font-weight:700;color:var(--gray-800)}
.detail-card-body{padding:20px 24px 24px}

/* Schedule */
.schedule-group{margin-bottom:20px}
.schedule-group:last-child{margin-bottom:0}
.schedule-group h4{font-size:.85rem;font-weight:600;color:var(--gray-600);margin-bottom:10px}
.time-chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:6px 14px;border-radius:var(--radius-sm);background:var(--blue-50);color:var(--blue-600);font-size:.8rem;font-weight:600;
  border:1px solid var(--blue-100);transition:var(--transition)}
.chip:hover{background:var(--blue-100);transform:scale(1.05)}

/* Prices */
.price-table{width:100%;border-collapse:separate;border-spacing:0 4px}
.price-table th{text-align:left;padding:10px 14px;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);font-weight:600}
.price-table td{padding:12px 14px;font-size:.9rem;color:var(--gray-700)}
.price-table tbody tr{background:var(--gray-50);transition:var(--transition)}
.price-table tbody tr:hover{background:var(--blue-50)}
.price-table tbody tr td:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}
.price-table tbody tr td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-weight:600;color:var(--green-600)}

/* Duration */
.duration-display{text-align:center}
.duration-main{margin-bottom:16px}
.duration-number{font-size:3.5rem;font-weight:900;
  background:linear-gradient(135deg,var(--blue-500),var(--green-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.duration-unit{font-size:1.1rem;font-weight:600;color:var(--gray-500);margin-left:6px}
.duration-note{font-size:.8rem;color:var(--gray-400);margin-bottom:20px;max-width:320px;margin-left:auto;margin-right:auto}
.duration-extras{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.extra-item{text-align:center;padding:14px 8px;background:var(--gray-50);border-radius:var(--radius-sm);border:1px solid var(--gray-200)}
.extra-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);margin-bottom:4px;font-weight:600}
.extra-value{font-size:.9rem;font-weight:700;color:var(--blue-600);line-height:1.2}
.cap-list{display:flex;flex-direction:column;gap:6px;align-items:flex-start;margin-top:8px;padding-left:15%}
.cap-item{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--gray-700);font-weight:600}
.cap-item svg{width:16px;height:16px;color:var(--blue-500);flex-shrink:0}

/* Map */
.map-container{position:relative}
.map-link{display:inline-block;margin-top:12px;font-size:.8rem;color:var(--blue-500);font-weight:600;transition:var(--transition)}
.map-link:hover{color:var(--blue-600);text-decoration:underline}

/* ═══════════════════════ FOOTER ═══════════════════════ */
#footer{padding:64px 0 0;background:var(--gray-900);color:var(--gray-300);border-top:1px solid var(--gray-200)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-size:1.15rem;font-weight:700;color:#fff}
.footer-logo svg{width:36px;height:36px;color:var(--blue-400)}
.footer-desc{font-size:.85rem;color:var(--gray-400);line-height:1.6}
.footer-col h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-300);font-weight:700;margin-bottom:14px}
.footer-col a{display:block;font-size:.85rem;color:var(--gray-400);padding:5px 0;transition:var(--transition)}
.footer-col a:hover{color:var(--blue-400);padding-left:6px}
.footer-col p{font-size:.85rem;color:var(--gray-400);line-height:1.6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0}
.legal-notice{font-size:.78rem;color:var(--gray-400);line-height:1.7;padding:16px 20px;background:rgba(255,255,255,.04);
  border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.06);margin-bottom:20px}
.footer-meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--gray-500)}

/* ═══════════════════════ BACK TO TOP ═══════════════════════ */
.back-to-top{position:fixed;bottom:28px;right:28px;width:48px;height:48px;border-radius:50%;
  background:var(--blue-500);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);opacity:0;transform:translateY(20px);transition:var(--transition);z-index:90}
.back-to-top.visible{opacity:1;transform:translateY(0)}
.back-to-top:hover{background:var(--blue-600);transform:translateY(-3px)}
.back-to-top svg{width:22px;height:22px}

/* ═══════════════════════ ADMIN & MODALS ═══════════════════════ */
.admin-lock-btn{background:none;border:none;color:var(--gray-600);cursor:pointer;padding:8px;opacity:.6;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.admin-lock-btn:hover{opacity:1;color:var(--blue-500);background:rgba(0,0,0,0.05);border-radius:50%}
.admin-lock-btn svg{width:18px;height:18px}

.modal{position:fixed;inset:0;background:rgba(15,23,42,.6);backdrop-filter:blur(8px);z-index:200;
  display:none;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}
.modal.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.modal-content{background:#fff;border-radius:var(--radius-lg);position:relative;box-shadow:var(--shadow-lg);max-width:500px;width:100%;overflow:hidden}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:2rem;color:var(--gray-400);cursor:pointer;line-height:1}

.login-box{padding:40px;text-align:center}
.login-box h3{margin-bottom:8px;font-size:1.5rem}
.login-box p{color:var(--gray-500);margin-bottom:24px}
.login-box input{width:100%;padding:14px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);margin-bottom:16px;font-size:1rem}
.error-text{color:#ef4444;font-size:.85rem;margin-top:8px}

.btn-primary{background:var(--blue-500);color:#fff;border:none;padding:14px 28px;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:var(--transition);width:100%}
.btn-primary:hover{background:var(--blue-600);transform:translateY(-2px)}
.btn-outline{background:none;border:1px solid var(--gray-300);color:var(--gray-600);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer}

/* Dashboard */
.dashboard-box{max-width:800px;display:flex;flex-direction:column;max-height:90vh}
.dashboard-header{padding:24px;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}
.dashboard-tabs{display:flex;background:var(--gray-50);padding:8px}
.tab-btn{flex:1;padding:12px;border:none;background:none;font-weight:600;color:var(--gray-500);cursor:pointer;border-radius:var(--radius-sm)}
.tab-btn.active{background:#fff;color:var(--blue-600);box-shadow:var(--shadow-sm)}
.dashboard-body{padding:24px;overflow-y:auto;flex:1}
.dashboard-footer{padding:20px 24px;border-top:1px solid var(--gray-100)}

.admin-section{margin-bottom:32px}
.admin-section h4{margin-bottom:16px;color:var(--gray-800);display:flex;align-items:center;gap:8px}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.admin-field{display:flex;flex-direction:column;gap:6px}
.admin-field label{font-size:.8rem;font-weight:600;color:var(--gray-500)}
.admin-field input, .admin-field select{padding:10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}

.admin-table{width:100%;border-collapse:collapse}
.admin-table th{text-align:left;font-size:.75rem;color:var(--gray-400);padding:8px}
.admin-table td{padding:12px 8px;border-top:1px solid var(--gray-100)}

.switch{position:relative;display:inline-block;width:40px;height:20px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:20px}
.slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:white;transition:.4s;border-radius:50%}
input:checked+.slider{background-color:var(--green-500)}
input:checked+.slider:before{transform:translateX(20px)}

.schedule-manager{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.time-tag{background:var(--blue-50);color:var(--blue-600);padding:4px 10px;border-radius:20px;font-size:.85rem;display:flex;align-items:center;gap:6px}
.time-tag button{background:none;border:none;color:var(--blue-400);cursor:pointer;font-size:1.1rem;line-height:1}

.row-stopped td{opacity:.5}
.status-badge-parado{background:#fef2f2;color:#ef4444;font-size:.7rem;padding:2px 6px;border-radius:4px;font-weight:700;margin-left:8px}

.log-list{display:flex;flex-direction:column;gap:12px}
.log-item{padding:12px;background:var(--gray-50);border-radius:var(--radius-sm);border-left:4px solid var(--blue-500);font-size:.85rem}
.log-time{display:block;font-size:.7rem;color:var(--gray-400);font-weight:700;margin-bottom:4px;text-transform:uppercase}
.log-msg{color:var(--gray-700)}
.log-empty{text-align:center;color:var(--gray-400);padding:40px 0}

/* ═══════════════════════ RESPONSIVE ═══════════════════════ */
@media(max-width:900px){
  .details-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-meta{flex-direction:column;gap:6px}
}
@media(max-width:700px){
  .header-nav{display:none}
  .mobile-menu-btn{display:flex}
  .header-inner{height:auto;min-height:60px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
  .logo-group{display:flex;align-items:center;gap:8px;flex:1;min-width:0;overflow:visible}
  .logo-group div{flex:1;min-width:0}
  .logo-group h1{font-size:0.9rem;line-height:1.2;white-space:normal;background:none;-webkit-text-fill-color:var(--blue-800);color:var(--blue-800);margin:0;display:block;width:100%}
  .tagline{font-size:.55rem;margin-top:0;display:block;color:var(--gray-500)}
  .logo-icon{width:32px;height:32px;flex-shrink:0}
  .logo-icon svg{width:100%;height:100%;display:block}
  .mobile-menu-btn{margin-left:0;padding:4px}
  .lang-toggle{padding:4px 6px;margin-left:0}
  .lang-label{display:none}
  .crossing-cards{grid-template-columns:1fr}
  .section-title{font-size:1.4rem}
  .status-cards{grid-template-columns:1fr}
  .duration-extras{grid-template-columns:1fr}
  .card-image{height:180px}
}
