/* ===== SlimMetHond - frontend stijl ===== */
/* ===== Structuur (kleuronafhankelijk) ===== */
:root{
  --radius:16px; --shadow:0 10px 30px rgba(30,22,15,.10); --shadow-sm:0 4px 14px rgba(30,22,15,.07);
  --maxw:1140px; --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

/* =====================================================================
   KLEURTHEMA'S - 4 opties. Wissel live via Admin > Instellingen,
   of pas hieronder de standaard aan (het :root-blok = standaardthema).
   ===================================================================== */

/* 1) CHOCOLADE & KARAMEL (labrador) - standaard */
:root,
[data-theme="chocolade"]{
  --brand:#9B5E2B; --brand-dark:#7C4A22; --brand-soft:#F1E4D2;
  --ink:#2A2018; --muted:#7d6e60; --line:#ece2d6;
  --cream:#FBF6EF; --green:#5E8C53; --green-soft:#E4EFDD;
}

/* 2) GOUDBLOND & ZAND (golden retriever) */
[data-theme="goud"]{
  --brand:#C68A2E; --brand-dark:#A06E1F; --brand-soft:#F6E8CF;
  --ink:#33291B; --muted:#7f7261; --line:#efe6d6;
  --cream:#FBF7EF; --green:#6E9153; --green-soft:#E8F0DC;
}

/* 3) BOSGROEN AVONTUUR (warme karamel als accent) */
[data-theme="groen"]{
  --brand:#4F8A5B; --brand-dark:#3C6E47; --brand-soft:#DDEFE0;
  --ink:#233028; --muted:#5f7065; --line:#e1eadf;
  --cream:#F4F8F2; --green:#B5762F; --green-soft:#F0E3CF;
}

/* 4) SLATEGRIJS-BLAUW (warme zandaccent) */
[data-theme="blauw"]{
  --brand:#3E6E86; --brand-dark:#2F586B; --brand-soft:#DCEAF0;
  --ink:#1F2A30; --muted:#647179; --line:#e3e9ed;
  --cream:#F5F8FA; --green:#C28A3E; --green-soft:#F3E6CF;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{line-height:1.2;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-999px}.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:99}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;font-weight:700;font-size:.95rem;
  padding:.7em 1.3em;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:.15s;font-family:inherit;white-space:nowrap}
.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark);transform:translateY(-1px)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-danger{background:#fff;border-color:#f3d0d0;color:#d23f3f}.btn-danger:hover{background:#d23f3f;color:#fff}
.btn-sm{padding:.4em .85em;font-size:.82rem}.btn-block{width:100%}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:.5em;font-size:1.3rem;font-weight:800;letter-spacing:-.03em}
.logo-mark{display:inline-flex;align-items:center}.logo-text strong{color:var(--brand)}
.paw{fill:var(--brand)}
.logo-footer .paw{fill:color-mix(in srgb, var(--brand) 55%, #fff)}
.main-nav{display:flex;align-items:center;gap:1.5rem}
.main-nav a{font-weight:600;color:var(--ink);font-size:.97rem}
.main-nav a:hover{color:var(--brand)}
.nav-cta{background:var(--brand-soft);color:var(--brand-dark)!important;padding:.5em 1.1em;border-radius:999px}
.nav-cta:hover{background:var(--brand);color:#fff!important}
.nav-dropdown{position:relative}
.nav-drop-menu{position:absolute;top:130%;left:0;background:#fff;box-shadow:var(--shadow);border-radius:12px;padding:.5rem;min-width:220px;display:none;flex-direction:column;gap:.1rem}
.nav-dropdown:hover .nav-drop-menu{display:flex}
.nav-drop-menu a{padding:.55rem .7rem;border-radius:8px;font-size:.92rem}
.nav-drop-menu a:hover{background:var(--cream)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* HERO */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--cream) 0%,var(--brand-soft) 100%);padding:64px 0 76px}
.hero-blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:0}
.hero-blob-1{width:340px;height:340px;background:radial-gradient(circle,var(--brand-soft),transparent 70%);opacity:.9;top:-80px;right:-60px}
.hero-blob-2{width:280px;height:280px;background:radial-gradient(circle,var(--green-soft),transparent 70%);bottom:-100px;left:-40px}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-block;background:#fff;color:var(--brand-dark);font-weight:700;font-size:.82rem;padding:.4em 1em;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:1rem}
.hero h1{font-size:3.2rem;margin-bottom:.3em}
.hero h1 .hl{color:var(--brand);position:relative}
.hero-sub{font-size:1.18rem;color:var(--muted);max-width:34ch;margin-bottom:1.6rem}
.hero-search{display:flex;gap:.5rem;background:#fff;padding:.5rem;border-radius:999px;box-shadow:var(--shadow);max-width:480px}
.hero-search input{flex:1;border:0;padding:.6em 1.1em;font-size:1rem;border-radius:999px;outline:none;font-family:inherit}
.hero-quick{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-top:1.2rem;font-size:.9rem;color:var(--muted)}
.hero-quick a{background:#fff;padding:.35em .9em;border-radius:999px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm)}
.hero-quick a:hover{color:var(--brand)}
.hero-card{position:relative;background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:14px}
.hero-photo{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;background:#eee}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo-tag{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.92);color:var(--ink);font-weight:700;font-size:.8rem;padding:.35em .8em;border-radius:999px;box-shadow:var(--shadow-sm)}
.hero-card-foot{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:14px 8px 6px}
.hero-card-foot-title{font-weight:700;font-size:.98rem;flex:1;min-width:140px;color:var(--ink)}
.hero-card-cta{color:var(--brand);font-weight:700;white-space:nowrap}
.hero-card-foot:hover .hero-card-cta{color:var(--brand-dark)}
.chip{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-weight:700;font-size:.76rem;padding:.3em .9em;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}
.chip-green{background:var(--green-soft);color:#1d7a4a}

/* USP bar */
.usp-bar{background:var(--ink);color:#fff}
.usp-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding:18px 20px}
.usp{display:flex;align-items:center;gap:.5em;font-weight:600;font-size:.92rem}
.usp span{font-size:1.2rem}

/* Sections */
.section{padding:64px 0}
.section-tint{background:var(--cream)}
.section-narrow{padding:24px 0}
.section-prose{max-width:760px}
.section-head{text-align:center;max-width:600px;margin:0 auto 2.5rem}
.section-head h2{font-size:2.1rem}
.section-head p{color:var(--muted);font-size:1.05rem}
.section-head.between{display:flex;justify-content:space-between;align-items:flex-end;text-align:left;max-width:none}
.section-head.between p{margin:0}

/* Category cards */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.cat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.18s}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.cat-icon{font-size:2.2rem;display:block;margin-bottom:.5rem}
.cat-card h3{font-size:1.2rem;margin-bottom:.3em}
.cat-card p{color:var(--muted);font-size:.92rem;margin:0}

/* Article cards */
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.article-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.18s;display:flex;flex-direction:column}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.article-card-media{position:relative;height:160px;background:linear-gradient(135deg,var(--brand-soft),var(--cream));display:flex;align-items:center;justify-content:center}
.article-emoji{font-size:3.4rem}
.badge-exp{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;font-weight:700;font-size:.74rem;padding:.3em .8em;border-radius:999px}
.badge-exp-lg{position:static;display:inline-block}
.article-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.article-card-body h3{font-size:1.18rem;margin:.2em 0}
.article-card-body h3 a:hover{color:var(--brand)}
.article-card-body p{color:var(--muted);font-size:.92rem;margin:0;flex:1}
.article-card-meta{font-size:.82rem;color:var(--muted);display:flex;gap:.4rem}

/* Breed cards */
.breed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.breed-grid-lg{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.breed-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:.18s}
.breed-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.breed-emoji{font-size:2.4rem}
.breed-card h3{font-size:1.2rem;margin:.3em 0 .1em}
.breed-meta{color:var(--muted);font-size:.85rem;margin-bottom:.8rem}
.breed-bars{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.mini-meter{display:grid;grid-template-columns:64px 1fr;align-items:center;gap:8px}
.mini-meter-label{font-size:.72rem;color:var(--muted);font-weight:700}
.mini-track{background:rgba(0,0,0,.08);border-radius:999px;height:8px;overflow:hidden}
.mini-fill{display:block;height:100%;background:var(--brand);border-radius:999px;min-width:6px}

/* Outings */
.outing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.outing-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.outing-card:hover{box-shadow:var(--shadow);border-color:transparent}
.outing-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.outing-rating{color:var(--brand);font-size:1rem}
.outing-prov{color:var(--muted);font-size:.88rem;margin:.2em 0 .6em}
.outing-card p{color:var(--muted);font-size:.93rem}

/* Page hero */
.page-hero{background:linear-gradient(160deg,var(--cream),var(--brand-soft));padding:56px 0;text-align:center}
.page-hero h1{font-size:2.6rem}
.page-hero p{color:var(--muted);font-size:1.1rem;max-width:60ch;margin:.3em auto 0}
.page-hero-icon{font-size:2.6rem;display:block;margin-bottom:.4rem}

/* Breadcrumb */
.breadcrumb{padding:20px;font-size:.85rem;color:var(--muted)}
.breadcrumb a:hover{color:var(--brand)}

/* Article layout */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;padding-bottom:64px;align-items:start}
.article-header h1{font-size:2.5rem;margin:.3em 0}
.article-lead{font-size:1.2rem;color:var(--muted)}
.article-byline{display:flex;align-items:center;gap:.8rem;margin:1.4rem 0;flex-wrap:wrap}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem}
.article-byline strong{display:block}.article-byline span{font-size:.85rem;color:var(--muted)}
.article-hero-visual{height:280px;border-radius:var(--radius);background:linear-gradient(135deg,var(--brand-soft),var(--cream));display:flex;align-items:center;justify-content:center;font-size:5rem;margin:1.5rem 0}
.article-body{font-size:1.07rem;color:#2a3540}
.article-body h2{font-size:1.6rem;margin:1.6em 0 .5em}
.article-body p{margin:0 0 1.2em}
.article-body em{color:var(--muted)}
.article-body a{color:var(--brand-dark);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.article-body a:hover{color:var(--brand)}
.article-body .cta-box{background:var(--brand-soft);border-radius:var(--radius);padding:18px 22px;margin:1.8em 0}
.article-body .cta-box p{margin:.3em 0}
.article-body .cta-box a.btn{text-decoration:none;color:#fff;margin-top:.5rem}
.article-body .cta-box a:not(.btn){color:var(--brand-dark)}

/* Affiliate box */
.aff-section{margin-top:2.5rem;background:var(--cream);padding:28px;border-radius:var(--radius)}
.aff-section h2{margin-top:0}
.aff-disclaimer{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}
.aff-box{display:grid;grid-template-columns:64px 1fr auto;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:14px}
.aff-img{width:64px;height:64px;border-radius:12px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.aff-info h4{margin:0 0 .2em;font-size:1.08rem}
.aff-info p{margin:0;color:var(--muted);font-size:.9rem}
.aff-meta{display:flex;gap:1rem;margin-top:.4rem;font-size:.9rem}
.aff-rating{color:var(--brand);font-weight:700}.aff-price{font-weight:800}
.aff-action{text-align:center}
.aff-note{display:block;font-size:.7rem;color:var(--muted);margin-top:.4rem}

/* Sidebar */
.sidebar-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:20px}
.sidebar-news{background:linear-gradient(160deg,var(--brand-soft),var(--cream));border:0}
.sidebar-news input{width:100%;padding:.7em 1em;border-radius:10px;border:1px solid var(--line);margin:.5rem 0;font-family:inherit}
.mini-link{display:block;padding:.4em 0;border-bottom:1px solid var(--line);font-weight:600;font-size:.92rem}
.mini-link:last-child{border:0}.mini-link:hover{color:var(--brand)}

/* Breed detail */
.breed-hero{display:grid;grid-template-columns:200px 1fr;gap:32px;align-items:center;padding:32px 20px}
.breed-hero-visual{height:180px;border-radius:var(--radius);background:linear-gradient(135deg,var(--brand-soft),var(--cream));display:flex;align-items:center;justify-content:center;font-size:4rem}
.breed-hero h1{font-size:2.4rem;margin-bottom:.2em}
.breed-origin{color:var(--muted)}
.breed-quickfacts{display:flex;gap:24px;margin-top:1rem}
.breed-quickfacts div{display:flex;flex-direction:column}
.breed-quickfacts span{font-size:.8rem;color:var(--muted)}
.breed-quickfacts strong{font-size:1.1rem}
.breed-scores{background:var(--cream);border-radius:var(--radius);padding:24px;margin-top:1.5rem}
.score-row{display:grid;grid-template-columns:140px 1fr 48px;gap:14px;align-items:center;margin-bottom:.8rem}
.score-label{font-weight:600;font-size:.92rem}
.score-track{position:relative;background:rgba(0,0,0,.08);border-radius:999px;height:14px;overflow:hidden}
.score-fill{display:block;height:100%;min-width:10px;background:var(--brand);border-radius:999px;transition:width .4s ease}
.score-num{font-weight:700;font-size:.88rem;text-align:right}

/* Ras-finder */
.finder{display:flex;gap:1.5rem;align-items:flex-end;background:var(--cream);padding:20px 24px;border-radius:var(--radius);margin-bottom:2rem;flex-wrap:wrap}
.finder-group{display:flex;flex-direction:column;gap:.3rem}
.finder-group label{font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.finder select{padding:.6em 1em;border-radius:10px;border:1px solid var(--line);font-family:inherit;font-size:.95rem;background:#fff;min-width:160px}
.finder-reset{color:var(--brand);font-weight:600;font-size:.9rem;padding-bottom:.7em}

/* Newsletter band */
.newsletter-band{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;padding:56px 0}
.newsletter-inner{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.newsletter-copy h2{font-size:1.3rem;margin-bottom:.2em}
.newsletter-copy p{margin:0;opacity:.95}
.newsletter-form{display:flex;gap:.5rem;background:#fff;padding:.5rem;border-radius:999px;box-shadow:var(--shadow)}
.newsletter-form input{border:0;padding:.7em 1.2em;font-size:1rem;border-radius:999px;outline:none;min-width:240px;font-family:inherit}

/* Newsletter landing */
.news-landing{background:linear-gradient(160deg,var(--cream),var(--brand-soft));padding:64px 0}
.news-landing-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.news-benefits{list-style:none;padding:0;margin:1.2rem 0 0;display:flex;flex-direction:column;gap:.5rem;font-weight:600}
.news-landing-form{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:32px}
.news-landing-form input{width:100%;padding:.8em 1em;border:1px solid var(--line);border-radius:10px;margin:.3rem 0 1rem;font-family:inherit;font-size:1rem}
.news-landing-form label{font-weight:600;font-size:.9rem}
.form-note{font-size:.8rem;color:var(--muted);margin-top:.8rem}

/* Ads */
.ad-zone{display:flex;align-items:center;justify-content:center;margin:0 auto}
.ad-placeholder{width:100%;min-height:90px;border:2px dashed var(--line);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#b9c2cb;font-size:.85rem;text-align:center;background:#fafbfc}
.ad-header-wrap,.ad-footer-wrap{padding:16px 20px}
.ad-sidebar .ad-placeholder{min-height:250px}

/* Flash */
.flash{padding:14px 18px;border-radius:12px;margin:16px 0;font-weight:600}
.flash-success{background:var(--green-soft);color:#1d7a4a}
.flash-error{background:#FDE8E8;color:#c0392b}

/* Footer */
.site-footer{background:var(--ink);color:#c8d0d8;padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.footer-grid h4{color:#fff;font-size:.95rem;margin-bottom:.9em}
.footer-grid a{display:block;color:#aeb8c2;font-size:.9rem;padding:.25em 0}
.footer-grid a:hover{color:var(--brand)}
.logo-footer .logo-text{color:#fff}
.footer-tag{font-size:.9rem;color:#8c97a2;margin-top:.8rem;max-width:32ch}
.footer-bottom{border-top:1px solid #2c3744;margin-top:32px;padding-top:20px;font-size:.82rem;color:#7c8794}

/* Consent */
.consent-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:560px;margin:0 auto;background:#fff;box-shadow:var(--shadow);border-radius:14px;padding:18px 20px;z-index:100;display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between}
.consent-banner[hidden]{display:none}
.consent-banner p{margin:0;font-size:.88rem;flex:1;min-width:200px}
.consent-banner a{color:var(--brand);font-weight:600}
.consent-actions{display:flex;gap:.5rem}

.empty,.muted{color:var(--muted)}
.search-count{color:var(--muted);margin-bottom:1.5rem}
.hero-search-page{margin:1rem auto 0}

/* Article-lijsten */
.article-body ul{margin:0 0 1.2em;padding-left:1.2em}
.article-body li{margin:.35em 0;color:#3a3027}

/* Error page */
.error-page{text-align:center;padding:80px 20px}
.error-emoji{font-size:4rem;margin-bottom:1rem}
.error-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}

/* Responsive */
@media(max-width:900px){
  .hero-inner,.news-landing-inner{grid-template-columns:1fr}
  .article-layout{grid-template-columns:1fr}
  .article-sidebar{order:2}
  .breed-hero{grid-template-columns:1fr;text-align:center}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2.4rem}
  .section-head.between{flex-direction:column;align-items:flex-start;gap:1rem}
}
@media(max-width:680px){
  .main-nav{position:fixed;inset:70px 0 auto 0;background:#fff;flex-direction:column;padding:1rem;gap:.4rem;border-bottom:1px solid var(--line);display:none}
  body.nav-open .main-nav{display:flex}
  .nav-toggle{display:flex}
  .nav-dropdown{width:100%}.nav-drop-menu{position:static;box-shadow:none;display:flex}
  .usp-grid{justify-content:flex-start}
  .footer-grid{grid-template-columns:1fr}
  .aff-box{grid-template-columns:1fr;text-align:center}
}

/* Rustige iconen (vervangen emoji) */
.ico{color:var(--brand);vertical-align:middle;flex:none}
.cat-icon .ico{width:30px;height:30px}
.usp .ico{color:var(--brand-soft)}
.breed-emoji .ico,.breed-hero-visual .ico,.article-emoji .ico{color:var(--brand);opacity:.85}
.page-hero-icon .ico{width:40px;height:40px}

/* Artikelkaart-media: compacter + ondersteunt previewfoto */
.article-card-media{height:140px}
.article-card-media img{width:100%;height:100%;object-fit:cover;display:block}
.article-card-media.is-placeholder{height:96px;background:var(--brand-soft)}
.article-card-media.is-placeholder .article-emoji{opacity:.55}
.chip-muted{background:var(--line);color:var(--muted)}

/* Rasfoto's */
.breed-emoji img{width:100%;height:120px;object-fit:cover;border-radius:12px;display:block;margin-bottom:.2rem}
.breed-hero-visual img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);display:block}

/* Klikbare rasfoto (zelfde opmaak als voorheen) + lightbox-popup */
.breed-hero-visual img.breed-photo-zoom{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.85);padding:24px;cursor:zoom-out}
.lightbox img{max-width:95vw;max-height:90vh;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.5);cursor:default}
.lightbox-close{position:absolute;top:14px;right:20px;background:none;border:0;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer}
