/* ══════════════════════════════════════════
   MAXIS MATCH MARKETPLACE — styles.css
   ══════════════════════════════════════════ */
:root {
  --charcoal: #4A4A4A; --mid-gray: #6E6E6E; --green: #66BB46; --lime: #A6E329;
  --off-white: #F9F9F9; --white: #ffffff;
  --shadow: 0 4px 24px rgba(74,74,74,0.10);
  --shadow-hover: 0 8px 36px rgba(102,187,70,0.18);
  --radius: 10px; --transition: 0.22s cubic-bezier(.4,0,.2,1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Lora', serif; background: var(--off-white); color: var(--charcoal); min-height: 100vh; }

/* ── NAV ── */
header { background: var(--white); border-bottom: 2px solid var(--lime); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(74,74,74,0.07); }
.nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 68px; gap: 16px; }
.logo { display: flex; flex-direction: column; line-height: 1.1; flex-shrink: 0; cursor: pointer; }
.logo-name { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 1.18rem; color: var(--charcoal); letter-spacing: -0.5px; }
.logo-tagline { font-family: 'Lora', serif; font-style: italic; font-size: 0.7rem; color: var(--green); }
nav { display: flex; align-items: center; gap: 6px; flex: 1; justify-content: center; flex-wrap: wrap; }
nav a { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 0.82rem; color: var(--charcoal); text-decoration: none; padding: 7px 13px; border-radius: 6px; transition: background var(--transition); cursor: pointer; }
nav a:hover, nav a.active { background: var(--lime); }
.search-wrap { display: flex; align-items: center; background: var(--off-white); border: 1.5px solid #e0e0e0; border-radius: 24px; padding: 5px 14px; gap: 7px; flex-shrink: 0; transition: border-color var(--transition); }
.search-wrap:focus-within { border-color: var(--green); }
.search-wrap input { border: none; background: transparent; font-family: 'Lora', serif; font-size: 0.85rem; color: var(--charcoal); outline: none; width: 160px; }
.search-wrap input::placeholder { color: var(--mid-gray); }

/* ── HERO ── */
.hero { position: relative; overflow: hidden; height: 440px; }
.slides { display: flex; width: 100%; height: 100%; transition: transform 0.7s cubic-bezier(.77,0,.18,1); }
.slide { min-width: 100%; height: 100%; position: relative; display: flex; align-items: center; justify-content: center; }
.slide-bg { position: absolute; inset: 0; }
.s1 .slide-bg { background: linear-gradient(135deg, #1e3d08 0%, #66BB46 50%, #A6E329 100%); }
.s2 .slide-bg { background: linear-gradient(135deg, #2a2a2a 0%, #5a5a5a 55%, #A6E329 100%); }
.s3 .slide-bg { background: linear-gradient(135deg, #0f2200 0%, #4a9030 50%, #c8f060 100%); }
.slide::after { content:''; position:absolute; inset:0; background:rgba(15,15,15,0.42); }
.slide-content { position:relative; z-index:2; text-align:center; padding:0 40px; max-width:760px; }
.slide-eyebrow { font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.7rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--lime); margin-bottom:14px; }
.slide-title { font-family:'Montserrat',sans-serif; font-weight:800; font-size:clamp(1.5rem,3.8vw,2.7rem); color:#fff; line-height:1.15; margin-bottom:16px; }
.slide-body { font-family:'Lora',serif; font-size:0.97rem; color:rgba(255,255,255,0.9); line-height:1.75; max-width:560px; margin:0 auto 22px; }
.slide-cta { display:inline-block; background:var(--lime); color:var(--charcoal); font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.82rem; letter-spacing:1.2px; text-transform:uppercase; padding:12px 26px; border-radius:6px; border:none; cursor:pointer; transition:background var(--transition),transform var(--transition); }
.slide-cta:hover { background:var(--green); color:#fff; transform:translateY(-2px); }
.hero-dots { position:absolute; bottom:18px; left:50%; transform:translateX(-50%); display:flex; gap:8px; z-index:5; }
.dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.4); cursor:pointer; transition:background var(--transition),transform var(--transition); border:none; padding:0; }
.dot.active { background:var(--lime); transform:scale(1.3); }
.hero-arrow { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,0.14); border:none; color:white; font-size:1.3rem; width:44px; height:44px; border-radius:50%; cursor:pointer; z-index:5; display:flex; align-items:center; justify-content:center; transition:background var(--transition); backdrop-filter:blur(4px); }
.hero-arrow:hover { background:rgba(102,187,70,0.5); }
.prev { left:18px; } .next { right:18px; }

/* ── LAYOUT ── */
main { max-width:1200px; margin:0 auto; padding:48px 24px 72px; }
.page-header { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:32px; border-bottom:2px solid var(--lime); padding-bottom:14px; }
.page-title { font-family:'Montserrat',sans-serif; font-weight:800; font-size:1.7rem; color:var(--charcoal); }
.item-count { font-family:'Lora',serif; font-style:italic; color:var(--mid-gray); font-size:0.88rem; }

/* ── LOADING ── */
.loading-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:80px 24px; gap:18px; grid-column:1/-1; }
.spinner { width:44px; height:44px; border:3px solid #e0e0e0; border-top-color:var(--green); border-radius:50%; animation:spin 0.8s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.loading-text { font-family:'Lora',serif; font-style:italic; color:var(--mid-gray); font-size:0.9rem; }

/* ── GRID & CARDS ── */
.cc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:24px; }
.cc-card { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); cursor:pointer; overflow:hidden; transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition); border:1.5px solid transparent; }
.cc-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-hover); border-color:var(--lime); }
.cc-thumb-wrap { width:100%; aspect-ratio:3/4; overflow:hidden; background:#dff0c8; }
.cc-thumb { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.4s ease; }
.cc-card:hover .cc-thumb { transform:scale(1.05); }
.cc-thumb-fallback { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; font-size:3rem; gap:8px; background:linear-gradient(135deg,#e8f5d8,#c8e890); }
.cc-thumb-fallback span { font-family:'Lora',serif; font-style:italic; font-size:0.68rem; color:var(--mid-gray); }
.cc-label { padding:12px 14px 14px; }
.cc-item-name { font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.83rem; color:var(--charcoal); line-height:1.3; margin-bottom:3px; }
.cc-creator-name { font-family:'Lora',serif; font-style:italic; font-size:0.75rem; color:var(--mid-gray); }

/* ── LIGHTBOX ── */
.lightbox-overlay { position:fixed; inset:0; background:rgba(40,40,40,0.75); z-index:1000; display:flex; align-items:center; justify-content:center; padding:24px; backdrop-filter:blur(5px); opacity:0; pointer-events:none; transition:opacity 0.25s; }
.lightbox-overlay.open { opacity:1; pointer-events:all; }
.lightbox-card { background:var(--white); border-radius:14px; max-width:760px; width:100%; display:flex; overflow:hidden; box-shadow:0 28px 90px rgba(0,0,0,0.3); transform:scale(0.93) translateY(18px); transition:transform 0.28s cubic-bezier(.4,0,.2,1); max-height:92vh; }
.lightbox-overlay.open .lightbox-card { transform:scale(1) translateY(0); }
.lightbox-img-wrap { width:42%; flex-shrink:0; background:#dff0c8; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.lightbox-img { width:100%; height:100%; object-fit:cover; display:block; }
.lb-img-fallback { font-size:5rem; display:flex; align-items:center; justify-content:center; width:100%; min-height:340px; }
.lightbox-info { flex:1; padding:30px 26px; display:flex; flex-direction:column; gap:13px; overflow-y:auto; }
.lightbox-close { align-self:flex-end; background:var(--off-white); border:none; width:32px; height:32px; border-radius:50%; font-size:1rem; cursor:pointer; color:var(--charcoal); display:flex; align-items:center; justify-content:center; transition:background var(--transition); flex-shrink:0; }
.lightbox-close:hover { background:#ffd6d6; }
.cat-badge { display:inline-block; background:var(--lime); color:var(--charcoal); font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.63rem; letter-spacing:1.5px; text-transform:uppercase; padding:3px 10px; border-radius:20px; width:fit-content; }
.lb-name { font-family:'Montserrat',sans-serif; font-weight:800; font-size:1.22rem; color:var(--charcoal); line-height:1.25; }
.lb-creator { font-family:'Lora',serif; font-size:0.88rem; color:var(--mid-gray); }
.lb-creator a { color:var(--green); text-decoration:none; font-weight:600; }
.lb-creator a:hover { text-decoration:underline; }
.lb-desc { font-family:'Lora',serif; font-size:0.91rem; color:var(--charcoal); line-height:1.72; flex:1; }
.divider { height:1px; background:#ededed; }
.tag-list { display:flex; flex-wrap:wrap; gap:5px; }
.tag { font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.6rem; letter-spacing:0.8px; text-transform:uppercase; background:#eef8db; color:#3d6e1a; padding:2px 8px; border-radius:20px; }
.patreon-btn { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--green); color:#fff; font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.86rem; letter-spacing:0.5px; padding:13px 20px; border-radius:8px; text-decoration:none; transition:background var(--transition),transform var(--transition); }
.patreon-btn:hover { background:#55a038; transform:translateY(-2px); }

/* ── STATUS ── */
.status-box { text-align:center; padding:60px 24px; color:var(--mid-gray); grid-column:1/-1; }
.status-box .icon { font-size:3rem; margin-bottom:12px; }
.status-box h3 { font-family:'Montserrat',sans-serif; font-weight:700; font-size:1.1rem; color:var(--charcoal); margin-bottom:6px; }
.status-box p { font-size:0.88rem; line-height:1.6; }
.retry-btn { margin-top:16px; display:inline-block; background:var(--green); color:#fff; font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.8rem; padding:10px 22px; border-radius:6px; border:none; cursor:pointer; }

/* ── PAGES ── */
.page { display:none; } .page.active { display:block; }

/* ── FOOTER ── */
footer { background:var(--charcoal); color:rgba(255,255,255,0.62); text-align:center; padding:28px 24px; font-family:'Lora',serif; font-size:0.82rem; line-height:1.75; }
footer strong { color:var(--lime); }

/* ── RESPONSIVE ── */
@media (max-width:700px) {
  .nav-inner { flex-wrap:wrap; height:auto; padding:12px 16px; gap:10px; }
  nav a { font-size:0.75rem; padding:6px 9px; }
  .search-wrap input { width:100px; }
  .hero { height:320px; }
  .lightbox-card { flex-direction:column; max-height:96vh; }
  .lightbox-img-wrap { width:100%; max-height:230px; }
  .lightbox-info { padding:18px 16px; }
  .cc-grid { grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:14px; }
}
