/* ===========================================================================
   PrintyStore — Premium 3D-lampenwinkel · Design System
   Palet: warm zand/beige, wit, bijna-zwart · zachte schaduwen · rustige spacing
   =========================================================================== */

:root {
  /* Kleuren — warm premium palet (PrintyStore designspec) */
  --c-ink:        #2B1E17;   /* donkerbruin, tekst */
  --c-ink-soft:   #7B6A5B;   /* zacht grijs/bruin, secundaire tekst */
  --c-muted:      #9a8b7b;   /* labels, captions */
  --c-line:       #e8ddca;   /* warme randen */
  --c-bg:         #F7F1E8;   /* cream pagina-achtergrond */
  --c-surface:    #ffffff;   /* kaarten */
  --c-sand:       #EAD8C0;   /* warm beige vlak */
  --c-sand-2:     #ddc9aa;   /* hover/accent vlak */
  --c-accent:     #B96F3C;   /* terracotta/bruin accent (designspec) */
  --c-accent-ink: #9a5a2f;   /* donkere terracotta voor hover/tekst */
  --c-glow:       #f2c98c;   /* lamplicht-gloed */
  --primary:      #B96F3C;   /* alias */
  --c-dark:       #2B1E17;   /* donkerbruine secties / balken */

  /* Typografie */
  --f-display: "Fraunces", "Playfair Display", Georgia, serif;
  --f-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Maatvoering */
  --maxw: 1240px;
  --gutter: clamp(1rem, 4vw, 2.5rem);
  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 28px;

  /* Schaduwen */
  --sh-1: 0 1px 2px rgba(28,26,23,.04), 0 4px 16px rgba(28,26,23,.06);
  --sh-2: 0 8px 30px rgba(28,26,23,.10);
  --sh-glow: 0 10px 50px rgba(246,201,122,.35);

  --t: .35s cubic-bezier(.2,.7,.2,1);
}

/* Reset ------------------------------------------------------------------- */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--f-body);
  color: var(--c-ink);
  background: var(--c-bg);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
h1,h2,h3,h4 { font-family: var(--f-display); font-weight: 600; line-height: 1.12; letter-spacing: -.01em; color: var(--c-ink); margin: 0 0 .5em; }
h1 { font-size: clamp(2.1rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.5rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.45rem); }
p { margin: 0 0 1rem; color: var(--c-ink-soft); }

/* Layout ------------------------------------------------------------------ */
.container { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(3rem, 8vw, 6rem); }
.section--tight { padding-block: clamp(2rem, 5vw, 3.5rem); }
.section--dark { background: var(--c-dark); color: #f3ede2; }
.section--dark h2,.section--dark h3 { color: #fff; }
.section--dark p { color: #cdc4b5; }
.section--sand { background: var(--c-sand); }
.eyebrow { font-family: var(--f-body); font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; color: var(--c-accent-ink); font-weight: 600; margin: 0 0 .8rem; }
.lead { font-size: 1.15rem; color: var(--c-ink-soft); max-width: 60ch; }
.center { text-align: center; }
.center .lead { margin-inline: auto; }

/* Buttons ----------------------------------------------------------------- */
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .85rem 1.6rem; border-radius: 999px; font-weight: 600; font-size: .98rem; border: 1px solid transparent; transition: var(--t); will-change: transform; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--c-ink); color: #fff; box-shadow: var(--sh-1); }
.btn-primary:hover { background: #000; box-shadow: var(--sh-2); }
.btn-secondary { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn-secondary:hover { background: var(--c-ink); color: #fff; }
.btn-ghost { background: var(--c-surface); border-color: var(--c-line); color: var(--c-ink); box-shadow: var(--sh-1); }
.btn-block { width: 100%; justify-content: center; }
.btn-lg { padding: 1.05rem 2rem; font-size: 1.05rem; }

/* Header ------------------------------------------------------------------ */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(250,247,241,.85); backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--c-line); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; height: 72px; }
.brand { font-family: var(--f-display); font-weight: 600; font-size: 1.35rem; letter-spacing: -.02em; display: flex; align-items: center; gap: .5rem; }
.brand .dot { width: 11px; height: 11px; border-radius: 50%; background: radial-gradient(circle at 35% 35%, var(--c-glow), var(--c-accent)); box-shadow: 0 0 12px var(--c-glow); }
.nav-links { display: flex; gap: 1.6rem; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-links a { font-size: .96rem; font-weight: 500; color: var(--c-ink-soft); position: relative; padding: .3rem 0; transition: var(--t); }
.nav-links a:hover { color: var(--c-ink); }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: var(--c-accent); transition: var(--t); }
.nav-links a:hover::after { width: 100%; }
.nav-actions { display: flex; align-items: center; gap: 1rem; }
.icon-btn { background: none; border: none; color: var(--c-ink); padding: .3rem; display: inline-flex; }
.nav-toggle { display: none; background: none; border: none; flex-direction: column; gap: 5px; padding: .4rem; }
.nav-toggle span { width: 24px; height: 2px; background: var(--c-ink); border-radius: 2px; transition: var(--t); }
.nav-links a { white-space: nowrap; }
.nav-links > li { position: relative; }
.has-dropdown > a { display: inline-flex; align-items: center; gap: .3rem; }
.has-dropdown .caret { font-size: .65em; opacity: .55; transition: var(--t); }
.has-dropdown:hover .caret, .has-dropdown:focus-within .caret { opacity: .9; transform: rotate(180deg); }
.dropdown { position: absolute; top: 100%; left: 0; min-width: 230px; background: var(--c-surface);
  border: 1px solid var(--c-line); border-radius: var(--radius-sm); box-shadow: var(--sh-2);
  padding: .45rem; display: grid; gap: .05rem; opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: var(--t); z-index: 60; }
.dropdown::before { content: ""; position: absolute; top: -12px; left: 0; right: 0; height: 12px; }
.has-dropdown:hover > .dropdown, .has-dropdown:focus-within > .dropdown, .has-dropdown.open > .dropdown {
  opacity: 1; visibility: visible; transform: none; }
.dropdown a { padding: .6rem .75rem; border-radius: 8px; font-size: .92rem; font-weight: 500; color: var(--c-ink-soft); }
.dropdown a::after { display: none; }
.dropdown a:hover { background: var(--c-sand); color: var(--c-ink); }
.nav-links a[aria-current="page"] { color: var(--c-accent); font-weight: 600; }
.nav-links > li > a[aria-current="page"]::after { width: 100%; }
@media (max-width: 820px){
  .nav-links a { white-space: normal; }
  .has-dropdown > a { justify-content: space-between; width: 100%; }
  .has-dropdown .caret { margin-left: auto; }
  .dropdown { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none;
    border: none; background: transparent; padding: 0 0 .4rem .9rem; display: none; min-width: 0; }
  .dropdown::before { display: none; }
  .has-dropdown.open > .dropdown { display: grid; }
  .dropdown a { padding: .55rem 0; }
}

/* Breadcrumb -------------------------------------------------------------- */
.breadcrumb { font-size: .85rem; color: var(--c-muted); padding-block: 1.1rem; }
.breadcrumb a:hover { color: var(--c-accent-ink); }
.breadcrumb span { margin-inline: .4rem; opacity: .6; }

/* Hero -------------------------------------------------------------------- */
.hero { position: relative; overflow: hidden; background: linear-gradient(160deg, var(--c-sand) 0%, var(--c-bg) 60%); }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; padding-block: clamp(2.5rem,6vw,5rem); }
.hero-copy h1 { margin-bottom: .4em; }
.hero-cta { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 1.6rem; }
.hero-visual { position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); background:
    radial-gradient(120% 90% at 50% 18%, rgba(246,201,122,.55), rgba(246,201,122,0) 55%),
    linear-gradient(180deg, #2a2620, #15120e);
  display: grid; place-items: center; box-shadow: var(--sh-2); overflow: hidden; }
.hero-visual .lamp { width: 46%; aspect-ratio: 1/1.3; border-radius: 46% 46% 38% 38%/ 55% 55% 45% 45%;
  background: linear-gradient(180deg, #f7d79a, #d79a48);
  box-shadow: var(--sh-glow), inset 0 -10px 30px rgba(0,0,0,.18);
  position: relative; }
.hero-visual .lamp::before { content:""; position:absolute; inset: 0;
  background: repeating-linear-gradient(180deg, rgba(255,255,255,.10) 0 3px, rgba(0,0,0,.04) 3px 6px);
  border-radius: inherit; mix-blend-mode: overlay; }
.hero-note { position:absolute; bottom: 14px; left: 16px; font-size:.75rem; color:#e9dcc4; opacity:.8; }

/* USP-balk ---------------------------------------------------------------- */
.usp-bar { background: var(--c-surface); border-block: 1px solid var(--c-line); }
.usp-list { list-style: none; margin: 0; padding: 1.1rem 0; display: grid; grid-template-columns: repeat(6,1fr); gap: 1rem; }
.usp-list li { display: flex; align-items: center; gap: .55rem; font-size: .9rem; font-weight: 500; color: var(--c-ink-soft); }
.usp-list .ico { font-size: 1.15rem; }

/* Section head ------------------------------------------------------------ */
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
/* Pagina-hero (eyebrow + H1 + lead) hoort gestapeld, niet als rij uitgelijnd */
.section-head:has(> h1) { display: block; max-width: 70ch; }
.section-head:has(> h1) .lead { margin-top: .6rem; }
.section-head .lead { margin: 0; }

/* Grids & cards ----------------------------------------------------------- */
.grid { display: grid; gap: clamp(1rem, 2.5vw, 1.8rem); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

.card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden; transition: var(--t); display: flex; flex-direction: column; }
.card:hover { transform: translateY(-6px); box-shadow: var(--sh-2); border-color: var(--c-sand-2); }
.card-media { aspect-ratio: 4/5; position: relative; overflow: hidden; background: linear-gradient(180deg, var(--c-sand), #fff); display:grid; place-items:center; }
.card-media .ph { width:55%; aspect-ratio:1/1.25; border-radius: 44% 44% 36% 36%/52% 52% 48% 48%; background: linear-gradient(180deg,#f3dca9,#cf9a52); box-shadow: inset 0 -8px 22px rgba(0,0,0,.15), 0 8px 30px rgba(207,154,82,.25); transition: var(--t); }
.card:hover .card-media .ph { transform: scale(1.04); box-shadow: var(--sh-glow); }
.card-body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.card-title { font-family: var(--f-display); font-size: 1.18rem; }
.card-sub { font-size: .9rem; color: var(--c-muted); }
.card-price { font-weight: 600; color: var(--c-ink); margin-top: .2rem; }
.card-foot { margin-top: auto; padding-top: .8rem; }

/* Collectie-tegel (groot) */
.col-tile { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 280px; display: flex; align-items: flex-end; padding: 1.4rem; color: #fff; background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55)), linear-gradient(160deg, var(--c-sand-2), #6b5a44); transition: var(--t); }
.col-tile:hover { transform: translateY(-4px); box-shadow: var(--sh-2); }
.col-tile h3 { color: #fff; margin: 0 0 .2rem; }
.col-tile p { color: rgba(255,255,255,.85); font-size: .9rem; margin: 0; max-width: 34ch; }
.col-tile .arrow { position:absolute; top:1.2rem; right:1.3rem; transition: var(--t); }
.col-tile:hover .arrow { transform: translate(4px,-4px); }
.col-tile--lg { grid-row: span 2; min-height: 100%; }

/* Badges ------------------------------------------------------------------ */
.badges { display: flex; flex-wrap: wrap; gap: .4rem; }
.badge { font-size: .72rem; font-weight: 600; letter-spacing: .02em; padding: .3rem .6rem; border-radius: 999px; background: var(--c-sand); color: var(--c-accent-ink); border: 1px solid var(--c-sand-2); }
.badge--ink { background: var(--c-ink); color: #fff; border-color: var(--c-ink); }
.badge-pos { position: absolute; top: .8rem; left: .8rem; z-index: 2; }

/* Productpagina ----------------------------------------------------------- */
.pdp { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem,4vw,3rem); align-items: start; }
.gallery .main-img { aspect-ratio: 1/1; border-radius: var(--radius); background: linear-gradient(180deg,var(--c-sand),#fff); display:grid; place-items:center; box-shadow: var(--sh-1); }
.gallery .main-img .ph { width: 58%; aspect-ratio:1/1.25; border-radius: 44% 44% 36% 36%/52% 52% 48% 48%; background: linear-gradient(180deg,#f5d9a0,#cf9a52); box-shadow: var(--sh-glow); }
.thumbs { display: grid; grid-template-columns: repeat(5,1fr); gap: .6rem; margin-top: .7rem; }
.thumb { aspect-ratio: 1/1; border-radius: var(--radius-sm); background: var(--c-sand); border: 1px solid var(--c-line); display:grid; place-items:center; cursor:pointer; transition: var(--t); font-size:.65rem; color: var(--c-muted); text-align:center; padding: .2rem; }
.thumb:hover, .thumb.is-active { border-color: var(--c-accent); box-shadow: 0 0 0 1px var(--c-accent); }
.swatches { max-width: 360px; }
.swatch { position: relative; }
.swatch[style*="#f3f1ec"], .swatch[title="Wit mat"] { box-shadow: 0 0 0 1px var(--c-line); }
.swatch-name { font-weight: 600; color: var(--c-ink); }
.pdp-info h1 { margin-bottom: .3rem; }
.pdp-price { font-size: 1.4rem; font-weight: 600; margin: .6rem 0 1rem; }
.opt-group { margin: 1.1rem 0; }
.opt-group .opt-label { font-size: .85rem; font-weight: 600; color: var(--c-ink); margin-bottom: .5rem; display:block; }
.swatches { display: flex; gap: .5rem; flex-wrap: wrap; }
.swatch { width: 34px; height: 34px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--c-line); cursor: pointer; transition: var(--t); }
.swatch:hover, .swatch.is-active { box-shadow: 0 0 0 2px var(--c-accent); transform: scale(1.08); }
.size-pills { display:flex; gap:.5rem; flex-wrap:wrap; }
.pill { padding: .5rem 1rem; border: 1px solid var(--c-line); border-radius: 999px; font-size: .88rem; cursor: pointer; transition: var(--t); background:#fff; }
.pill:hover, .pill.is-active { border-color: var(--c-ink); background: var(--c-ink); color:#fff; }
.spec-table { width:100%; border-collapse: collapse; font-size: .92rem; margin: 1rem 0; }
.spec-table td { padding: .6rem 0; border-bottom: 1px solid var(--c-line); vertical-align: top; }
.spec-table td:first-child { color: var(--c-muted); width: 42%; }
.todo { color: #b5651d; background: #fff4e6; padding: .05rem .35rem; border-radius: 5px; font-size: .85em; }
.opt-note { display: block; margin-top: .4rem; font-size: .85rem; color: var(--c-muted); }

/* Productconfigurator */
.pdp-meta { font-size: .85rem; color: var(--c-muted); margin: .2rem 0 1.2rem; }
.configurator .opt-label { display:block; }
.configurator .opt-label .req { color: #c0392b; font-style: normal; }
.size-pills .pill small { font-size: .78em; color: var(--c-muted); font-weight: 500; }
.size-pills .pill.is-active small { color: rgba(255,255,255,.85); }
.config-summary { background: var(--c-sand); border: 1px solid var(--c-line); border-radius: var(--radius-sm); padding: 1rem 1.2rem; margin: 1.3rem 0; }
.config-summary strong { display: block; font-family: var(--f-display); font-size: 1.05rem; margin-bottom: .6rem; }
.config-summary ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .35rem; font-size: .92rem; color: var(--c-ink-soft); }
.config-summary li span[data-sum] { font-weight: 600; color: var(--c-ink); }
.config-error { color: #c0392b; font-size: .9rem; margin-top: .7rem; font-weight: 600; }
.config-error[hidden] { display: none; }

/* Accordion / FAQ --------------------------------------------------------- */
.accordion { border-top: 1px solid var(--c-line); }
.acc-item { border-bottom: 1px solid var(--c-line); }
.acc-head { width: 100%; text-align: left; background: none; border: none; padding: 1.1rem 0; font-size: 1.05rem; font-weight: 600; font-family: var(--f-display); display: flex; justify-content: space-between; align-items: center; gap: 1rem; color: var(--c-ink); }
.acc-head .plus { transition: var(--t); flex: none; }
.acc-item.is-open .acc-head .plus { transform: rotate(45deg); }
.acc-panel { max-height: 0; overflow: hidden; transition: max-height var(--t); }
.acc-panel p { padding-bottom: 1.1rem; margin: 0; }

/* Reviews ----------------------------------------------------------------- */
.review-card { background: var(--c-surface); border:1px solid var(--c-line); border-radius: var(--radius); padding: 1.4rem; box-shadow: var(--sh-1); }
.stars { color: var(--c-accent); letter-spacing: .1em; }

/* Sticky add-to-cart (mobiel) -------------------------------------------- */
.sticky-atc { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; background: rgba(255,255,255,.96); backdrop-filter: blur(10px); border-top: 1px solid var(--c-line); padding: .7rem var(--gutter); display: none; align-items: center; justify-content: space-between; gap: 1rem; box-shadow: 0 -6px 24px rgba(28,26,23,.08); }
.sticky-atc .p { font-weight: 600; }

/* Newsletter -------------------------------------------------------------- */
.newsletter { background: linear-gradient(160deg, var(--c-sand), var(--c-bg)); border-radius: var(--radius-lg); padding: clamp(2rem,5vw,3.5rem); text-align: center; }
.news-form { display: flex; gap: .6rem; max-width: 460px; margin: 1.2rem auto 0; }
.news-form input { flex: 1; padding: .9rem 1.1rem; border: 1px solid var(--c-line); border-radius: 999px; background: #fff; font: inherit; }
.news-form input:focus { outline: 2px solid var(--c-accent); outline-offset: 1px; }

/* Footer ------------------------------------------------------------------ */
.site-footer { background: var(--c-dark); color: #cdc4b5; padding-block: clamp(2.5rem,6vw,4rem) 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(4,1fr); gap: 2rem; }
.site-footer h4 { color: #fff; font-family: var(--f-body); font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1rem; }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .5rem; }
.site-footer a { color: #cdc4b5; font-size: .92rem; transition: var(--t); }
.site-footer a:hover { color: #fff; }
.footer-brand .brand { color:#fff; margin-bottom:.7rem; }
.footer-pay { display:flex; gap:.4rem; flex-wrap:wrap; margin-top:1rem; }
.footer-pay span { font-size:.7rem; background:#37322b; border:1px solid #4a443b; padding:.25rem .5rem; border-radius:6px; color:#e8dfd0; }
.footer-bottom { border-top: 1px solid #3a342c; margin-top: 2.5rem; padding-top: 1.4rem; font-size: .82rem; color: #9a9183; display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; }

/* Echte afbeeldingen (vervangen de .ph placeholders) ---------------------- */
.card-media img, .main-img img, .thumb img, .col-tile img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card-media, .main-img, .thumb { overflow: hidden; }
.thumb img { border-radius: inherit; }
.col-tile { position: relative; }
.col-tile img { position: absolute; inset: 0; z-index: 0; }
.col-tile > * { position: relative; z-index: 1; }
.col-tile::after { content: ""; position: absolute; inset: 0; z-index: 0; background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55)); }
.hero-visual img.hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; border-radius: inherit; z-index: 0; }
.hero-visual .hero-note { position: absolute; z-index: 1; }

/* Prose ------------------------------------------------------------------- */
.prose { max-width: 72ch; }
.prose p { margin-bottom: 1.1rem; }
.prose h2 { margin-top: 1.8rem; }
.intro-seo { max-width: 80ch; color: var(--c-ink-soft); }
.intro-seo a { color: var(--c-accent-ink); text-decoration: underline; text-underline-offset: 3px; }

/* Reveal animatie --------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none;} html{scroll-behavior:auto;} }

/* Responsive -------------------------------------------------------------- */
@media (max-width: 980px){
  .usp-list { grid-template-columns: repeat(3,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .grid-4 { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 820px){
  .nav-links { position: fixed; inset: 72px 0 auto 0; background: var(--c-bg); flex-direction: column; align-items: stretch; gap: 0; padding: .5rem var(--gutter) 1.2rem; border-bottom: 1px solid var(--c-line); transform: translateY(-120%); transition: var(--t); box-shadow: var(--sh-2); }
  .nav-links.open { transform: none; }
  .nav-links li { border-bottom: 1px solid var(--c-line); }
  .nav-links a { display: block; padding: .9rem 0; }
  .nav-toggle { display: flex; }
  .hero-grid, .pdp { grid-template-columns: 1fr; }
  .hero-visual { order: -1; aspect-ratio: 16/12; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .sticky-atc { display: flex; }
  body { padding-bottom: 72px; }
}
@media (max-width: 560px){
  .usp-list { grid-template-columns: repeat(2,1fr); }
  .grid-2,.grid-3,.grid-4 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .news-form { flex-direction: column; border-radius: var(--radius); }
  .news-form input, .news-form .btn { width: 100%; }
}
