/* ===== Theme ===== */
:root{
  --bg:#0b0d10;
  --card:#12151a;
  --fg:#e8eef6;
  --muted:#aeb6c2;
  --pri:#6ae3ff;
  --line:#273043;
}

/* ===== Base ===== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--fg);
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:var(--pri);text-decoration:none}
a:hover{text-decoration:underline}
a:focus-visible, button:focus-visible, select:focus-visible, input:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:2px;
}

.wrap{max-width:1100px;margin:0 auto;padding:16px}

/* ===== Header / Nav ===== */
header{
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--line);
}
.logo{display:inline-flex;align-items:center}
.logo img{display:block;height:auto;/* width/height set in HTML attrs */}
.logo span{color:var(--pri)} /* in case old text-logo shows anywhere */

nav{display:flex;flex-wrap:wrap;gap:8px}
nav a{color:var(--muted);padding:8px 6px;border-radius:8px}
nav a.active{color:var(--fg);text-decoration:underline}

/* ===== Type ===== */
h1{font-size:28px;margin:24px 0 8px}
h2{font-size:20px;margin:18px 0 8px}
.intro{color:var(--muted);margin-bottom:16px}

/* ===== Cards / Layout ===== */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  margin:12px 0;
}
.controls .row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
label{display:flex;flex-direction:column;font-size:14px;color:var(--muted)}

/* ===== Form Elements ===== */
select,input{
  background:#0e1217;border:1px solid var(--line);color:var(--fg);
  padding:10px 12px;border-radius:10px;min-width:150px
}
select:focus,input:focus{border-color:var(--pri)}
@media (max-width:600px){select,input{min-width:120px}}

button{
  background:var(--pri);color:#001018;border:0;
  padding:10px 16px;border-radius:10px;font-weight:700;cursor:pointer
}
button:hover{filter:brightness(1.05)}
button.ghost{background:transparent;border:1px solid var(--line);color:var(--fg)}
button.ghost:hover{border-color:var(--pri)}

/* ===== Status / Ads ===== */
#status{color:var(--muted);margin-left:8px}
.ad-slot{min-height:90px;margin:12px 0;border:1px dashed var(--line);border-radius:12px}

/* ===== Results Grid ===== */
.results{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:10px;margin:16px 0
}
.name{
  display:flex;justify-content:space-between;align-items:center;
  background:#0e1217;border:1px solid var(--line);border-radius:12px;padding:10px
}
.name .actions button{margin-left:6px;padding:6px 10px;border-radius:8px}

/* ===== Tips / Footer ===== */
.tips .cta{font-weight:700}
.foot{border-top:1px solid var(--line);color:var(--muted)}

/* ===== Utilities ===== */
.visually-hidden{
  position:absolute!important;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;overflow:hidden;white-space:nowrap
}

/* --- Seasonal link grid --- */
.link-grid{
  list-style:none;
  padding:0;
  margin:8px 0 0;
  display:grid;
  gap:10px;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.link-grid li{margin:0}
.link-grid a{
  display:block;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#0e1217;
  color:var(--fg);
  text-decoration:none;
  line-height:1.2;
}
.link-grid a:hover{border-color:var(--pri)}
.link-grid a:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:2px;
}

/* (optional) compact on very small screens */
@media (max-width:480px){
  .link-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
}
.logo{line-height:0}
.logo img{display:block;height:28px;width:auto}
