:root { --bg:#0a0e27; --panel:#111827; --panel-border:#1e293b; --text:#f1f5f9; --muted:#94a3b8; --accent:#ef4444; --danger:#dc2626; --ok:#10b981; --outline:#475569; --f1-yellow:#fbbf24; --f1-red:#dc2626; }
  *{box-sizing:border-box}
  body{margin:0;font-family:'Segoe UI', 'Helvetica Neue', system-ui, sans-serif;background:linear-gradient(135deg, var(--bg) 0%, #0f1932 100%);color:var(--text);line-height:1.6;overflow-x:hidden;
    /* iPhone/iPad safe areas (notch support) */
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
    padding-bottom: env(safe-area-inset-bottom);
  }

  #loadingOverlay.show{
    animation:gppoule-loading-overlay-failsafe 6s forwards;
  }

  @keyframes gppoule-loading-overlay-failsafe{
    0%,85%{opacity:1;visibility:visible;pointer-events:auto}
    100%{opacity:0;visibility:hidden;pointer-events:none}
  }

  /* ===== ANIMATED HEADER ===== */
  header{
    position: sticky;
    top: 0;
    z-index: 1000;
    background: linear-gradient(90deg, #2a2a2a 0%, #1a1a1a 50%, rgba(225, 6, 0, 0.3) 100%);
    padding: 20px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 4px 20px rgba(225, 6, 0, 0.6);
    height: 90px;
    overflow: visible;
    border-bottom: none;
    max-width: 100vw; /* Prevent header from exceeding viewport width */
    /* Safe area padding for iPhone notch */
    padding-top: max(20px, env(safe-area-inset-top));
  }

  .header-content{
    position: relative;
    width: 100%;
    max-width: 100%; /* Ensure content stays within bounds */
    height: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
    padding: 0 15px; /* Add horizontal padding to keep items within screen */
  }

  /* Car animation */
  .car-background{
    position: absolute;
    bottom: 0;
    left: -400px;
    width: 380px;
    height: auto;
    opacity: 0.4;
    pointer-events: none;
    z-index: 1;
    animation: drive-stop-accelerate 10s cubic-bezier(0.25, 0.1, 0.25, 1) 1s forwards;
  }

  .car-background img{
    width: 100%;
    height: auto;
    filter: brightness(1.3) contrast(1.2) saturate(1.2);
  }

  /* Logo */
  .logo{
    z-index: 10;
    position: relative;
  }

  .logo img{
    height: 50px;
    width: auto;
    filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.8));
  }

  /* Title with traffic lights */
  .title{
    z-index: 10;
    position: relative;
  }

  .title h1{
    margin: 0;
    font-size: 36px;
    font-weight: 700;
    color: white;
    text-transform: uppercase;
    letter-spacing: 3px;
    text-shadow: 2px 2px 8px rgba(225, 6, 0, 0.9), 0 0 20px rgba(225, 6, 0, 0.5);
    display: flex;
    align-items: center;
    gap: 15px;
    background: none;
    -webkit-background-clip: unset;
    -webkit-text-fill-color: unset;
    background-clip: unset;
  }

  .traffic-lights{
    display: flex;
    gap: 8px;
    animation: lights-sequence 10s ease-in-out 1s forwards;
  }

  .light{
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #333;
    box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.8);
  }

  .light:nth-child(1) { animation: light-on 0.2s ease-out 4s forwards; }
  .light:nth-child(2) { animation: light-on 0.2s ease-out 5s forwards; }
  .light:nth-child(3) { animation: light-on 0.2s ease-out 6s forwards; }
  .light:nth-child(4) { animation: light-on 0.2s ease-out 7s forwards; }
  .light:nth-child(5) { animation: light-on 0.2s ease-out 8s forwards; }

  @keyframes light-on{
    from { background: #333; box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.8); }
    to { background: #ff0000; box-shadow: 0 0 15px #ff0000, inset 0 0 5px rgba(255, 0, 0, 0.6); }
  }

  @keyframes lights-sequence{
    0%, 80% { opacity: 1; }
    80.5%, 100% { opacity: 0; }
  }

  /* Hamburger */
  .hamburger{
    display: none; /* Hidden on desktop, shown on mobile */
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    z-index: 10;
    position: relative;
  }

  .hamburger span{
    width: 30px;
    height: 3px;
    background: white;
    border-radius: 2px;
    transition: all 0.3s;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.6);
  }

  .hamburger:hover span{
    background: #e10600;
    box-shadow: 0 0 12px rgba(225, 6, 0, 0.9);
  }

  .hamburger:hover span:nth-child(1) { transform: translateY(-2px); }
  .hamburger:hover span:nth-child(3) { transform: translateY(2px); }
  
  /* Hamburger active state - animated X */
  .hamburger.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
  }
  .hamburger.active span:nth-child(2) {
    opacity: 0;
  }
  .hamburger.active span:nth-child(3) {
    transform: rotate(-45deg) translate(6px, -6px);
  }

  /* Glow line */
  .glow-line{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, transparent, #ff6600 20%, #e10600 50%, #ff6600 80%, transparent);
    box-shadow: 0 0 20px #ff6600, 0 0 30px #e10600;
    z-index: 5;
    animation: pulse-glow 2s ease-in-out infinite;
  }

  @keyframes pulse-glow{
    0%, 100% { box-shadow: 0 0 20px #ff6600, 0 0 30px #e10600; opacity: 0.8; }
    50% { box-shadow: 0 0 40px #ff6600, 0 0 60px #e10600, 0 0 80px rgba(225, 6, 0, 0.5); opacity: 1; }
  }

  @keyframes drive-stop-accelerate{
    0% { left: -900px; opacity: 0; }
    10% { opacity: 0.4; }
    30% { left: 80px; opacity: 0.4; }
    80% { left: 80px; opacity: 0.4; }
    100% { left: 1400px; opacity: 0; }
  }

  /* ===== REST OF APP ===== */
  main.app{max-width:1200px;margin:0 auto;padding:24px 16px}
  .tabs{display:flex;gap:12px;margin-top:26px;margin-bottom:24px;flex-wrap:wrap}
  .tabs button{background:rgba(255,255,255,.05);color:var(--text);border:2px solid transparent;border-radius:10px;padding:12px 20px;cursor:pointer;font-weight:700;font-size:15px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}
  .tabs button:hover{background:rgba(255,255,255,.1);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px rgba(239,68,68,.2)}
  .tabs button.active{background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);border-color:var(--accent);box-shadow:0 8px 16px rgba(239,68,68,.3)}
  section.panel{display:none;background:linear-gradient(135deg, var(--panel) 0%, #0f1932 100%);border:1px solid var(--panel-border);border-radius:16px;padding:20px;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;transform:translateY(20px);transition:opacity .4s ease, transform .4s ease}
  section.panel.active{display:block;animation:panelFadeIn .4s ease forwards}
  section.panel.fade-out{animation:panelFadeOut .3s ease forwards}
  section.panel > h3{margin:0 0 8px;font-size:28px;letter-spacing:-.02em}
  .page-lead{margin:0 0 22px;color:var(--muted);font-size:14px;line-height:1.7;max-width:900px}
  @keyframes panelFadeIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
  @keyframes panelFadeOut{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.98)}}
  .controls{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin:12px 0 24px}
  .controls .group{display:flex;gap:12px;align-items:center;padding:12px;background:rgba(255,255,255,.03);border-radius:10px;flex-wrap:wrap}
  select, input[type=text], input[type=password], input[type=email], input[type=tel]{background:rgba(0,0,0,.3);color:var(--text);border:2px solid var(--outline);border-radius:10px;padding:12px 14px;font-size:15px;transition:all .2s ease;font-weight:500}
  select:focus, input[type=text]:focus, input[type=password]:focus, input[type=email]:focus, input[type=tel]:focus{outline:none;border-color:var(--accent);background:rgba(0,0,0,.5);box-shadow:0 0 8px rgba(239,68,68,.3)}
  select:hover, input[type=text]:hover, input[type=password]:hover, input[type=email]:hover, input[type=tel]:hover{border-color:var(--accent)}
  .dynamicSelect{background:rgba(0,0,0,.65) !important;border:2px solid rgba(71,85,105,.8) !important;color:var(--text) !important;border-radius:10px !important;cursor:pointer !important;font-weight:600 !important;padding:10px 12px !important}
  .dynamicSelect:hover{border-color:var(--f1-yellow) !important;box-shadow:0 0 10px rgba(251,191,36,.3) !important}
  .dynamicSelect:focus{outline:none !important;border-color:var(--f1-yellow) !important;box-shadow:0 0 12px rgba(251,191,36,.4) !important}
  label{font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
  .btn{background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);color:#fff;border:none;padding:12px 20px;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(239,68,68,.2);text-transform:uppercase;letter-spacing:.5px;font-size:14px}
  .btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(239,68,68,.4)}
  .btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(239,68,68,.2)}
  .btn.secondary{background:rgba(255,255,255,.1);border:2px solid var(--outline)}
  .btn.secondary:hover{background:rgba(255,255,255,.15);border-color:var(--accent)}
  .btn.danger{background:linear-gradient(135deg, #dc2626 0%, #ef4444 100%)}
  .card{background:linear-gradient(180deg, rgba(255,255,255,.045) 0%, rgba(15,23,42,.58) 100%);border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:18px;box-shadow:0 12px 28px rgba(2,6,23,.22);backdrop-filter:blur(8px);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
  .card:hover{border-color:rgba(239,68,68,.28);box-shadow:0 16px 32px rgba(2,6,23,.3)}
  .card > h4{margin:0 0 10px;font-size:17px;letter-spacing:-.02em}
  .metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
  .app-footer{margin:34px auto 18px;max-width:1200px;padding:0 16px 24px}
  .app-footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;background:linear-gradient(180deg, rgba(255,255,255,.035) 0%, rgba(15,23,42,.42) 100%);border:1px solid rgba(148,163,184,.16);border-radius:16px;padding:16px 18px;box-shadow:0 10px 24px rgba(2,6,23,.18)}
  .app-footer-brand{display:flex;flex-direction:column;gap:4px}
  .app-footer-brand strong{font-size:15px;letter-spacing:.02em}
  .app-footer-brand span{font-size:12px;color:var(--muted)}
  .app-footer-meta{display:flex;gap:10px 14px;flex-wrap:wrap;justify-content:flex-end;color:var(--muted);font-size:12px}
  .app-footer-meta span{padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(148,163,184,.12)}
  .metric-card{position:relative;overflow:hidden}
  .metric-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg, rgba(239,68,68,.85), rgba(251,191,36,.7));opacity:.9}
  .metric-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}
  .metric-value{font-size:28px;font-weight:900;line-height:1.1;letter-spacing:-.03em}
  .metric-meta{margin-top:8px;font-size:13px;color:var(--muted);line-height:1.5}
  .hero-card{background:linear-gradient(135deg, rgba(15,23,42,.96) 0%, rgba(30,41,59,.94) 100%);border:1px solid rgba(96,165,250,.24);box-shadow:0 18px 40px rgba(2,6,23,.28)}
  .action-card{background:linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(15,23,42,.6) 100%)}
  .feature-card{min-height:100%}
  .soft-banner{background:linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(15,23,42,.52) 100%);border-left:4px solid var(--accent)}
  .section-title-row{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;margin:26px 0 14px}
  .section-title-row h4{margin:0;font-size:18px}
  .section-title-row p{margin:0;color:var(--muted);font-size:13px}
  .card-grid-tight{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
  .list-empty{color:var(--muted);font-size:13px;line-height:1.6}
  .commerce-hero-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:20px}
  .commerce-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);font-size:12px;font-weight:700;color:var(--text)}
  .commerce-plan-card{position:relative;overflow:hidden}
  .commerce-plan-card::before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:3px;background:linear-gradient(90deg, rgba(255,255,255,.3), rgba(255,255,255,.02))}
  .commerce-plan-card.recommended{box-shadow:0 18px 36px rgba(217,119,6,.18);border-color:rgba(251,191,36,.35)}
  .commerce-plan-card.recommended::before{background:linear-gradient(90deg, rgba(251,191,36,.9), rgba(249,115,22,.8))}
  .commerce-compare-table{width:100%;border-collapse:collapse;font-size:13px}
  .commerce-compare-table th,.commerce-compare-table td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.08);vertical-align:top}
  .commerce-compare-table th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left}
  .commerce-compare-table td strong{color:var(--text)}
  .commerce-owner-note{padding:14px 16px;border-radius:14px;background:linear-gradient(135deg, rgba(96,165,250,.12), rgba(15,23,42,.4));border:1px solid rgba(96,165,250,.24);font-size:13px;color:var(--text)}

  /* Progress bar loading animation */
  @keyframes fillBar {
    from { width: 0%; }
  }

  /* Loading spinner */
  @keyframes spin {
    to { transform: rotate(360deg); }
  }
  .loading-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
  }
  .loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    backdrop-filter: blur(4px);
  }
  .loading-overlay .spinner {
    width: 60px;
    height: 60px;
    border: 4px solid rgba(255,255,255,.2);
    border-top-color: var(--f1-yellow);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
  }

  /* Dark mode toggle */
  .dark-mode-toggle {
    position: fixed;
    top: 80px;
    right: 20px;
    z-index: 1000;
    background: rgba(255,255,255,.1);
    border: 2px solid rgba(255,255,255,.2);
    border-radius: 50px;
    padding: 8px 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 20px;
  }
  .dark-mode-toggle:hover {
    background: rgba(255,255,255,.15);
    border-color: var(--f1-yellow);
    transform: scale(1.05);
  }
  body.light-mode {
    --bg: #f5f5f5;
    --panel: #ffffff;
    --text: #0a0e27;
    --outline: #d1d5db;
  }
  body.light-mode .driver-card {
    background: linear-gradient(135deg, #ffffff 0%, #f3f4f6 100%);
    color: #0a0e27;
  }
  
  /* Checkmark flash on successful drop */
  @keyframes checkmarkFlash {
    0% { opacity: 0; transform: translate(-50%, -50%) scale(0.5); }
    50% { opacity: 1; transform: translate(-50%, -50%) scale(1.3); }
    100% { opacity: 0; transform: translate(-50%, -50%) scale(1); }
  }
  .checkmark-flash {
    position: fixed;
    font-size: 60px;
    color: #10b981;
    pointer-events: none;
    z-index: 10000;
    animation: checkmarkFlash 0.8s ease-out;
    text-shadow: 0 0 20px rgba(16,185,129,1), 0 0 40px rgba(16,185,129,.6);
    font-weight: 900;
  }

  /* Loading spinner */
  @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
  }
  .loading-spinner {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 4px solid rgba(239,68,68,.2);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
  }
  .loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    gap: 20px;
    color: var(--muted);
  }
  .loading-container p {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
  }

  /* Rank change arrow animations */
  @keyframes rankUp {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
  }
  @keyframes rankDown {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(4px); }
  }
  @keyframes pulse {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.15); opacity: 0.9; }
    100% { transform: scale(1); opacity: 1; }
  }
  .rank-up {
    color: #10b981 !important;
    font-weight: 700 !important;
    font-size: 18px !important;
    display: inline-block !important;
    animation: rankUp 0.5s ease-in-out infinite !important;
  }
  .rank-down {
    color: #ef4444 !important;
    font-weight: 700 !important;
    font-size: 18px !important;
    display: inline-block !important;
    animation: rankDown 0.5s ease-in-out infinite !important;
  }
  
  /* Ranking table row fade-in */
  @keyframes fadeInRow {
    from { opacity: 0; transform: translateX(-20px); }
    to { opacity: 1; transform: translateX(0); }
  }

  .predict-layout{display:grid;grid-template-columns:280px 1fr 280px;gap:20px;align-items:start}
  #drivers-list{position:sticky;top:100px;height:fit-content;max-height:calc(100vh - 100px);border:1px solid var(--panel-border);border-radius:16px;padding:16px;background:linear-gradient(135deg, rgba(17,24,39,.8) 0%, rgba(15,25,50,.8) 100%);overflow:auto;z-index:8;box-shadow:0 8px 24px rgba(0,0,0,.3)}
  #canvasWrap{position:sticky;top:100px;height:fit-content;max-height:calc(100vh - 100px);overflow:auto;z-index:8}
  #seasonPredictions{display:block}
  #drivers-list h4{margin-top:0;font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;color:var(--f1-yellow)}
  .driver-card{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:10px;border-radius:8px;color:#0a0e27 !important;font-weight:700;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:all .3s ease;font-size:14px;position:relative;z-index:1;border-left:5px solid #666}
  .driver-card:hover{transform:translateX(4px);box-shadow:0 4px 12px rgba(0,0,0,.25)}
  .driver-card.dragging{opacity:0.5 !important;transform:scale(0.95) !important;z-index:1000 !important;box-shadow:0 8px 24px rgba(0,0,0,.5) !important;cursor:grabbing !important}
  .driver-team{font-size:12px;color:#555;margin-left:auto;font-weight:600}

  .canvas{position:relative;width:100%;aspect-ratio:1/1;border:3px solid var(--accent);border-radius:16px;background:linear-gradient(135deg, rgba(31,41,55,.8) 0%, rgba(15,25,50,.8) 100%);overflow:hidden;box-shadow:0 12px 32px rgba(239,68,68,.15);transition:border-color 0.3s ease}
  .canvas .bg{position:absolute;inset:0;pointer-events:none}
  .canvas .bg::before{content:"";position:absolute;inset:0;border:6px solid rgba(239,68,68,.1);border-radius:12px;box-shadow:inset 0 0 0 2px rgba(239,68,68,.05)}

  #grid-race10 .slot{position:absolute;width:43%;height:12%;border-radius:12px;background:linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(240,240,240,.9) 100%);display:flex;align-items:center;justify-content:center;padding:8px;box-sizing:border-box;font-weight:800;color:#0a0e27;outline:3px dashed transparent;transition:all .2s ease;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.2)}
  #grid-race10 .slot:hover{transform:scale(1.05);box-shadow:0 6px 18px rgba(0,0,0,.3)}
  #grid-race10 .slot.drop-target{outline-color:var(--ok) !important;background:linear-gradient(135deg, rgba(234,179,8,.2) 0%, rgba(234,179,8,.1) 100%) !important;border:2px dashed #eab308 !important;box-shadow:0 0 0 3px rgba(234,179,8,.4),0 8px 20px rgba(0,0,0,.25) !important;transform:scale(1.04);transition:all 0.2s ease !important}
  #grid-race10 .slot::after{content:attr(data-slot);position:absolute;top:-14px;left:-14px;background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);color:#fff;font-size:12px;border-radius:10px;padding:3px 7px;opacity:.9;font-weight:800}

  .vslots{display:flex;flex-direction:column;gap:10px}
  .countdown-mini{transition:all 0.3s ease}
  #grid-quali, #grid-sprint, #grid-sq{border:3px solid var(--accent);border-radius:16px;padding:16px;background:linear-gradient(135deg, rgba(31,41,55,.6) 0%, rgba(15,25,50,.6) 100%);transition:border-color 0.3s ease}
  .vslot{height:50px;border-radius:12px;background:linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(240,240,240,.9) 100%);display:flex;align-items:center;justify-content:center;padding:6px 8px;box-sizing:border-box;font-weight:800;color:#0a0e27;outline:3px dashed transparent;position:relative;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.2);transition:all .2s ease;font-size:14px;cursor:pointer}
  .vslot:hover{transform:translateX(4px);box-shadow:0 6px 18px rgba(0,0,0,.3)}
  .vslot:active{transform:scale(0.98)}
  .vslot.drop-target{outline-color:var(--ok) !important;background:linear-gradient(135deg, rgba(234,179,8,.2) 0%, rgba(234,179,8,.1) 100%) !important;border:2px dashed #eab308 !important;box-shadow:0 0 0 3px rgba(234,179,8,.4),0 8px 20px rgba(0,0,0,.25) !important;transform:scale(1.02);transition:all 0.2s ease !important}
  
  /* Disable heavy animations on mobile devices */
  .mobile-device .car-background,
  .mobile-device .traffic-lights,
  .mobile-device .checkmark-flash {
    animation: none !important;
  }
  
  /* Keep rank animations on mobile but make them lighter */
  @media (max-width: 900px) {
    .rank-up {
      animation: rankUp 0.8s ease-in-out 3 !important; /* Only 3 iterations instead of infinite */
    }
    .rank-down {
      animation: rankDown 0.8s ease-in-out 3 !important; /* Only 3 iterations instead of infinite */
    }
  }
  
  /* Desktop: infinite animation */
  @media (min-width: 901px) {
    .rank-up {
      animation: rankUp 0.5s ease-in-out infinite !important;
    }
    .rank-down {
      animation: rankDown 0.5s ease-in-out infinite !important;
    }
  }
  
  .mobile-device * {
    transition-duration: 0.15s !important; /* Faster transitions */
  }
  
  /* Landscape specific styling */
  body.landscape .dash-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  
  body.landscape .tabs {
    font-size: 11px;
  }
  
  /* Loading spinner overlay */
  #loadingOverlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 9998;
  }
  
  #loadingOverlay.show {
    display: flex;
  }
  
  .loading-spinner {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-top-color: var(--f1-yellow);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
  }
  
  @keyframes spin {
    to { transform: rotate(360deg); }
  }
  
  .loading-text {
    position: absolute;
    margin-top: 80px;
    color: var(--f1-yellow);
    font-weight: 700;
    font-size: 14px;
  }
  
  /* Mobile improvements */
  @media (max-width: 600px) {
    .vslot{height:60px;font-size:13px;padding:8px;touch-action:manipulation}
    .vslot:active{transform:scale(0.95)}
    .driver-card{cursor:grab;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
    .driver-card:active{cursor:grabbing;opacity:0.8}
  }
  
  /* Extra small phones */
  @media (max-width: 380px) {
    header{padding:8px 12px;height:60px}
    .title h1{font-size:16px}
    .logo img{height:32px}
    main.app{padding:8px 6px}
    .tabs button{min-width:100px;font-size:11px;padding:8px 10px}
    .btn, button{font-size:13px;padding:10px 12px}
    .dash-card h3{font-size:16px}
  }

  /* Ensure placed driver cards fill the slot and align nicely */
  #grid-race10 .slot .driver-card, .vslot .driver-card{width:100%;height:100%;margin:0;padding:6px 8px;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;font-weight:700;border:none;font-size:15px}
  #grid-race10 .slot .driver-team, .vslot .driver-team{margin-left:auto;font-size:11px;color:#555}
  #grid-race10 .slot .driver-card span, .vslot .driver-card span{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* Predict grid small badges */
  #grid-race10 .slot .pos-badge, .vslot .pos-badge{position:absolute;left:8px;top:8px;background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);color:#fff;font-size:11px;border-radius:10px;padding:3px 7px;opacity:.95;font-weight:800;box-shadow:0 2px 8px rgba(0,0,0,.3)}
  .pos-badge.small-badge{font-size:11px;padding:3px 7px;border-radius:8px}

  /* Custom tooltip for full driver info */
  #f1-tooltip{position:fixed;z-index:9999;background:rgba(10,14,39,.95);color:#fff;padding:8px 12px;border-radius:8px;font-size:13px;pointer-events:none;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:none;border:1px solid var(--accent);box-shadow:0 4px 12px rgba(0,0,0,.4);font-weight:600} 

  table{width:100%;border-collapse:collapse}
  th,td{border:1px solid var(--panel-border);padding:10px 12px;text-align:left}
  th{background:linear-gradient(135deg, rgba(31,41,55,.8) 0%, rgba(15,25,50,.8) 100%);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--f1-yellow)}
  td{background:rgba(255,255,255,.02);transition:all .2s ease}
  tr:hover td{background:rgba(255,255,255,.05)}
  .points-header{display:flex;align-items:center;gap:12px;font-weight:700}

  /* Compact results layout: stacked sections (vertical) */
  .results-layout{display:flex;flex-direction:column;gap:16px}
  .results-layout .card:nth-child(1){order:1}
  .results-layout .card:nth-child(2){order:2}
  .results-layout .card:nth-child(3){order:3}
  .results-layout .card:nth-child(4){order:4}
  .results-layout .card{width:100%;padding:16px;box-sizing:border-box;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--panel-border);margin-bottom:8px}

  /* Race results grid-stijl zoals voorspel blad - larger and more readable */
  #raceTop22{position:relative;min-height:750px;padding:20px;background:linear-gradient(135deg, rgba(15,25,50,.3) 0%, rgba(10,14,39,.3) 100%);border-radius:12px}
  #raceTop22 .pos-row{position:absolute;width:320px;height:64px;display:flex;align-items:center;gap:12px;padding:10px 14px 10px 60px;border-radius:12px;background:linear-gradient(135deg, rgba(31,41,55,.95) 0%, rgba(15,25,50,.95) 100%);box-sizing:border-box;border:2px solid var(--panel-border);transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3)}
  #raceTop22 .pos-row:hover{background:linear-gradient(135deg, rgba(31,41,55,1) 0%, rgba(15,25,50,1) 100%);border-color:var(--accent);transform:scale(1.05);box-shadow:0 6px 18px rgba(0,0,0,.5);z-index:10}
  #raceTop22 .pos-row select{flex:1;min-width:220px;max-width:280px;font-size:16px;background:rgba(0,0,0,.4);border:1px solid var(--outline);color:var(--text);border-radius:8px;padding:12px 14px;font-weight:600}
  #raceTop22 .pos-row select:focus{border-color:var(--accent);outline:none;background:rgba(0,0,0,.6)}
  #raceTop22 .pos-row div{display:flex;gap:6px;align-items:center;margin-left:auto}
  #raceTop22 .pos-row input[type=checkbox]{transform:scale(1.3);cursor:pointer}
  #raceTop22 .pos-row label{font-size:11px;cursor:pointer;text-transform:none;letter-spacing:0}

  /* Sprint Race grid-stijl zoals voorspel blad - larger and more readable */
  #sprintRaceTop8{position:relative;min-height:750px;padding:20px;background:linear-gradient(135deg, rgba(15,25,50,.3) 0%, rgba(10,14,39,.3) 100%);border-radius:12px}
  #sprintRaceTop8 .pos-row{position:absolute;width:320px;height:64px;display:flex;align-items:center;gap:12px;padding:10px 14px 10px 60px;border-radius:12px;background:linear-gradient(135deg, rgba(31,41,55,.95) 0%, rgba(15,25,50,.95) 100%);box-sizing:border-box;border:2px solid var(--panel-border);transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3)}
  #sprintRaceTop8 .pos-row:hover{background:linear-gradient(135deg, rgba(31,41,55,1) 0%, rgba(15,25,50,1) 100%);border-color:var(--accent);transform:scale(1.05);box-shadow:0 6px 18px rgba(0,0,0,.5);z-index:10}
  #sprintRaceTop8 .pos-row select{flex:1;min-width:220px;max-width:280px;font-size:16px;background:rgba(0,0,0,.4);border:1px solid var(--outline);color:var(--text);border-radius:8px;padding:12px 14px;font-weight:600}
  #sprintRaceTop8 .pos-row select:focus{border-color:var(--accent);outline:none;background:rgba(0,0,0,.6)}
  #sprintRaceTop8 .pos-row div{display:flex;gap:6px;align-items:center;margin-left:auto}
  #sprintRaceTop8 .pos-row input[type=checkbox]{transform:scale(1.3);cursor:pointer}
  #sprintRaceTop8 .pos-row label{font-size:11px;cursor:pointer;text-transform:none;letter-spacing:0}

  /* Qualifying grid-stijl zoals Race (absolute positioning) - larger and more readable */
  #qualiTop3{position:relative;min-height:250px;padding:20px;background:linear-gradient(135deg, rgba(15,25,50,.3) 0%, rgba(10,14,39,.3) 100%);border-radius:12px}
  #qualiTop3 .pos-row{position:absolute;width:320px;height:64px;display:flex;align-items:center;gap:12px;padding:10px 14px 10px 60px;border-radius:12px;background:linear-gradient(135deg, rgba(31,41,55,.95) 0%, rgba(15,25,50,.95) 100%);box-sizing:border-box;border:2px solid var(--panel-border);transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3)}
  #qualiTop3 .pos-row:hover{background:linear-gradient(135deg, rgba(31,41,55,1) 0%, rgba(15,25,50,1) 100%);border-color:var(--accent);transform:scale(1.05);box-shadow:0 6px 18px rgba(0,0,0,.5);z-index:10}
  #qualiTop3 .pos-row select{flex:1;min-width:220px;max-width:280px;font-size:16px;background:rgba(0,0,0,.4);border:1px solid var(--outline);color:var(--text);border-radius:8px;padding:12px 14px;font-weight:600}
  #qualiTop3 .pos-row select:focus{border-color:var(--accent);outline:none;background:rgba(0,0,0,.6)}
  #qualiTop3 .pos-row div{display:flex;gap:6px;align-items:center;margin-left:auto}
  #qualiTop3 .pos-row input[type=checkbox]{transform:scale(1.3);cursor:pointer}
  #qualiTop3 .pos-row label{font-size:11px;cursor:pointer;text-transform:none;letter-spacing:0}

  /* Sprint Qualifying grid-stijl zoals Sprint Race (absolute positioning) - larger and more readable */
  #sprintQualiTop3{position:relative;min-height:250px;padding:20px;background:linear-gradient(135deg, rgba(15,25,50,.3) 0%, rgba(10,14,39,.3) 100%);border-radius:12px}
  #sprintQualiTop3 .pos-row{position:absolute;width:320px;height:64px;display:flex;align-items:center;gap:12px;padding:10px 14px 10px 60px;border-radius:12px;background:linear-gradient(135deg, rgba(31,41,55,.95) 0%, rgba(15,25,50,.95) 100%);box-sizing:border-box;border:2px solid var(--panel-border);transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3)}
  #sprintQualiTop3 .pos-row:hover{background:linear-gradient(135deg, rgba(31,41,55,1) 0%, rgba(15,25,50,1) 100%);border-color:var(--accent);transform:scale(1.05);box-shadow:0 6px 18px rgba(0,0,0,.5);z-index:10}
  #sprintQualiTop3 .pos-row select{flex:1;min-width:220px;max-width:280px;font-size:16px;background:rgba(0,0,0,.4);border:1px solid var(--outline);color:var(--text);border-radius:8px;padding:12px 14px;font-weight:600}
  #sprintQualiTop3 .pos-row select:focus{border-color:var(--accent);outline:none;background:rgba(0,0,0,.6)}
  #sprintQualiTop3 .pos-row div{display:flex;gap:6px;align-items:center;margin-left:auto}
  #sprintQualiTop3 .pos-row input[type=checkbox]{transform:scale(1.3);cursor:pointer}
  #sprintQualiTop3 .pos-row label{font-size:11px;cursor:pointer;text-transform:none;letter-spacing:0}

  #results .result-driver-name{flex:1;min-width:220px;max-width:280px;font-size:16px;background:rgba(0,0,0,.24);border:1px solid rgba(148,163,184,.22);color:var(--text);border-radius:8px;padding:12px 14px;font-weight:700;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  #results .result-status-wrap{display:flex;gap:6px;align-items:center;margin-left:auto;min-width:48px;justify-content:flex-end}
  #results .result-status-chip{align-items:center;justify-content:center;min-width:42px;padding:3px 7px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}

  /* Position badge styling */
  .pos-badge{position:absolute;left:8px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);color:#fff;font-size:13px;border-radius:10px;padding:6px 10px;font-weight:800;box-shadow:0 3px 10px rgba(239,68,68,.4);min-width:36px;text-align:center;z-index:10}
  #qualiTop3 .pos-badge, #sprintQualiTop3 .pos-badge{left:6px;font-size:12px;padding:5px 9px}

  /* Team logo images and holders */
  img.team-logo{width:18px;height:18px;border-radius:50%;object-fit:contain;background:#fff;border:1px solid rgba(0,0,0,.25);box-shadow:0 2px 6px rgba(0,0,0,.2)}

  /* Loading spinner overlay */
  #loadingOverlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 9998;
  }
  
  #loadingOverlay.show {
    display: flex;
  }
  
  .loading-spinner {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-top-color: var(--f1-yellow);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
  }
  
  @keyframes spin {
    to { transform: rotate(360deg); }
  }
  
  .loading-text {
    position: absolute;
    margin-top: 80px;
    color: var(--f1-yellow);
    font-weight: 700;
    font-size: 14px;
  }
  
  /* Toast notification styling - RECHTSONDER */
  #toast{position:fixed;bottom:24px;right:24px;transform:translateX(calc(100% + 50px));background:linear-gradient(135deg, rgba(17,24,39,.95) 0%, rgba(15,25,50,.95) 100%);color:#fff;padding:16px 24px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.4);font-size:15px;font-weight:600;z-index:9999;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55),opacity .3s ease;opacity:0;pointer-events:none;min-width:300px;max-width:500px;text-align:left;border:2px solid var(--outline)}
  #toast.show{transform:translateX(0);opacity:1;pointer-events:none}
  #toast.success{border-color:#10b981;background:linear-gradient(135deg, #065f46 0%, #047857 100%);color:#86efac;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}
  #toast.error{border-color:#ef4444;background:linear-gradient(135deg, #7f1d1d 0%, #991b1b 100%);color:#fca5a5;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}
  #toast.warning{border-color:#fbbf24;background:linear-gradient(135deg, #92400e 0%, #b45309 100%);color:#fef3c7;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}

  /* ===== AUTH MODAL STYLING ===== */
  #authModal{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease, visibility .2s ease;padding:24px 16px}
  #authModal.is-open{opacity:1;visibility:visible;pointer-events:auto}
  .auth-container{background:linear-gradient(135deg, var(--panel) 0%, #0f1932 100%);border:1px solid var(--panel-border);border-radius:16px;padding:24px;max-width:460px;width:min(100%,460px);max-height:min(88vh,820px);overflow-y:auto;box-shadow:0 8px 32px rgba(239,68,68,.2);scrollbar-gutter:stable}
  .auth-header{text-align:center;margin-bottom:24px}
  .auth-header h2{margin:0;font-size:24px;color:var(--accent);text-shadow:0 2px 4px rgba(239,68,68,.4)}
  .auth-tabs{display:flex;gap:8px;margin-bottom:18px;border-bottom:2px solid var(--outline);padding-bottom:12px}
  .auth-tab{flex:1;padding:8px;text-align:center;cursor:pointer;border:none;background:transparent;color:var(--muted);font-weight:600;border-bottom:3px solid transparent;transition:all .3s;text-transform:uppercase;font-size:12px}
  .auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
  .auth-form{display:none}
  .auth-form.active{display:block;animation:fadeIn .3s}
  .auth-field{margin-bottom:12px}
  .auth-field label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;color:var(--muted)}
  .auth-field input{width:100%;padding:10px 12px;background:rgba(0,0,0,.3);border:1px solid var(--outline);border-radius:8px;color:var(--text);font-size:14px;transition:all .2s}
  .auth-field input:focus{outline:none;border-color:var(--accent);background:rgba(0,0,0,.5);box-shadow:0 0 8px rgba(239,68,68,.3)}
  .auth-role-select{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
  .auth-role-option{padding:12px;border:2px solid var(--outline);border-radius:8px;text-align:center;cursor:pointer;background:rgba(255,255,255,.03);transition:all .2s;font-size:12px;font-weight:600}
  .auth-role-option.selected{border-color:var(--accent);background:rgba(239,68,68,.1);color:var(--accent)}
  .auth-actions{display:flex;gap:8px;margin-top:16px}
  .auth-btn{flex:1;padding:10px 12px;border:none;border-radius:8px;font-weight:700;cursor:pointer;text-transform:uppercase;font-size:12px;transition:all .2s}
  .auth-btn.primary{background:linear-gradient(135deg, var(--accent) 0%, #f87171 100%);color:#fff}
  .auth-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(239,68,68,.4)}
  .auth-info{font-size:12px;color:var(--muted);margin-top:12px;text-align:center}
  .auth-info strong{color:var(--f1-yellow)}
  
  /* User badge in header */
  .user-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(239,68,68,.1);border:1px solid var(--accent);border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}
  .user-badge:hover{background:rgba(239,68,68,.2);box-shadow:0 2px 8px rgba(239,68,68,.2)}
  .user-badge .role-badge{background:var(--accent);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;text-transform:uppercase}
  .user-badge .role-badge.admin{background:var(--f1-yellow);color:#000}
  .user-menu{position:absolute;top:calc(100% + 8px);right:86px;min-width:220px;padding:8px;background:rgba(8,13,24,.97);border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 18px 42px rgba(0,0,0,.45);display:none;z-index:45}
  .user-menu.is-open{display:block}
  .user-menu button{width:100%;justify-content:flex-start;background:transparent;border:1px solid transparent;color:var(--text);padding:10px 12px;border-radius:10px;font-size:13px;min-height:auto}
  .user-menu button:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08)}
  .profile-modal{position:fixed;inset:0;background:radial-gradient(circle at top, rgba(225,6,0,.14), transparent 30%), rgba(2,6,23,.78);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:12000;padding:24px 18px}
  .profile-modal.is-open{display:flex}
  .profile-dialog{position:relative;width:min(620px,100%);max-height:min(90vh,920px);overflow:auto;background:linear-gradient(180deg, rgba(7,12,23,.98) 0%, rgba(12,19,34,.985) 56%, rgba(17,24,39,.99) 100%);border:1px solid rgba(148,163,184,.16);border-radius:22px;box-shadow:0 30px 80px rgba(0,0,0,.58), 0 0 0 1px rgba(255,255,255,.03) inset;padding:24px}
  .profile-dialog::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;border-radius:22px 22px 0 0;background:linear-gradient(90deg, rgba(225,6,0,.95), rgba(251,191,36,.78))}
  .profile-dialog.wide{width:min(980px,100%)}
  .profile-header{position:sticky;top:-24px;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin:-24px -24px 18px;padding:22px 24px 16px;background:linear-gradient(180deg, rgba(7,12,23,.985) 0%, rgba(7,12,23,.95) 78%, rgba(7,12,23,0) 100%);border-bottom:1px solid rgba(148,163,184,.08)}
  .profile-header h3{margin:0;font-size:26px;letter-spacing:-.03em}
  .profile-header p{max-width:760px}
  .profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .profile-field{display:flex;flex-direction:column;gap:6px}
  .profile-field.full{grid-column:1 / -1}
  .profile-field label{font-size:12px;color:var(--muted);font-weight:700}
  .profile-dialog input[type=text],
  .profile-dialog input[type=password],
  .profile-dialog input[type=email],
  .profile-dialog input[type=tel],
  .profile-dialog input[type=number],
  .profile-dialog input[type=datetime-local],
  .profile-dialog select,
  .profile-dialog textarea{width:100%;background:linear-gradient(180deg, rgba(2,6,23,.64) 0%, rgba(15,23,42,.78) 100%);border:1px solid rgba(148,163,184,.2);border-radius:12px;color:var(--text);padding:12px 14px;font-size:14px;transition:border-color .2s ease, box-shadow .2s ease, background .2s ease}
  .profile-dialog textarea{min-height:120px;resize:vertical}
  .profile-dialog input:focus,
  .profile-dialog select:focus,
  .profile-dialog textarea:focus{outline:none;border-color:rgba(239,68,68,.6);box-shadow:0 0 0 4px rgba(239,68,68,.12);background:linear-gradient(180deg, rgba(2,6,23,.78) 0%, rgba(15,23,42,.9) 100%)}
  .profile-meta{padding:12px 14px;border-radius:12px;background:linear-gradient(135deg, rgba(255,255,255,.045) 0%, rgba(15,23,42,.52) 100%);border:1px solid rgba(148,163,184,.12);font-size:12px;color:var(--muted);line-height:1.6}
  .profile-actions{position:sticky;bottom:-24px;z-index:2;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin:22px -24px -24px;padding:16px 24px 22px;background:linear-gradient(180deg, rgba(7,12,23,0) 0%, rgba(7,12,23,.96) 28%, rgba(7,12,23,.99) 100%);border-top:1px solid rgba(148,163,184,.08)}
  .profile-close{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(255,255,255,.04);border:1px solid rgba(148,163,184,.14);color:var(--muted);font-size:24px;line-height:1;cursor:pointer;padding:0;border-radius:12px;min-height:auto;transition:all .2s ease}
  .profile-close:hover{background:rgba(255,255,255,.08);border-color:rgba(239,68,68,.25);color:var(--text)}
  .profile-status{display:none;margin-bottom:14px;padding:12px 14px;border-radius:10px;font-size:13px}
  .profile-status.is-error{display:block;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.35);color:#fecaca}
  .profile-status.is-success{display:block;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.28);color:#bbf7d0}
  .profile-dialog .btn{min-height:46px}
  #roleToggleBtn{display:none;padding:8px 12px;font-size:11px;white-space:nowrap}

  @media (max-width: 720px){
    .profile-modal{padding:14px 10px}
    .profile-dialog,
    .profile-dialog.wide{width:min(100%,100%);max-height:min(92vh,920px);padding:18px}
    .profile-header{top:-18px;margin:-18px -18px 16px;padding:18px 18px 14px}
    .profile-header h3{font-size:22px}
    .profile-grid{grid-template-columns:1fr}
    .profile-actions{bottom:-18px;margin:18px -18px -18px;padding:14px 18px 18px;justify-content:stretch}
    .profile-actions .btn{width:100%}
  }

  /* Improved tab navigation styling */
  .tabs button{transition:all .3s ease}
  .tabs button:hover:not(.active){background:rgba(255,255,255,.1);border-color:var(--accent);transform:translateY(-3px);box-shadow:0 4px 12px rgba(239,68,68,.15)}
  .tabs button.active{box-shadow:0 4px 16px rgba(239,68,68,.4)}

  /* Players list styling */
  .players{list-style:none;padding:0;margin:0}
  .players li{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;margin-bottom:8px;background:rgba(255,255,255,.03);border:1px solid var(--panel-border);border-radius:10px;transition:all .2s ease}
  .players li:hover{background:rgba(255,255,255,.05);border-color:var(--accent)}
  .players li .name{flex:1;font-weight:600;font-size:15px}
  .players li .btn{padding:6px 12px;font-size:12px;margin:0}

  /* Mobile prediction interface */
  .mobile-pred-row{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.02);padding:8px;border-radius:8px;border:1px solid var(--panel-border)}
  .mobile-pred-select{
    flex:1;
    min-height:44px;
    font-size:16px; /* iOS requires 16px to prevent auto-zoom */
    background:rgba(0,0,0,.65);
    border:2px solid rgba(71,85,105,.8);
    border-left:6px solid rgba(71,85,105,.8);
    color:var(--text);
    border-radius:10px;
    padding:12px 16px;
    font-weight:600;
    cursor:pointer;
    transition:all .2s ease;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
    -webkit-tap-highlight-color: transparent;
    text-align:left
  }
  .mobile-pred-select:hover{
    border-color:var(--f1-yellow);
    box-shadow:0 0 10px rgba(251,191,36,.3)
  }
  .mobile-pred-select:focus{
    border-color:var(--f1-yellow);
    outline:none;
    box-shadow:0 0 12px rgba(251,191,36,.4)
  }
  .mobile-pred-select[data-value]:not([data-value=""]){
    font-weight:700;
    text-shadow:0 1px 3px rgba(0,0,0,.6)
  }
  
  /* Custom dropdown overlay for mobile */
  .mobile-dropdown-overlay{
    display:none;
    position:fixed;
    top:0;left:0;right:0;bottom:0;
    background:rgba(0,0,0,.95);
    z-index:99999;
    padding:20px;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch
  }
  .mobile-dropdown-overlay.active{display:flex;flex-direction:column}
  .mobile-dropdown-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:20px;
    padding-bottom:15px;
    border-bottom:2px solid rgba(251,191,36,.3)
  }
  .mobile-dropdown-title{
    font-size:20px;
    font-weight:700;
    color:var(--f1-yellow)
  }
  .mobile-dropdown-close{
    background:rgba(220,38,38,.8);
    border:none;
    color:#fff;
    width:40px;
    height:40px;
    border-radius:50%;
    font-size:24px;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:700
  }
  .mobile-dropdown-list{
    flex:1;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch
  }
  .mobile-dropdown-item{
    border-radius:10px;
    padding:16px 20px;
    margin-bottom:12px;
    font-size:18px;
    font-weight:700;
    color:#fff;
    text-shadow:0 1px 3px rgba(0,0,0,.5);
    cursor:pointer;
    display:flex;
    align-items:center;
    gap:14px;
    transition:all .2s ease;
    border-left:6px solid #666;
    box-shadow:0 3px 10px rgba(0,0,0,.3);
    position:relative
  }
  .mobile-dropdown-item:active{
    transform:scale(.98);
    box-shadow:0 2px 6px rgba(0,0,0,.4)
  }
  .mobile-dropdown-item.selected{
    box-shadow:0 0 0 3px var(--f1-yellow), 0 4px 12px rgba(251,191,36,.4);
    transform:scale(1.02)
  }
  .mobile-dropdown-item.selected::after{
    content:'✓';
    position:absolute;
    right:20px;
    font-size:24px;
    color:var(--f1-yellow);
    font-weight:900
  }
  .mobile-dropdown-item.is-disabled{
    cursor:not-allowed;
    opacity:.58;
    filter:saturate(.45) brightness(.82)
  }
  .mobile-dropdown-item.is-disabled::before{
    content:'';
    position:absolute;
    inset:0;
    border-radius:10px;
    background:rgba(8,12,26,.42)
  }
  .mobile-dropdown-item.is-disabled::after{
    content:'Al gekozen';
    position:absolute;
    right:16px;
    top:50%;
    transform:translateY(-50%);
    font-size:12px;
    font-weight:800;
    letter-spacing:.04em;
    text-transform:uppercase;
    color:#fff;
    background:rgba(8,12,26,.8);
    padding:5px 8px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.18)
  }
  .mobile-dropdown-item.is-disabled > *{
    position:relative;
    z-index:1
  }
  
  /* Responsive layout for mobile */
  @media (max-width: 900px){
    /* Hide tabs by default on mobile, show with .show-mobile class */
    .tabs {
      display: none;
      position: fixed;
      top: 70px;
      left: 0;
      right: 0;
      background: linear-gradient(180deg, rgba(10,14,39,.98) 0%, rgba(15,25,50,.98) 100%);
      flex-direction: column;
      z-index: 1000;
      border-bottom: 2px solid var(--f1-red);
      box-shadow: 0 4px 12px rgba(0,0,0,0.5);
      max-height: calc(100vh - 70px);
      overflow-y: auto;
      backdrop-filter: blur(10px);
    }
    
    .tabs.show-mobile {
      display: flex !important;
    }
    
    .tabs button {
      width: 100%;
      border-radius: 0;
      border-bottom: 1px solid rgba(255,255,255,0.15);
      text-align: left;
      padding: 16px 20px;
      font-size: 15px;
      font-weight: 600;
      color: #ffffff;
      background: transparent;
      transition: all 0.2s ease;
    }
    
    .tabs button:hover {
      background: rgba(251,191,36,0.15);
      color: var(--f1-yellow);
      padding-left: 28px;
    }
    
    .tabs button.active {
      background: rgba(251,191,36,0.2);
      color: var(--f1-yellow);
      border-left: 4px solid var(--f1-yellow);
      padding-left: 24px;
    }
    
    .tabs button:last-child {
      border-bottom: none;
    }
    
    /* Header optimizations - completely redesigned for mobile */
    header{
      padding:8px 6px;
      height:auto;
      min-height:60px;
      flex-wrap:wrap;
    }
    
    .header-content{
      gap:6px;
      padding:4px 6px !important;
      flex-wrap:wrap;
    }
    
    .car-background{display:none} /* Hide car animation on mobile */
    .traffic-lights{display:none} /* Hide traffic lights on mobile */
    
    /* Logo smaller */
    .logo{flex-shrink:0}
    .logo img{height:28px}
    
    /* Title much smaller and flexible */
    .title{
      flex:1;
      min-width:0;
      overflow:hidden;
    }
    .title h1{
      font-size:14px;
      letter-spacing:0.5px;
      gap:0;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }
    
    /* Hamburger always visible and sized properly */
    .hamburger{
      display:flex !important;
      flex-shrink:0;
    }
    .hamburger span{width:22px;height:2.5px}
    
    /* User badge - compact but available on mobile */
    .user-badge{
      display:inline-flex !important;
      padding:6px 9px;
      font-size:10px;
      min-height:36px;
      max-width:112px;
      overflow:hidden;
      white-space:nowrap;
      text-overflow:ellipsis;
    }
    .user-badge .role-badge{
      display:none;
    }
    .user-menu{
      right:64px;
      min-width:190px;
    }
    .profile-grid{
      grid-template-columns:1fr;
    }
    .profile-dialog{
      padding:18px;
    }
    
    /* Logout button smaller and compact */
    #logoutBtn{
      font-size:9px !important;
      padding:5px 8px !important;
      white-space:nowrap;
      flex-shrink:0;
    }
    
    /* Right side container - make it flexible and compact */
    .header-content > div:last-child{
      gap:6px !important;
      flex-shrink:0;
      display:flex !important;
      align-items:center !important;
    }
    
    /* Tabs - make scrollable horizontally */
    .tabs{overflow-x:auto;overflow-y:hidden;white-space:nowrap;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
    .tabs button{min-width:120px;font-size:12px;padding:10px 12px}
    
    /* Main content */
    main.app{padding:12px 8px}
    .app-footer{margin:24px auto 12px;padding:0 8px 16px}
    .app-footer-inner{padding:14px}
    .app-footer-meta{justify-content:flex-start}
    
    /* Tables - horizontal scroll wrapper */
    table{font-size:13px;min-width:360px}
    .table-wrapper, .scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px;overscroll-behavior-x:contain;width:100%;max-width:100%}
    td,th{padding:8px 6px!important;white-space:nowrap}
    
    /* Buttons - larger touch targets */
    .btn, button{min-height:44px;font-size:14px;padding:12px 16px}
    .auth-btn{min-height:48px;font-size:13px}
    
    /* Prediction layout - hide drag-drop, show mobile dropdowns */
    .predict-layout{display:none!important}
    #mobilePredictInterface{display:block!important}
    #seasonCard{display:none!important} /* Hide desktop season card */
    
    /* Dashboard cards responsive */
    #dashboard .card h4{font-size:13px!important}
    #dashboard .card span{font-size:20px!important}
    #dashboard .card{padding:12px!important}
    
    /* Controls */
    .controls{flex-direction:column;align-items:stretch;gap:10px}
    .controls .group{flex-direction:column;gap:8px}
    .controls select{min-height:44px;font-size:14px;padding:10px}
    
    /* Results forms */
    #raceTop22, #sprintRaceTop8{min-height:0;padding:12px}
    #raceTop22 .pos-row, #sprintRaceTop8 .pos-row{position:relative!important;width:100%!important;left:0!important;top:0!important;margin-bottom:10px;height:auto;min-height:48px}
    #raceTop22 .pos-row select, #sprintRaceTop8 .pos-row select{min-height:44px;font-size:14px}
    #raceTop22 .result-driver-name, #sprintRaceTop8 .result-driver-name{min-height:44px;font-size:14px;display:flex;align-items:center}
    #raceTop22 .pos-row:hover, #sprintRaceTop8 .pos-row:hover{transform:scale(1.01)!important}
    #raceTop22 .pos-row input[type=checkbox], #sprintRaceTop8 .pos-row input[type=checkbox]{transform:scale(1.5)}
    
    /* Quali forms - remove flex for mobile since now using absolute positioning */
    #qualiTop3, #sprintQualiTop3{position:relative!important;min-height:200px!important;padding:12px!important}
    #qualiTop3 .pos-row, #sprintQualiTop3 .pos-row{position:absolute!important;width:200px!important;left:auto!important;top:auto!important;min-height:48px;margin-bottom:0!important}
    #qualiTop3 .pos-row select, #sprintQualiTop3 .pos-row select{max-width:100%;min-height:44px;font-size:14px}
    #qualiTop3 .result-driver-name, #sprintQualiTop3 .result-driver-name{max-width:100%;min-height:44px;font-size:14px;display:flex;align-items:center}
    
    /* Season predictions */
    #seasonPredictions select{min-height:44px;font-size:14px;width:100%}
    
    /* Dashboard cards */
    .dash-grid{grid-template-columns:1fr!important;gap:12px}
    .dash-card{padding:16px}
    
    /* Modals and containers */
    #authModal{padding:16px 12px}
    .auth-container{padding:18px 16px;max-width:100%;max-height:88vh}
    .auth-header{margin-bottom:18px}
    .auth-header h2{font-size:21px}
    .auth-tabs{margin-bottom:14px;padding-bottom:10px}
    .auth-field{margin-bottom:10px}
    .auth-field label{font-size:11px;margin-bottom:4px}
    .auth-field input{padding:10px 12px;font-size:13px}
    .auth-actions{margin-top:14px}
    .auth-btn{padding:10px;font-size:11px}
    .panel{padding:16px}
    
    /* Season prediction dropdowns */
    .season-pred-row{flex-direction:column;gap:12px}
    .season-pred-row select{width:100%}
    
    /* Points system inputs */
    input[type="text"], input[type="number"], select{min-height:44px;font-size:14px}
    
    /* Smaller table columns for mobile dashboard - optimized for narrow screens */
    #scoreTotals, #scoreByGP, #dashRanking{
      min-width:360px !important;
      max-width:100% !important;
      font-size:11px !important;
    }
    #scoreTotals th, #scoreTotals td,
    #scoreByGP th, #scoreByGP td,
    #dashRanking th, #dashRanking td{
      padding:6px 3px !important;
      font-size:10px !important;
    }
    #dnfStats{
      min-width:360px !important;
      max-width:100% !important;
      font-size:11px !important;
    }
    #dnfStats > div{
      padding:6px 8px !important;
      font-size:10px !important;
    }
  }

  /* Extra small screens (iPhone SE, small phones) */
  @media (max-width: 400px){
    header{padding:8px 10px}
    .logo img{height:28px}
    .title h1{font-size:14px}
    .user-badge{
      display:inline-flex !important;
      max-width:92px;
      padding:5px 8px;
      font-size:9px;
    }
    #logoutBtn{font-size:9px !important;padding:5px 8px !important}
    .hamburger span{width:20px;height:2px}
    .app-footer-brand strong{font-size:14px}
    .app-footer-brand span,.app-footer-meta{font-size:11px}
  }
