/* ============================================================
   PuntoShop24 — shared styles
   Estratto e allineato alla landing puntoshop24.it
   ============================================================ */
:root {
  --green-900:#0F3D2E;
  --green-800:#124735;
  --green-700:#1a5c42;
  --orange:#F79640;
  --orange-600:#e8842f;
  --purple:#667eea;
  --text:#333333;
  --muted:#666666;
  --line:#e8e8e8;
  --soft:#f8f9fa;
  --footer:#0a2a1e;
  --white:#ffffff;
  --rovere:#B89968;
  --antracite:#2C2E2D;
  --teal:#0d8a87;
  --shadow-sm:0 12px 30px rgba(15,61,46,.08);
  --shadow-md:0 22px 50px rgba(15,61,46,.14);
  --radius:22px;
  --radius-md:16px;
  --container:1200px;
  --nav-height:86px;
  --transition:220ms ease;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text); background:#fff;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
section{scroll-margin-top:calc(var(--nav-height) + 18px)}
.container{width:min(100% - 32px, var(--container));margin:0 auto}
.section{padding:88px 0}
.section--soft{background:var(--soft)}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:999px;font-size:13px;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  white-space:nowrap;
}
.eyebrow--orange{background:rgba(247,150,64,.14);color:var(--orange);border:1px solid rgba(247,150,64,.4)}
.eyebrow--green{background:rgba(15,61,46,.06);color:var(--green-900);border:1px solid rgba(15,61,46,.18)}
.eyebrow--light{color:var(--orange);background:rgba(247,150,64,.14);border:1px solid rgba(247,150,64,.45)}
.section-head{max-width:860px;margin:0 auto 50px;text-align:center}
.section-title{
  margin:0 0 16px;font-size:clamp(32px,4vw,42px);line-height:1.12;font-weight:900;
  letter-spacing:-.04em;color:var(--green-900);
}
.section-subtitle{margin:0;font-size:clamp(16px,2vw,18px);color:var(--muted)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:999px;padding:16px 28px;border:1px solid transparent;
  font-weight:800;font-size:16px;line-height:1;cursor:pointer;
  transition:transform var(--transition), box-shadow var(--transition), background-color var(--transition), color var(--transition), border-color var(--transition);
  white-space:nowrap;text-decoration:none;
}
.btn:hover,.btn:focus-visible{transform:translateY(-2px);box-shadow:0 14px 28px rgba(0,0,0,.12);outline:none}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--orange-600)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline-light:hover,.btn-outline-light:focus-visible{background:rgba(255,255,255,.12);border-color:#fff}
.btn-outline-dark{background:transparent;color:var(--green-900);border-color:rgba(15,61,46,.18)}
.btn-outline-dark:hover,.btn-outline-dark:focus-visible{border-color:var(--orange);color:var(--orange-600)}
.btn-dark{background:var(--green-900);color:#fff}
.btn-dark:hover{background:var(--green-700)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* NAV */
.site-header{
  position:sticky;top:0;z-index:1000;background:rgba(15,61,46,.98);
  border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px);
}
.navbar{
  min-height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:16px 0;position:relative;
}
.brand img{height:44px;width:auto}
.nav-links{display:none;align-items:center;gap:28px}
.nav-links a{color:rgba(255,255,255,.92);font-size:15px;font-weight:700;transition:color var(--transition)}
.nav-links a:hover,.nav-links a:focus-visible,.nav-links a.is-active{color:var(--orange);outline:none}
.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.hamburger{
  display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;
  border-radius:12px;border:1px solid rgba(255,255,255,.14);background:transparent;color:#fff;cursor:pointer;
}
.hamburger:hover,.hamburger:focus-visible{background:rgba(255,255,255,.08);outline:none}
.hamburger svg{width:24px;height:24px}
.mobile-menu{
  display:none;position:absolute;left:0;right:0;top:calc(100% + 10px);
  background:rgba(10,42,30,.98);border:1px solid rgba(255,255,255,.08);border-radius:18px;
  padding:14px;box-shadow:0 16px 40px rgba(0,0,0,.24);
}
.mobile-menu.open{display:block;animation:fadeDown .22s ease}
.mobile-menu a{display:block;padding:14px 12px;color:rgba(255,255,255,.92);border-radius:12px;font-weight:700}
.mobile-menu a:hover,.mobile-menu a.is-active{background:rgba(255,255,255,.08);color:var(--orange)}
@keyframes fadeDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(135deg,#0F3D2E 0%, #1a5c42 50%, #0F3D2E 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='white' stroke-width='1'%3E%3Cpath d='M0 0H80V80H0z'/%3E%3Cpath d='M40 0V80M0 40H80'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 80px;
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;padding:96px 0 82px}
.hero-badge{margin-bottom:20px}
.hero-title{margin:0;font-size:clamp(40px,6vw,68px);line-height:1.04;font-weight:900;letter-spacing:-.05em}
.hero-title .accent{color:var(--orange)}
.hero-text{margin:22px 0 0;max-width:700px;color:rgba(255,255,255,.9);font-size:clamp(18px,2.2vw,21px)}
.hero-actions{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px}
.hero-stats{margin-top:56px;display:grid;grid-template-columns:1fr;gap:16px}
.stat{padding:18px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px)}
.stat strong{display:block;margin-bottom:8px;color:var(--orange);font-size:clamp(28px,3.6vw,38px);line-height:1;font-weight:900}
.stat span{color:rgba(255,255,255,.72);font-size:15px;font-weight:600}
.hero-visual{
  position:relative;border-radius:28px;overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);
}
.hero-visual img{width:100%;height:100%;object-fit:cover;min-height:320px;display:block}
.hero-card{
  position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border-radius:18px;
  background:rgba(15,61,46,.82);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(16px);
}
.hero-card strong{display:block;font-size:18px;font-weight:800;color:#fff}
.hero-card span{display:block;color:rgba(255,255,255,.8);font-size:14px}

/* PANELS, SPLIT, CARDS */
.split{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.panel{
  background:#fff;border:1px solid rgba(15,61,46,.08);border-radius:var(--radius);padding:32px;
  box-shadow:var(--shadow-sm);
}
.panel h3{
  margin:0 0 14px;font-size:clamp(24px,3vw,30px);line-height:1.15;font-weight:900;color:var(--green-900);
  letter-spacing:-.03em;
}
.panel p{margin:0 0 16px;color:var(--muted)}
.feature-list,.check-list{margin:0;padding:0;list-style:none;display:grid;gap:12px}
.feature-list li,.check-list li{position:relative;padding-left:28px;color:var(--text)}
.feature-list li::before,.check-list li::before{
  content:"";position:absolute;left:0;top:.58em;width:10px;height:10px;border-radius:50%;background:#9ed155;
  transform:translateY(-50%);
}
.visual-card{background:#fff;border:1px solid rgba(15,61,46,.08);border-radius:28px;overflow:hidden;box-shadow:var(--shadow-md)}
.visual-card img{width:100%;height:100%;object-fit:cover;display:block}
.visual-caption{padding:16px 20px;font-size:14px;color:var(--muted);border-top:1px solid rgba(15,61,46,.08);background:#fff}

/* FOOTER */
.site-footer{background:var(--footer);color:rgba(255,255,255,.8);padding:60px 0 30px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:36px;margin-bottom:36px}
.footer-title{margin:0 0 14px;color:#fff;font-size:18px;font-weight:800}
.footer-logo img{height:46px;width:auto;margin-bottom:16px;display:block}
.footer-payoff{margin:0 0 18px;max-width:320px;color:rgba(255,255,255,.78)}
.socials{display:flex;gap:12px}
.socials a{
  width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;
  border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.72);transition:all var(--transition);
}
.socials a:hover,.socials a:focus-visible{color:var(--orange);border-color:rgba(247,150,64,.5);background:rgba(247,150,64,.08);outline:none}
.socials svg{width:20px;height:20px}
.footer-links,.footer-contact{display:grid;gap:10px}
.footer-links a,.footer-contact a,.footer-contact span{color:rgba(255,255,255,.78);transition:color var(--transition)}
.footer-links a:hover,.footer-contact a:hover{color:var(--orange);outline:none}
.footer-divider{height:1px;background:rgba(255,255,255,.1);margin:20px 0 22px}
.footer-bottom{text-align:center;color:rgba(255,255,255,.6);font-size:14px}

/* ─────────── RENDER GALLERY (primo negozio) ─────────── */
.render-gallery{
  display:grid;grid-template-columns:1fr;gap:18px;margin-top:8px;
}
.render-card{
  position:relative;overflow:hidden;border-radius:22px;
  border:1px solid rgba(15,61,46,.08);box-shadow:var(--shadow-sm);
  background:#0F3D2E;
  transition:transform var(--transition), box-shadow var(--transition);
}
.render-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.render-card img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:16/10}
.render-card.tall img{aspect-ratio:4/5}
.render-card.wide img{aspect-ratio:21/9}
.render-tag{
  position:absolute;top:14px;left:14px;
  padding:8px 14px;border-radius:999px;
  background:rgba(15,61,46,.88);color:#fff;
  font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);
}
.render-tag .orange{color:var(--orange)}
.render-caption{
  position:absolute;bottom:14px;left:14px;right:14px;
  padding:14px 18px;border-radius:16px;
  background:rgba(15,61,46,.78);color:#fff;
  font-size:14px;font-weight:600;
  backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);
}

/* MATERIALS CARDS */
.materials-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:8px}
.material-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--transition), box-shadow var(--transition);
}
.material-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.material-swatch{
  height:200px;position:relative;
  background-size:cover;background-position:center;
}
.material-swatch.rovere{
  background-image:url('./assets/foggia-materials.jpg');
}
.material-swatch.antracite{
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0, transparent 1px, transparent 6px, rgba(0,0,0,.18) 7px),
    linear-gradient(180deg, #34373A 0%, #2C2E2D 60%, #1F2121 100%);
}
.material-swatch.green{
  background:linear-gradient(135deg, #0F3D2E 0%, #1a5c42 100%);
  display:grid;place-items:center;color:#fff;font-weight:900;letter-spacing:.04em;
}
.material-swatch.green::after{
  content:"BRAND COLOR";font-size:14px;font-family:'Inter',sans-serif;
  letter-spacing:.16em;
}
.material-info{padding:24px 26px 26px}
.material-code{
  display:inline-block;font-size:12px;font-weight:800;letter-spacing:.1em;
  color:var(--orange);text-transform:uppercase;margin-bottom:8px;
}
.material-name{margin:0 0 8px;font-size:24px;font-weight:900;color:var(--green-900);letter-spacing:-.02em}
.material-desc{margin:0;color:var(--muted);font-size:15px}

/* PLAN SECTION */
.plan-wrap{
  background:#fff;border:1px solid rgba(15,61,46,.08);border-radius:28px;
  overflow:hidden;box-shadow:var(--shadow-md);
}
.plan-wrap img{width:100%;height:auto;display:block;background:#0a0a0a}
.plan-meta{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
}
.plan-meta-cell{padding:20px 22px;border-right:1px solid var(--line)}
.plan-meta-cell:last-child{border-right:none}
.plan-meta-label{font-size:12px;font-weight:800;letter-spacing:.1em;color:var(--orange);text-transform:uppercase;margin-bottom:4px}
.plan-meta-value{font-size:22px;font-weight:900;color:var(--green-900);letter-spacing:-.02em}
.plan-meta-value .unit{font-size:14px;color:var(--muted);font-weight:600;letter-spacing:0;margin-left:4px}

/* ─────────── CATALOG ─────────── */
.catalog-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  margin-bottom:36px;padding:18px 22px;
  background:#fff;border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-sm);
}
.filter-row{display:flex;gap:8px;flex-wrap:wrap}
.filter-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;border:1px solid var(--line);
  background:#fff;color:var(--green-900);font-size:14px;font-weight:700;
  cursor:pointer;transition:all var(--transition);
}
.filter-chip:hover{border-color:var(--orange);color:var(--orange-600)}
.filter-chip.is-active{background:var(--green-900);color:#fff;border-color:var(--green-900)}
.filter-chip .count{
  font-size:11px;font-weight:800;letter-spacing:.05em;
  padding:2px 8px;border-radius:999px;
  background:rgba(15,61,46,.08);color:var(--green-900);
}
.filter-chip.is-active .count{background:rgba(255,255,255,.18);color:#fff}
.toolbar-note{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:800;letter-spacing:.05em;
  color:var(--orange);text-transform:uppercase;
}
.toolbar-note::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--orange);
}

.catalog-grid{display:grid;grid-template-columns:1fr;gap:20px}
.cat-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow-sm);cursor:pointer;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  display:flex;flex-direction:column;
}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--orange)}
.cat-card-img{
  aspect-ratio:4/3;position:relative;background:var(--soft);overflow:hidden;
  display:grid;place-items:center;
  background-image:
    linear-gradient(rgba(15,61,46,.03), rgba(15,61,46,.05)),
    repeating-linear-gradient(135deg, transparent 0 18px, rgba(15,61,46,.04) 18px 19px);
}
.cat-card-img svg{width:60%;height:65%;display:block}
.cat-code{
  position:absolute;top:14px;left:14px;
  padding:7px 12px;border-radius:8px;
  background:var(--green-900);color:#fff;
  font-size:11px;font-weight:800;letter-spacing:.08em;
  font-family:'Inter',monospace;
}
.cat-cat{
  position:absolute;top:14px;right:14px;
  padding:6px 12px;border-radius:999px;
  background:rgba(247,150,64,.14);color:var(--orange-600);
  font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid rgba(247,150,64,.3);
}
.cat-card-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.cat-name{margin:0;font-size:20px;font-weight:800;color:var(--green-900);letter-spacing:-.02em;line-height:1.2}
.cat-size{font-size:14px;color:var(--muted);font-weight:600}
.cat-desc{font-size:14px;color:var(--muted);margin:4px 0 0}
.cat-card-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;border-top:1px solid var(--line);background:var(--soft);
}
.cat-price{font-size:13px;font-weight:800;color:var(--green-900);letter-spacing:.04em;text-transform:uppercase}
.cat-cta{font-size:13px;font-weight:800;color:var(--orange);display:inline-flex;align-items:center;gap:6px;transition:gap var(--transition)}
.cat-card:hover .cat-cta{gap:10px}

/* CATALOG MODAL */
.modal-back{
  position:fixed;inset:0;background:rgba(15,61,46,.55);
  z-index:2000;backdrop-filter:blur(6px);display:grid;place-items:center;
  padding:24px;animation:fade .2s ease;
}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{
  background:#fff;border-radius:22px;max-width:920px;width:100%;
  max-height:90vh;overflow:auto;position:relative;
  display:grid;grid-template-columns:1fr;
  box-shadow:0 40px 80px rgba(0,0,0,.3);
  animation:slide .25s cubic-bezier(.2,.7,.2,1);
}
@keyframes slide{from{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}
.modal-close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:40px;height:40px;border-radius:999px;
  background:rgba(255,255,255,.92);border:1px solid var(--line);
  cursor:pointer;font-size:18px;color:var(--green-900);
  display:grid;place-items:center;
}
.modal-close:hover{background:var(--green-900);color:#fff}
.modal-img{
  aspect-ratio:1/1;background:var(--soft);position:relative;
  background-image:
    linear-gradient(rgba(15,61,46,.03), rgba(15,61,46,.05)),
    repeating-linear-gradient(135deg, transparent 0 18px, rgba(15,61,46,.04) 18px 19px);
  display:grid;place-items:center;
}
.modal-img svg{width:60%;height:60%}
.modal-img .cat-code{top:18px;left:18px}
.modal-info{padding:34px 34px 28px;display:flex;flex-direction:column;gap:14px}
.modal-info .cat-cat{position:static;align-self:flex-start}
.modal-info h3{margin:0;font-size:32px;font-weight:900;color:var(--green-900);letter-spacing:-.03em;line-height:1.1}
.modal-info p{margin:0;color:var(--muted)}
.spec-table{margin-top:6px;border-top:1px solid var(--line)}
.spec-row{
  display:grid;grid-template-columns:140px 1fr;padding:14px 0;
  border-bottom:1px solid var(--line);font-size:14px;align-items:start;
}
.spec-key{font-size:11px;font-weight:800;letter-spacing:.1em;color:var(--orange);text-transform:uppercase}
.spec-val{color:var(--text)}
.spec-val strong{color:var(--green-900);font-weight:800}
.modal-cta-row{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}

/* Page hero variant (smaller, for sub-pages) */
.page-hero{padding:64px 0 36px;color:#fff;background:linear-gradient(135deg,#0F3D2E 0%, #1a5c42 50%, #0F3D2E 100%);position:relative;overflow:hidden}
.page-hero::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='white' stroke-width='1'%3E%3Cpath d='M0 0H80V80H0z'/%3E%3Cpath d='M40 0V80M0 40H80'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 80px;
}
.page-hero-inner{position:relative;z-index:1;display:grid;gap:14px;max-width:860px}
.page-hero-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.page-hero-meta .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.5)}
.page-hero-title{margin:0;font-size:clamp(34px,5vw,52px);line-height:1.06;font-weight:900;letter-spacing:-.04em;color:#fff}
.page-hero-title .accent{color:var(--orange)}
.page-hero-text{margin:0;max-width:680px;color:rgba(255,255,255,.86);font-size:clamp(16px,2vw,19px)}

/* CTA banner section */
.cta-banner{padding:80px 0;background:linear-gradient(135deg, var(--green-900) 0%, var(--green-700) 100%);color:#fff;position:relative;overflow:hidden}
.cta-banner::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='white' stroke-width='1'%3E%3Cpath d='M0 0H80V80H0z'/%3E%3Cpath d='M40 0V80M0 40H80'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 80px;
}
.cta-banner-inner{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.cta-banner-title{margin:0;font-size:clamp(28px,4vw,40px);font-weight:900;line-height:1.12;letter-spacing:-.03em;max-width:820px}
.cta-banner-title .accent{color:var(--orange)}
.cta-banner-text{margin:0;max-width:660px;color:rgba(255,255,255,.86);font-size:17px}
.cta-banner-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:10px}

/* RESPONSIVE */
@media (min-width:769px){
  .nav-links{display:flex}
  .hamburger,.mobile-menu{display:none !important}
  .hero-grid{grid-template-columns:1.08fr .92fr;gap:42px}
  .hero-stats{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr}
  .render-gallery{grid-template-columns:repeat(12,1fr);gap:20px}
  .render-gallery .r-big{grid-column:span 8}
  .render-gallery .r-tall{grid-column:span 4}
  .render-gallery .r-mid{grid-column:span 6}
  .render-gallery .r-wide{grid-column:span 12}
  .materials-grid{grid-template-columns:repeat(3,1fr)}
  .catalog-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1.2fr 1fr 1fr}
  .modal{grid-template-columns:1.1fr 1fr}
}
@media (min-width:1024px){
  .catalog-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1280px){
  .catalog-grid.dense{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:768px){
  :root{--nav-height:80px}
  .brand img{height:40px}
  .nav-right .btn{padding:13px 18px;font-size:14px}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
  .section{padding:64px 0}
  .render-gallery .r-big img,.render-gallery .r-tall img,.render-gallery .r-mid img,.render-gallery .r-wide img{aspect-ratio:4/3}
  .plan-meta{grid-template-columns:1fr;}
  .plan-meta-cell{border-right:none;border-bottom:1px solid var(--line)}
  .plan-meta-cell:last-child{border-bottom:none}
}
