/* ===== Global ===== */
:root{
  --bg:#f7f8fb;
  --card-bg:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --border:#e2e8f0;
  --shadow:0 8px 24px rgba(2,6,23,.08);
  --accent:#0ea5e9;
  --accent-2:#06b6d4;
  --success:#22c55e;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg);color:var(--text)}

.container{max-width:1120px;margin:0 auto;padding:20px}
.header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.header .nav{display:flex;justify-content:space-between;align-items:center}
.logo{display:flex;gap:10px;align-items:center;font-weight:700}
.logo img{width:24px;height:24px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;color:#0f172a;text-decoration:none;font-weight:600;box-shadow:var(--shadow)}
.btn:hover{transform:translateY(-1px)}
.btn-cta{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#fff;border:none}
.btn-outline{background:#fff;border:1px solid var(--border);color:#0f172a}

/* ===== Hero ===== */
.hero{background:#ffffff}
.hero .badge{display:inline-block;background:#ecfeff;border:1px solid #a5f3fc;color:#0e7490;padding:6px 10px;border-radius:999px;font-weight:600;margin-bottom:10px}
.searchbar{display:flex;gap:10px;margin-top:14px}
.searchbar input{flex:1;padding:12px 14px;border-radius:12px;border:1px solid var(--border)}

/* ===== Grid & Cards ===== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.thumb{position:relative;height:220px;background:#0b1220;display:flex;align-items:center;justify-content:center}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* Dim the image to improve text contrast and fight watermarks */
.thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,.4) 100%);pointer-events:none}

.card-body{padding:14px 14px 16px 14px;display:flex;flex-direction:column;gap:10px}
.card-meta{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:13px}
.pill{display:inline-block;background:#eafff3;color:#067647;border:1px solid #bbf7d0;padding:4px 8px;border-radius:999px;font-weight:700;font-size:11px}
.category{background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe;border-radius:999px;padding:2px 8px;font-weight:600;font-size:11px}

.title{font-size:18px;line-height:1.35;font-weight:750;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.desc{color:var(--muted);font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:42px}

.meta-line{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#0f172a;background:#f8fafc;border:1px dashed var(--border);padding:8px 10px;border-radius:10px}
.price{font-weight:800}
.refund{color:#0f766e}

/* ===== Table / Sections ===== */
.section{padding:24px 0}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}
.table th,.table td{padding:10px 12px;background:#fff;border:1px solid var(--border)}
.table th{background:#f1f5f9}

/* ===== Notices & Consent ===== */
.notice{background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;padding:10px 12px;border-radius:12px}
.consent{position:fixed;left:20px;bottom:20px;display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--border);padding:10px 12px;border-radius:12px;box-shadow:var(--shadow)}

/* ===== Responsive tweaks ===== */
@media (max-width: 640px){
  .grid{grid-template-columns:1fr}
  .thumb{height:200px}
}
