/*
Theme Name: Book Cheap Flight Pro
Theme URI: https://bookcheapflight.co
Author: Assuage Tech Group
Author URI: https://assuagetech.net
Description: Production-ready affiliate travel theme with wired server-side endpoints (Travelpayouts Flights Search flow + Hotellook cache + Ticketmaster Discovery), dark mode, deals UI, opt-in hooks, and Travel Blog.
Version: 1.3.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bookcheapflight
Tags: travel, affiliate, dark-mode, responsive, custom-menu, blog
Requires at least: 6.0
Requires PHP: 7.4
*/

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
img{max-width:100%;height:auto;}
a{text-decoration:none;}

:root{
  --bg:#0f1115;
  --card:#151924;
  --text:#f2f4f8;
  --muted:#a7b0c0;
  --accent:#ff6a00;
  --border:rgba(255,255,255,.09);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}
[data-bcf-theme="light"]{
  --bg:#f7f8fb;
  --card:#ffffff;
  --text:#101828;
  --muted:#475467;
  --border:rgba(16,24,40,.12);
  --shadow: 0 10px 30px rgba(16,24,40,.10);
}

body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
.container{
  width:min(1160px, calc(100% - 32px));
  margin:0 auto;
}
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex; align-items:center; gap:16px; padding:14px 0;}
.brand{display:flex; align-items:center; gap:10px; min-width:180px;}
.brand-logo{width:42px; height:42px; border-radius:999px; border:1px solid var(--border); overflow:hidden; background:var(--card);}
.brand-title{font-weight:800; letter-spacing:-.02em; font-size:16px;}
.brand-sub{font-size:12px; color:var(--muted);}

.nav{flex:1; display:flex; align-items:center; justify-content:space-between; gap:12px;}
.menu{display:flex; align-items:center; gap:10px; list-style:none; padding:0; margin:0; flex-wrap:wrap;}
.menu a{color:var(--text); padding:8px 10px; border-radius:999px; border:1px solid transparent;}
.menu a:hover{border-color:var(--border); background:color-mix(in srgb, var(--card) 70%, transparent);}

.header-actions{display:flex; align-items:center; gap:10px;}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px; border-radius:14px;
  background:var(--card);
  border:1px solid var(--border);
  color:var(--text);
  box-shadow: var(--shadow);
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px);}
.btn-accent{background: color-mix(in srgb, var(--accent) 18%, var(--card)); border-color: color-mix(in srgb, var(--accent) 45%, var(--border));}
.btn-ghost{box-shadow:none; background:transparent;}

.banner{
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 22%, transparent), transparent);
  border-bottom:1px solid var(--border);
}
.banner-inner{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 0;}
.banner a{color:var(--text);}
.banner small{color:var(--muted);}

.hero{padding:26px 0 10px;}
.hero-grid{display:grid; grid-template-columns: 1.15fr .85fr; gap:16px;}
.card{background:var(--card); border:1px solid var(--border); border-radius:20px; box-shadow:var(--shadow);}
.card-pad{padding:18px;}
.h1{font-size:34px; line-height:1.1; letter-spacing:-.03em; margin:0 0 10px;}
.p{color:var(--muted); margin:0 0 14px;}
.kpis{display:flex; gap:10px; flex-wrap:wrap; margin-top:8px;}
.kpi{padding:8px 10px; border-radius:14px; border:1px solid var(--border); color:var(--muted); font-size:13px;}

.tabs{display:flex; gap:8px; flex-wrap:wrap; margin:12px 0 12px;}
.tab{padding:8px 10px; border-radius:999px; border:1px solid var(--border); background:transparent; color:var(--text); cursor:pointer; font-weight:700; font-size:13px;}
.tab[aria-selected="true"]{background:color-mix(in srgb, var(--accent) 18%, transparent); border-color: color-mix(in srgb, var(--accent) 45%, var(--border));}

.form-grid{display:grid; grid-template-columns: repeat(6, 1fr); gap:10px;}
.field{grid-column: span 2; display:flex; flex-direction:column; gap:6px;}
.field label{font-size:12px; color:var(--muted);}
.field input,.field select{
  padding:11px 12px; border-radius:14px; border:1px solid var(--border);
  background: color-mix(in srgb, var(--card) 85%, transparent);
  color:var(--text);
}
.field-wide{grid-column: span 3;}
.field-full{grid-column: 1 / -1;}

.results{margin:16px 0 26px;}
.result-item{display:flex; justify-content:space-between; gap:14px; padding:14px; border-top:1px solid var(--border);}
.result-item:first-child{border-top:none;}
.result-title{font-weight:800;}
.result-meta{color:var(--muted); font-size:13px;}
.result-price{font-weight:900; font-size:16px; white-space:nowrap;}

.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px;}
.post-card{padding:14px;}
.post-card h3{margin:0 0 6px; font-size:16px;}
.post-card .meta{color:var(--muted); font-size:13px; margin-bottom:10px;}
.post-card p{margin:0; color:var(--muted); font-size:14px;}

.site-footer{border-top:1px solid var(--border); padding:22px 0; color:var(--muted);}
.site-footer a{color:var(--text);}

.notice{padding:12px 14px; border-radius:16px; border:1px dashed color-mix(in srgb, var(--accent) 55%, var(--border)); background: color-mix(in srgb, var(--accent) 10%, transparent); color:var(--text);}

@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr; }
  .form-grid{grid-template-columns: repeat(2, 1fr);}
  .field,.field-wide{grid-column: span 1;}
  .field-full{grid-column: 1 / -1;}
  .brand{min-width:unset;}
  .grid-3{grid-template-columns: 1fr;}
}
