:root {
  --bg: #f4f7fb;
  --fg: #1e293b;
  --muted: #64748b;
  --primary: #0f62fe;
  --card: #ffffff;
  --border: #dbe4ef;
  --danger: #b42318;
}
* { box-sizing: border-box; }
[hidden] { display: none !important; }
body {
  margin: 0;
  font-family: system-ui, Arial, sans-serif;
  background: var(--bg);
  color: var(--fg);
}
.container { max-width: 1100px; margin: 0 auto; padding: 1rem; }
.topbar { background: #0b1220; color: white; }
.bar-content { display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.brand, .topbar a { color: white; text-decoration:none; margin-right: 1rem; }
.inline { display:inline; }
.link-button {
  background:none; border:none; color:white; cursor:pointer; padding:0; font:inherit;
}
.hero { padding: 1rem 0; }
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
  padding: 1rem;
  margin: 1rem 0;
}
.card.narrow { max-width: 420px; }
.card.small { max-width: 620px; }
.grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:1rem;
}
.stats {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:1rem;
}
.stat .label { color: var(--muted); font-size:.9rem; }
.stat .value { font-size:1.4rem; font-weight:700; margin-top:.35rem; }
label { display:block; font-weight:600; margin:.3rem 0; }
input, select, button, .button {
  width:100%;
  padding:.75rem .9rem;
  border-radius:10px;
  border:1px solid var(--border);
  font:inherit;
}
button, .button {
  background: var(--primary);
  color:white;
  border:none;
  text-align:center;
  text-decoration:none;
  display:inline-block;
  width:auto;
  min-width:150px;
  cursor:pointer;
}
.button.secondary { background:#334155; }
.danger { background: var(--danger); }
.validation { color: var(--danger); margin:.5rem 0; }
.notice {
  background:#ecfdf3; border:1px solid #abefc6; color:#067647;
  padding:.75rem 1rem; border-radius:10px; margin-top:1rem;
}
table { width:100%; border-collapse: collapse; }
th, td { padding:.65rem; border-bottom:1px solid var(--border); text-align:left; vertical-align:top; }
.table-scroll { overflow-x:auto; }
.probability-matrix { min-width:980px; }
.probability-matrix th { white-space:nowrap; }
.probability-matrix input { min-width:82px; padding:.55rem .6rem; }
.kv { display:grid; grid-template-columns: 180px 1fr; gap:.5rem 1rem; }
.actions { display:flex; gap:.75rem; flex-wrap:wrap; margin-top:1rem; }
.ticket-create-actions { align-items:center; }
.ticket-create-actions button { font-weight:800; }
.ticket-create-actions-top { margin:.75rem 0 1rem; }
.ticket-created-card h1 { margin-bottom:.75rem; }
.ticket-created-actions { margin:.25rem 0 1rem; }
.ticket-created-actions form { display:inline-flex; }
.ticket-created-actions button,
.ticket-created-actions .button { min-width:150px; }
.checks { display:flex; gap:1rem; flex-wrap:wrap; margin: 1rem 0; }
.inline-form { display:flex; gap:.75rem; align-items:center; flex-wrap:wrap; }
.inline-form input { width:auto; flex:1; min-width:220px; }
.muted { color:var(--muted); }
.status {
  display:inline-flex;
  align-items:center;
  font-weight:800;
  border-radius:999px;
  padding:.18rem .55rem;
  line-height:1.2;
}
.status-won { color:#067647; background:#ecfdf3; border:1px solid #abefc6; }
.status-lost { color:#b42318; background:#fef3f2; border:1px solid #fecdca; }
.status-open { color:#854d0e; background:#fffbeb; border:1px solid #fde68a; }
.status-cancelled { color:#475467; background:#f2f4f7; border:1px solid #d0d5dd; }
.amount-positive { color:#067647; font-weight:800; }
.amount-negative { color:#b42318; font-weight:800; }
.text-success { color:#067647 !important; font-weight:800; }
.text-danger { color:#b42318 !important; font-weight:800; }
.report-filter-form {
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.filter-header {
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.draw-choice-list {
  display:flex;
  flex-direction:column;
  max-height:360px;
  overflow:auto;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
}
.draw-choice {
  display:grid;
  grid-template-columns:2rem minmax(220px, 1fr) minmax(160px, 42%);
  gap:.65rem;
  align-items:center;
  min-height:48px;
  padding:.55rem .75rem;
  border:0;
  border-bottom:1px solid var(--border);
  border-radius:0;
  background:#fff;
  cursor:pointer;
}
.draw-choice:last-child { border-bottom:0; }
.draw-choice:hover { background:#f8fafc; }
.draw-choice.selected {
  background:#fff8dd;
  box-shadow:inset 4px 0 0 #f5a400;
}
.draw-choice input {
  width:1.1rem;
  height:1.1rem;
  padding:0;
}
.draw-choice-main {
  font-weight:700;
  min-width:0;
}
.draw-choice-number {
  font-size:.95rem;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  min-width:0;
  text-align:right;
}
.report-search-row {
  display:grid;
  grid-template-columns:minmax(220px, 1fr) auto;
  gap:1rem;
  align-items:end;
}
.public-home {
  background:linear-gradient(135deg, #071b46 0%, #10356e 58%, #f4c400 100%);
  color:#fff;
  border-radius:14px;
  padding:1.5rem;
  margin:1rem 0;
}
.public-home h1 { margin:.1rem 0 .35rem; font-size:clamp(2.2rem, 7vw, 4.2rem); line-height:1; }
.public-home p { margin:.35rem 0; font-size:1.15rem; font-weight:650; }
.draw-result-list { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:.8rem; }
.draw-result-card {
  border:1px solid var(--border);
  border-left:6px solid #f4c400;
  border-radius:10px;
  padding:.85rem;
  background:#fbfdff;
}
.draw-result-card strong { display:block; color:#071b46; margin-bottom:.45rem; }
.draw-result-card span { display:block; font-size:1.25rem; font-weight:900; letter-spacing:.04em; }
.verify-result {
  margin-top:1rem;
  border-radius:12px;
  padding:1rem;
  font-size:1.35rem;
  font-weight:900;
}
.verify-won { color:#067647; background:#ecfdf3; border:1px solid #abefc6; }
.verify-lost { color:#b42318; background:#fef3f2; border:1px solid #fecdca; }
@media (max-width:700px) {
  .kv { grid-template-columns: 1fr; }
  .bar-content { flex-direction:column; align-items:flex-start; }
  .container { padding:.6rem; }
  .card { border-radius:10px; margin:.65rem 0; padding:.75rem; }
  h1 { margin:.35rem 0 .65rem; font-size:1.85rem; line-height:1.08; }
  h2 { margin:.8rem 0 .55rem; font-size:1.35rem; line-height:1.15; }
  input, select, button, .button { padding:.85rem .9rem; border-radius:9px; }
  button, .button { width:100%; min-width:0; }
  .actions { gap:.55rem; margin-top:.75rem; }
  .actions > *,
  .actions form,
  .actions button,
  .actions .button { width:100%; }
  .report-search-row { grid-template-columns:1fr; }
  .draw-choice-list { max-height:420px; }
  .draw-choice {
    grid-template-columns:1.8rem 1fr;
    grid-template-areas:
      "check main"
      "check number";
    align-items:start;
  }
  .draw-choice input { grid-area:check; margin-top:.15rem; }
  .draw-choice-main { grid-area:main; }
  .draw-choice-number {
    grid-area:number;
    text-align:left;
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .ticket-created-card .kv { gap:.25rem; font-size:.95rem; }
  .ticket-created-card .kv dt { color:var(--muted); font-size:.82rem; font-weight:700; }
  .ticket-created-card .kv dd { margin:0 0 .35rem; overflow-wrap:anywhere; }
  .ticket-created-card h2 { margin-top:.75rem; }
  .ticket-created-card table th,
  .ticket-created-card table td { padding:.45rem .35rem; }
}

.main-nav { display:flex; align-items:center; gap:.75rem; flex-wrap:wrap; }
.nav-dropdown { position:relative; display:inline-block; }
.nav-group { color:white; cursor:pointer; padding:.25rem .4rem; }
.nav-dropdown-content {
  display:none;
  position:absolute;
  top:100%;
  left:0;
  background:#0b1220;
  min-width:220px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:10px;
  padding:.5rem;
  z-index:1000;
}
.nav-dropdown-content a { display:block; margin:0; padding:.55rem .75rem; white-space:nowrap; }
.nav-dropdown:hover .nav-dropdown-content { display:block; }
.notice-error { background:#fef3f2; border-color:#fecdca; color:#b42318; }
.list { list-style:none; padding-left:0; }
.list li { padding:.45rem 0; border-bottom:1px solid var(--border); }

.ticket-hero {
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, .9fr);
  gap:1.25rem;
  align-items:stretch;
  background:linear-gradient(135deg, #ffffff 0%, #eef5ff 62%, #fff8d7 100%);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.25rem;
  margin:1rem 0;
  overflow:hidden;
}
.ticket-hero-content { display:flex; gap:1rem; align-items:flex-start; }
.ticket-hero h1 { margin:.1rem 0 .25rem; font-size:clamp(2rem, 5vw, 3.5rem); line-height:1; color:#071b46; }
.ticket-tagline { color:#b39a05; font-weight:800; font-size:1.2rem; margin:.2rem 0 1rem; }
.ticket-hero-image { width:100%; height:100%; max-height:360px; object-fit:cover; border-radius:10px; border:1px solid rgba(7,27,70,.12); }
.payment-strip { display:grid; grid-template-columns:repeat(3, 1fr); gap:1rem; margin:1rem 0; }
.payment-item {
  background:#071b46; color:#fff; border-radius:12px; padding:1rem;
  display:block;
  box-shadow:0 8px 18px rgba(7,27,70,.12);
}
.payment-item strong { color:#f4c400; font-size:1.35rem; line-height:1.25; display:block; }
.win-chance-strip { grid-template-columns:repeat(auto-fit, minmax(130px, 1fr)); }
.win-chance-item { padding:.85rem; background:#102a56; }
.win-chance-item strong { font-size:1rem; margin-bottom:.35rem; }
.win-chance-item span { display:block; font-size:1.15rem; font-weight:800; }
.ticket-entry-card { border-top:5px solid #f4c400; }
.ticket-line {
  border:1px solid var(--border); border-radius:12px; padding:1rem; margin:.75rem 0;
  display:grid; grid-template-columns: minmax(160px, 1fr) minmax(130px, .55fr) minmax(130px, .55fr);
  gap:1rem; align-items:end; background:#fbfdff;
}
.ticket-line[data-derived="true"] { background:#f8fafc; }
.highlight { font-size:1.25rem; font-weight:900; color:#071b46; padding:.75rem .9rem; background:#fff8d7; border-radius:10px; border:1px solid #f4c400; }
.rules-panel {
  background:#071b46; color:#fff; border-radius:14px; padding:1.25rem; margin:1rem 0;
  border:1px solid rgba(255,255,255,.08);
}
.rules-panel h2 { margin-top:0; letter-spacing:.04em; }
.rules-list { list-style:none; padding:0; margin:0; display:grid; gap:.75rem; }
.rules-list li { position:relative; padding-left:2rem; font-weight:650; }
.rules-list li::before { content:"✓"; position:absolute; left:0; top:-.05rem; color:#f4c400; font-weight:900; }
@media (max-width:800px) {
  .ticket-hero { grid-template-columns:1fr; padding:.8rem; margin:.65rem 0; border-radius:10px; }
  .ticket-hero h1 { font-size:2.15rem; }
  .ticket-tagline { margin:.1rem 0 .55rem; font-size:1.05rem; }
  .ticket-hero p { margin:.45rem 0; }
  .ticket-hero-image { max-height:180px; }
  .payment-strip { grid-template-columns:1fr; }
  .ticket-line { grid-template-columns:1fr; }
  .win-chance-strip { grid-template-columns:repeat(2, minmax(0, 1fr)); gap:.55rem; }
  .win-chance-item { border-radius:10px; padding:.7rem; }
  .win-chance-item strong { font-size:1.1rem; }
  .win-chance-item span { font-size:1rem; }
  .highlight { font-size:1.4rem; }
  .rules-panel { margin:.65rem 0; padding:.9rem; border-radius:10px; }
}
