:root{
  /* LOVELANCS — LoveRio structure, 4am visual system (purple/cyan/gold) */
  --bg:#050208;
  --panel:#0A0312;
  --panel2:#0D0518;
  --border:#1A0830;
  --accent:#C47AFF;
  --accent2:#8A4DD6;
  --accentDim:rgba(196,122,255,0.08);
  --cyan:#00E5FF;
  --gold:#FFC400;
  --hot:#FF3B7C;
  --text:#E4D8F8;
  --textDim:#5A4470;
  --up:#00FF9C;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{ background:var(--bg); }
body{
  position:relative;
  background:
    radial-gradient(circle at 20% 10%, rgba(196,122,255,0.08), transparent 40%),
    radial-gradient(circle at 80% 40%, rgba(0,229,255,0.06), transparent 45%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  font-family:'IBM Plex Mono', monospace;
  min-height:100vh;
  font-size:13px;
}
body::before{
  content:"";
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:0.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.display{font-family:'Bebas Neue', sans-serif; letter-spacing:1px;}

/* MASTHEAD */
.masthead{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; border-bottom:2px solid var(--accent);
  background:var(--panel);
  box-shadow:0 2px 16px rgba(196,122,255,0.18), 0 1px 0 rgba(196,122,255,0.4);
  position:relative; z-index:2;
}
.logo{display:flex; align-items:center; gap:10px;}
.logo-img{ height:32px; width:auto; max-width:240px; display:block; object-fit:contain; }
.logo-mark{
  width:26px;height:26px; border:1.5px solid var(--accent); transform:rotate(45deg);
  display:flex; align-items:center; justify-content:center;
}
.logo-mark span{transform:rotate(-45deg); color:var(--accent); font-size:12px; font-weight:700;}
.logo-text{font-family:'Bebas Neue',sans-serif; font-size:26px; letter-spacing:2px; color:var(--text);}
.logo-text b{color:var(--accent);}
.masthead-right{display:flex; align-items:center; gap:12px; font-size:10px; color:var(--accent);}
.live-dot{color:var(--up); animation:blink 2s infinite; font-size:11px; text-shadow:0 0 8px rgba(0,255,156,0.6);}
@keyframes blink{50%{opacity:0.3;}}
.masthead-badge{
  border:1px solid var(--cyan); color:var(--cyan); font-size:9px;
  letter-spacing:1.5px; padding:5px 10px; font-weight:700;
}
.masthead-exit{
  border:1px solid var(--hot); color:var(--hot);
  text-shadow:0 0 8px rgba(255,59,124,0.6);
  box-shadow:0 0 10px rgba(255,59,124,0.25);
  font-size:10px; letter-spacing:1px; padding:5px 10px;
  text-decoration:none; font-family:'IBM Plex Mono',monospace; font-weight:700;
}
.masthead-exit:hover{ box-shadow:0 0 16px rgba(255,59,124,0.5); }

/* MODULE COMBAT BANNER — kept, ready to wire to game later */
.mc-banner{
  width:100%; display:block; padding:0;
  background:var(--panel2) url('/lancsgame.png') center/cover no-repeat;
  aspect-ratio:1080/140;
  border-top:2px solid var(--accent);
  border-bottom:2px solid var(--accent);
  cursor:pointer; transition:all 0.2s;
  filter:brightness(1.15);
  box-shadow:0 0 20px rgba(196,122,255,0.3);
  color:transparent; font-size:0;
}
.mc-banner:hover{ box-shadow:0 0 28px rgba(196,122,255,0.45); filter:brightness(1.25); }
.mc-banner.active{ box-shadow:0 0 28px rgba(196,122,255,0.5); filter:brightness(1.3); }

/* AD BANNER */
.ad-banner{
  overflow:hidden; max-height:0; transition:max-height .6s cubic-bezier(.4,0,.2,1);
  background:#000; position:relative;
}
.ad-banner.visible{ max-height:220px; }
.ad-banner-video{
  width:100%; height:220px; object-fit:cover; display:block;
  opacity:0; transition:opacity .4s ease;
}
.ad-banner.visible .ad-banner-video{ opacity:1; }
.ad-banner-tag{
  position:absolute; bottom:4px; right:8px; font-size:8px;
  color:rgba(255,255,255,0.3); letter-spacing:1px;
}

/* DATA TICKER — multi-row */
.ticker-wrap{
  border-top:1px solid rgba(196,122,255,0.3); border-bottom:1px solid rgba(196,122,255,0.3);
  background:linear-gradient(180deg, #08040D 0%, #0A0312 100%);
  box-shadow:inset 0 0 20px rgba(0,0,0,0.4);
  overflow:hidden;
}
.ticker-row{
  display:flex; align-items:center; overflow:hidden; width:100%;
  height:28px; border-bottom:1px solid rgba(196,122,255,0.08);
  white-space:nowrap; flex-wrap:nowrap;
}
.ticker-row:last-child{border-bottom:none;}
.ticker-flag-label{
  flex:0 0 auto; font-size:9px; letter-spacing:1.5px; font-weight:700;
  padding:4px 10px; color:var(--bg); white-space:nowrap; margin-left:12px;
  box-shadow:0 0 8px rgba(0,0,0,0.4);
}
.ticker-flag-label.sport{background:var(--accent2); color:#fff;}
.ticker-flag-label.weather{background:var(--cyan); color:#000;}
.ticker-track{
  display:flex; flex-wrap:nowrap; align-items:center; gap:32px;
  will-change:transform; padding:0 0 0 14px; flex:0 0 auto;
}
.ticker-item{display:flex; flex:0 0 auto; align-items:center; gap:8px; font-size:11px; white-space:nowrap;}
.ticker-item::before{ content:"●"; color:var(--accent); font-size:6px; opacity:0.7; }
.ticker-item .name{color:var(--text); font-weight:700; text-shadow:0 0 6px rgba(196,122,255,0.15);}
.ticker-item .tag{ font-size:9px; padding:2px 6px; letter-spacing:0.5px; border-radius:1px; white-space:nowrap; }
.tag-hot{background:rgba(255,59,124,0.12); color:var(--hot); border:1px solid rgba(255,59,124,0.4);}
.tag-low{background:rgba(255,196,0,0.12); color:var(--gold); border:1px solid rgba(255,196,0,0.4);}
.tag-new{background:rgba(0,229,255,0.1); color:var(--cyan); border:1px solid rgba(0,229,255,0.4);}

/* KPI STRIP */
.kpi-strip{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border);
  border-bottom:1px solid var(--border);
}
.kpi-tile{ background:var(--panel); padding:10px 16px; }
.kpi-label{ font-size:9px; letter-spacing:1.5px; color:var(--textDim); text-transform:uppercase; margin-bottom:4px; }
.kpi-value{ font-size:18px; font-weight:700; color:var(--accent); line-height:1.1; text-shadow:0 0 10px rgba(196,122,255,0.35); }
.kpi-value.green{ color:var(--up); text-shadow:0 0 10px rgba(0,255,156,0.4); }
.kpi-value.red{ color:var(--hot); text-shadow:0 0 10px rgba(255,59,124,0.4); }
.kpi-sub{ font-size:9px; color:var(--textDim); margin-top:3px; letter-spacing:0.5px; }

/* NAV TABS */
.tabs{
  display:flex; border-bottom:1px solid var(--border); background:var(--panel);
  overflow-x:auto;
}
.tab{
  padding:11px 16px; font-size:11px; letter-spacing:1.5px; color:var(--textDim);
  background:transparent; border:none; border-bottom:2px solid transparent;
  cursor:pointer; white-space:nowrap; font-family:'IBM Plex Mono',monospace;
  transition:all .15s; font-weight:700; text-transform:uppercase;
}
.tab.active{color:var(--accent); border-bottom:2px solid var(--accent); background:var(--accentDim);}
.status-bar{
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 16px; border-bottom:1px solid var(--border); background:var(--bg);
  font-size:9px; color:var(--textDim); letter-spacing:0.5px;
}
.status-bar .live-dot{font-size:9px;}

/* LAYOUT */
.layout{display:grid; grid-template-columns:1fr; gap:1px; background:var(--border);}
@media(min-width:900px){ .layout{grid-template-columns:2.2fr 1fr;} }
.col{background:var(--bg);}
.section{border-bottom:1px solid var(--border); padding:14px 16px;}
.section-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:10px; }
.section-title{font-family:'IBM Plex Mono',monospace; font-weight:700; font-size:13px; letter-spacing:1.5px; color:var(--text); text-transform:uppercase;}
.section-title span{color:var(--accent);}
.section-meta{font-size:9px; color:var(--textDim); letter-spacing:1px;}
.feed-item{
  display:flex; gap:10px; padding:11px 0 11px 10px; border-bottom:1px solid var(--border);
  cursor:pointer; border-left:2px solid var(--accent2);
}
.feed-item:last-child{border-bottom:none;}
.feed-item:hover{ border-left-color:var(--accent); background:var(--accentDim); }
.feed-item:hover .feed-title{color:var(--accent);}
.feed-dot{display:none;}
.feed-body{flex:1;}
.feed-title{font-size:12.5px; color:var(--text); line-height:1.4; transition:color .15s; font-weight:500;}
.feed-src{font-size:9px; color:var(--textDim); margin-top:4px; letter-spacing:0.5px;}
.feed-src b{color:var(--cyan); font-weight:700;}

/* SIDEBAR WIDGETS */
.widget{border-bottom:1px solid var(--border); padding:14px 16px; background:var(--panel);}
.widget-title{font-size:9px; letter-spacing:2px; color:var(--textDim); margin-bottom:10px; font-weight:700; text-transform:uppercase;}
.video-frame{
  aspect-ratio:16/9; background:#000; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; color:var(--textDim);
  font-size:10px; letter-spacing:1px; position:relative; overflow:hidden;
}
.play-btn{
  width:40px;height:40px;border-radius:50%; border:1.5px solid var(--accent);
  display:flex; align-items:center; justify-content:center; color:var(--accent);
}
.ad-slot{
  border:1px dashed var(--border); padding:12px; text-align:center;
  color:var(--textDim); font-size:9px; letter-spacing:1px;
}
.top10-row{display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid var(--border); font-size:11px;}
.top10-row:last-child{border-bottom:none;}
.top10-rank{color:var(--accent); font-weight:700; width:18px;}
.top10-name{flex:1; color:var(--text);}
.top10-chg{font-size:9px;}
.up-c{color:var(--up);} .down-c{color:var(--hot);}
.btn-ticket{
  display:inline-block; margin-top:10px; font-size:10px; letter-spacing:1px;
  color:var(--bg); background:var(--accent); padding:8px 14px;
  text-decoration:none; font-weight:700;
}
.footer{padding:12px 16px; font-size:9px; color:var(--textDim); display:flex; justify-content:space-between; border-top:1px solid var(--border); letter-spacing:1px;}

/* DATA-ROW PAGES — events/sport/weather/etc */
.events-page{ padding:0; background:var(--bg) !important; }
.filter-chips{
  display:flex; gap:8px; padding:10px 16px; border-bottom:1px solid var(--border);
  overflow-x:auto; background:var(--panel);
}
.filter-chip{
  border:1px solid var(--border); color:var(--textDim); font-size:10px; letter-spacing:1px;
  padding:6px 12px; white-space:nowrap; cursor:pointer; font-family:'IBM Plex Mono',monospace;
  font-weight:700; background:transparent; text-transform:uppercase;
}
.filter-chip.active{ border-color:var(--accent); color:var(--accent); }
.data-rows{ display:flex; flex-direction:column; }
.data-row{
  display:flex; flex-direction:column; gap:6px; padding:14px 16px 14px 14px;
  border-bottom:1px solid var(--border); border-left:2px solid var(--gold);
  text-decoration:none; color:inherit;
}
.data-row:hover{ background:var(--panel); }
.data-row-top{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.data-row-title{ font-size:14px; font-weight:700; color:var(--text); }
.data-row-value{ font-size:17px; font-weight:700; color:var(--gold); white-space:nowrap; }
.data-row-meta{ font-size:10px; color:var(--cyan); letter-spacing:0.3px; }
.data-row-sub{ font-size:9px; color:var(--textDim); letter-spacing:0.3px; }

/* EVENTS GRID (card view, alternative to data-rows) */
.events-grid{ display:grid; grid-template-columns:1fr; gap:14px; margin-top:14px; padding:16px; }
@media(min-width:640px){ .events-grid{ grid-template-columns:1fr 1fr; } }
.event-card{
  background:var(--panel2); border:1px solid var(--border); border-radius:4px;
  overflow:hidden; text-decoration:none; color:inherit; display:block;
}
.event-card img{ width:100%; height:140px; object-fit:cover; display:block; background:#000; }
.event-card-body{ padding:12px; }
.event-card-title{ font-size:13px; color:var(--text); line-height:1.4; margin-bottom:6px; }
.event-card-meta{ font-size:9px; color:var(--textDim); letter-spacing:0.5px; }

/* GALLERY */
.gallery-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px; background:var(--border); }
@media(min-width:640px){ .gallery-grid{ grid-template-columns:repeat(4,1fr); } }
.gallery-tile{ aspect-ratio:1; overflow:hidden; background:var(--panel); }
.gallery-tile img{ width:100%; height:100%; object-fit:cover; display:block; }

/* INTRO OVERLAY — splash, intro video, login gate (4am timing/behaviour) */
.intro-overlay{
  position:fixed; inset:0; z-index:9999; background:#000;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s ease;
}
.intro-overlay.fading{ opacity:0; pointer-events:none; }
.intro-splash{ width:100%; height:100%; object-fit:contain; background:var(--bg); }
.intro-video{ width:100%; height:100%; object-fit:cover; background:var(--bg); opacity:0; transition:opacity 0.4s ease; }
.intro-video.visible{ opacity:1; }
.intro-login{
  position:absolute; inset:0; background:rgba(0,0,0,0.7);
  display:flex; align-items:center; justify-content:center;
}
.intro-login-box{ text-align:center; }
.intro-login-title{ font-family:'Bebas Neue',sans-serif; font-size:26px; color:var(--text); margin-bottom:16px; }
.intro-google-btn{ font-size:13px; padding:12px 22px; }
.intro-skip{
  position:absolute; bottom:24px; right:24px; z-index:2;
  background:rgba(0,0,0,0.5); color:var(--textDim); border:1px solid var(--border);
  padding:8px 14px; font-size:10px; letter-spacing:1px; cursor:pointer;
  font-family:'IBM Plex Mono',monospace;
}

/* universal panel depth sheen */
.masthead, .kpi-tile, .tabs, .widget, .filter-chips,
.gallery-tile, .ad-banner{
  background-image:linear-gradient(180deg, rgba(255,255,255,0.025) 0%, rgba(0,0,0,0.08) 100%);
  background-blend-mode:overlay;
}

/* ===== FLIGHTS (ported from 4am — shared across all LoveGuide apps) ===== */
.flight-search-box{ padding:16px; }
.flight-field-group{ display:flex; gap:10px; margin-bottom:14px; }
.flight-field{ flex:1; position:relative; }
.flight-label{ display:block; font-size:9px; letter-spacing:1.5px; color:var(--textDim); margin-bottom:4px; }
.flight-input{
  width:100%; box-sizing:border-box;
  background:var(--panel2); border:1px solid var(--border); color:var(--text);
  font-family:'IBM Plex Mono',monospace; font-size:13px; padding:10px 12px;
}
.flight-input:focus{ outline:none; border-color:var(--accent); }
.flight-suggest{
  position:absolute; top:100%; left:0; right:0; z-index:50;
  background:var(--panel2); border:1px solid var(--accent); border-top:none;
  max-height:160px; overflow-y:auto; display:none;
}
.flight-suggest.visible{ display:block; }
.flight-suggest-item{ padding:8px 12px; font-size:12px; color:var(--text); cursor:pointer; border-bottom:1px solid var(--border); }
.flight-suggest-item:hover{ background:var(--accentDim); color:var(--accent); }
.flight-suggest-item small{ display:block; color:var(--textDim); font-size:10px; }
.flight-search-btn{
  width:100%; background:var(--accent); color:var(--bg); border:none;
  font-family:'IBM Plex Mono',monospace; font-weight:700; letter-spacing:1px;
  font-size:13px; padding:14px; cursor:pointer; margin-bottom:18px;
}
.flight-search-btn:hover{ filter:brightness(1.1); }
.flight-results{ display:flex; flex-direction:column; gap:10px; }
.flight-trip-toggle{ display:flex; gap:8px; margin-bottom:14px; }
.trip-toggle-btn{
  flex:1; background:var(--panel2); border:1px solid var(--border);
  color:var(--textDim); font-family:'IBM Plex Mono',monospace; font-size:11px;
  letter-spacing:1px; padding:8px; cursor:pointer;
}
.trip-toggle-btn.active{ background:var(--accentDim); border-color:var(--accent); color:var(--accent); }
.flight-card{
  background:var(--panel2); border:1px solid var(--border); padding:14px;
  border-radius:2px; position:relative; overflow:hidden; margin-bottom:10px;
}
.flight-card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent); }
.flight-card-airline{ font-size:9px; color:var(--cyan); letter-spacing:1px; margin-bottom:6px; }
.flight-card-route{
  font-size:16px; color:var(--text); font-weight:700; margin-bottom:6px;
  display:flex; align-items:center; gap:8px;
}
.flight-card-route .arrow{ color:var(--accent); }
.flight-card-meta{ font-size:11px; color:var(--textDim); margin-bottom:10px; }
.flight-card-price{
  font-size:22px; color:var(--accent); font-weight:700; margin-bottom:10px;
  text-shadow:0 0 12px rgba(196,122,255,0.4);
}
.load-more-btn{
  display:block; width:100%; background:var(--panel2); border:1px solid var(--border);
  color:var(--accent); font-family:'IBM Plex Mono',monospace; font-size:11px;
  letter-spacing:1px; padding:10px; margin-top:10px; cursor:pointer;
}
.load-more-btn:hover{ border-color:var(--accent); background:var(--accentDim); }
