/* =========================================================
   app-theme.css — shared theme for Help / Reports / Desktop
   ---------------------------------------------------------
   - Matches your current Help styling
   - Fixes h2 contrast via --accent-ink
   - Provides common layout + cards + buttons + chips
   ========================================================= */

:root{
  --bg:#0b1220;
  --panel:#0c0f10;
  --ink:#e7f5ed;
  --muted:#9AA4A9;
  --line:#263036;

  /* Accent: use --accent for backgrounds, --accent-ink for headings/text */
  --accent:#0F3224;
  --accent-ink:#14b67d;

  --chip:#1D2428;
  --link:#7dd3fc;
  --note:#112329;

  --radius-lg:14px;
  --radius-md:10px;
  --radius-sm:8px;

  --maxw:1100px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
}

a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

header{
  position:sticky;
  top:0;
  z-index:30;
  background:linear-gradient(180deg, rgba(11,18,32,.96), rgba(11,18,32,.85) 80%, rgba(11,18,32,0));
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(6px);
}

.nav{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 20px;
  max-width:var(--maxw);
  margin:0 auto;
}

.brand{
  font-weight:700;
  color:#d9fff1;
  font-size:18px;
  display:flex;
  align-items:center;
  gap:8px;
}
.brand img{height:24px;width:auto}

.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--chip);
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  color:var(--ink);
}

.lang{
  margin-left:auto;
  display:flex;
  gap:8px;
}
.lang button{
  background:#122126;
  border:1px solid var(--line);
  color:var(--ink);
  padding:6px 10px;
  border-radius:var(--radius-sm);
  cursor:pointer;
}
.lang button.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:24px;
}

.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:18px;
}

h1{
  margin:0 0 8px 0;
  font-size:28px;
  color:#d9fff1;
}

h2{
  margin:18px 0 10px 0;
  font-size:20px;
  color:var(--accent-ink);
  font-weight:600;
}

/* Optional small accent bar for section titles */
.h2-bar h2::before{
  content:"";
  display:inline-block;
  width:4px;
  height:18px;
  background:var(--accent-ink);
  margin-right:8px;
  border-radius:2px;
  vertical-align:middle;
}

p{line-height:1.7}
ul{margin:8px 0 0 18px}
li{margin:6px 0}

.small{font-size:12px}
.muted{color:var(--muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}

.note{
  background:var(--note);
  border:1px solid #1d3440;
  border-radius:var(--radius-md);
  padding:10px 12px;
  color:#b9d4e0;
}

.grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
@media (max-width:900px){
  .grid{grid-template-columns:1fr}
}

.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  background:#122126;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  display:inline-block;
}

.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:var(--accent-ink);
  color:#052016;
  border-radius:var(--radius-md);
  padding:10px 14px;
  font-weight:700;
  border:1px solid rgba(0,0,0,0);
  cursor:pointer;
}

.btn.secondary{
  background:#122126;
  color:var(--ink);
  border:1px solid var(--line);
}

.btn.ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--line);
}

.footer{
  margin:24px 0 14px;
  color:var(--muted);
  font-size:13px;
  text-align:center;
}

/* Form elements */
label{
  font-size:12px;
  color:var(--muted);
  display:block;
  margin-top:10px;
}
input, textarea, select{
  width:100%;
  padding:10px;
  margin-top:6px;
  background:#1a1f22;
  color:var(--ink);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  outline:none;
}
textarea{resize:vertical}

/* =========================================================
   Sound Tuner shared theme layer
   ---------------------------------------------------------
   - Shared layout/classes for GeoDetectit Sound Tuner
   - Keeps page-specific sizing/backgrounds in soundtuner page
   ========================================================= */
.st-wrap{
  max-width:1380px;
  margin:0 auto;
  padding:24px;
}
.st-hero{ margin-bottom:16px; }
.st-title-row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.st-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(20,182,125,.14);
  color:#9af1d1;
  border:1px solid rgba(20,182,125,.25);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
}
.st-top-actions{
  margin-left:auto;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.st-grid-main{
  display:grid;
  grid-template-columns:1.2fr .95fr;
  gap:16px;
}
.st-controls-grid,
.st-tuning-grid{
  display:grid;
  gap:14px;
  align-items:end;
}
.st-controls-grid{ grid-template-columns:repeat(4,minmax(180px,1fr)); }
.st-tuning-grid{ grid-template-columns:repeat(4,minmax(170px,1fr)); }
.st-btn-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.st-btn-row > *{ flex:0 0 auto; }
.st-section-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}
.st-status-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(120px,1fr));
  gap:10px;
  margin-top:12px;
}
.st-stat{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
}
.st-stat-k{
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.st-stat-v{
  font-size:22px;
  margin-top:4px;
  font-variant-numeric:tabular-nums;
}
.st-legend{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  margin-top:8px;
}
.st-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  display:inline-block;
  margin-right:6px;
}
.st-event-list{
  max-height:560px;
  overflow:auto;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,.03);
}
.st-event-row{
  display:grid;
  grid-template-columns:64px 1fr 82px 82px 88px 92px;
  gap:8px;
  align-items:center;
  padding:9px 10px;
  border-bottom:1px solid rgba(255,255,255,.04);
  font-size:13px;
}
.st-event-row:last-child{ border-bottom:0; }
.st-event-row.header{
  position:sticky;
  top:0;
  z-index:1;
  background:rgba(12,15,16,.98);
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:11px;
}
.st-badge-soft{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  font-size:11px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.st-slots-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.st-slot-card{
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:12px;
  border:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:250px;
  max-width:320px;
  position:relative;
}
.st-slot-header{
  display:flex;
  gap:8px;
  align-items:center;
}
.st-slot-id{
  font-weight:700;
  font-size:12px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(20,182,125,.14);
  color:#9af1d1;
  white-space:nowrap;
}
.st-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.st-slots-toolbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
}
.st-section-note{ margin-top:8px; }
.st-footer-note{ margin-top:10px; }

@media (max-width:1100px){
  .st-grid-main{ grid-template-columns:1fr; }
  .st-controls-grid,
  .st-tuning-grid{ grid-template-columns:repeat(2,minmax(160px,1fr)); }
}
@media (max-width:720px){
  .st-wrap{ padding:14px; }
  .st-controls-grid,
  .st-tuning-grid,
  .st-status-grid{ grid-template-columns:1fr; }
  .st-event-row{
    grid-template-columns:52px 1fr 66px 66px 74px 78px;
    font-size:12px;
  }
  .st-top-actions{
    margin-left:0;
    width:100%;
  }
}
