/* ============================================================
   HANDCRAFTBANDIT — Irish Belt House
   Quiet-luxury homepage system
   ============================================================ */

:root{
  /* Paper & ink */
  --paper:      #F7F3EC;
  --paper-2:    #F0E9DC;   /* alt section ground */
  --paper-line: rgba(26,26,26,.13);
  --ink:        #1A1A1A;
  --ink-70:     rgba(26,26,26,.70);
  --ink-55:     rgba(26,26,26,.55);

  /* Accents */
  --oxblood:    #6A1F1B;
  --oxblood-dk: #561714;
  --brass:      #8A6A44;
  --brass-lt:   #A6855C;

  /* Dark oak grounds */
  --oak-900:    #16110D;
  --oak-850:    #1D1611;
  --oak-800:    #241B14;
  --oak-line:   rgba(237,228,214,.16);
  --cream:      #EDE4D6;
  --cream-70:   rgba(237,228,214,.72);
  --cream-50:   rgba(237,228,214,.52);

  /* Type */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Jost", system-ui, -apple-system, sans-serif;
  --mono:  ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

  --measure: 62ch;
  --pad: clamp(20px, 5.5vw, 88px);
  --maxw: 1280px;

  --ease: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:clamp(15px, .55vw + 13px, 17.5px);
  line-height:1.78;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--oxblood); color:var(--paper); }

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block: clamp(72px, 11vw, 168px); }
.section--tight{ padding-block: clamp(56px, 8vw, 120px); }

.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:12px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--brass);
  margin:0 0 clamp(20px,3vw,34px);
  display:flex; align-items:center; gap:14px;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--brass); opacity:.8;
}
.eyebrow--center{ justify-content:center; }
.eyebrow--center::after{
  content:""; width:34px; height:1px; background:var(--brass); opacity:.8;
}
.on-dark .eyebrow{ color:var(--brass-lt); }
.on-dark .eyebrow::before,.on-dark .eyebrow--center::after{ background:var(--brass-lt); }

/* ---------- Headlines ---------- */
.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.02;
  letter-spacing:-.012em;
  margin:0;
}
h1.display{ font-size:clamp(54px, 11vw, 142px); }
h2.display{ font-size:clamp(33px, 5.4vw, 70px); line-height:1.05; }
h3.display{ font-size:clamp(24px, 2.6vw, 36px); }
.display em{ font-style:italic; color:var(--brass); }
.lede{
  font-family:var(--serif);
  font-size:clamp(20px, 2.1vw, 28px);
  line-height:1.5;
  font-weight:400;
  color:var(--ink-70);
  max-width:34ch;
}
.body-copy{ max-width:var(--measure); color:var(--ink-70); }
.body-copy p + p{ margin-top:1.25em; }
.on-dark{ color:var(--cream); }
.on-dark .body-copy{ color:var(--cream-70); }
.on-dark .lede{ color:var(--cream-70); }

/* ---------- Buttons ---------- */
.actions{ display:flex; flex-wrap:wrap; gap:14px 22px; align-items:center; }
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:500;
  font-size:12.5px; letter-spacing:.2em; text-transform:uppercase;
  padding:1.15em 2.1em;
  border:1px solid transparent;
  cursor:pointer; background:none; white-space:nowrap;
  transition:background .5s var(--ease), color .5s var(--ease),
             border-color .5s var(--ease), transform .5s var(--ease);
}
.btn:hover{ transform:translateY(-2px); }
.btn--primary{ background:var(--oxblood); color:var(--paper); border-color:var(--oxblood); }
.btn--primary:hover{ background:var(--oxblood-dk); border-color:var(--oxblood-dk); }
.btn--ghost{ border-color:var(--paper-line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); }
.btn--ghost-light{ border-color:var(--oak-line); color:var(--cream); }
.btn--ghost-light:hover{ border-color:var(--cream); }
.btn--arrow::after{ content:"\2192"; font-size:1.1em; transition:transform .5s var(--ease); }
.btn--arrow:hover::after{ transform:translateX(5px); }

/* text link with drawn underline */
.tlink{
  font-family:var(--sans); font-weight:500; font-size:12.5px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink);
  display:inline-flex; align-items:center; gap:.6em;
  position:relative; padding-bottom:4px;
}
.tlink::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .55s var(--ease);
}
.tlink:hover::after{ transform:scaleX(1); }
.tlink .ar{ transition:transform .5s var(--ease); }
.tlink:hover .ar{ transform:translateX(5px); }
.on-dark .tlink{ color:var(--cream); }

/* ============================================================
   IMAGE PLACEHOLDERS  (warm, lit gradient frames)
   ============================================================ */
.ph{
  position:relative; margin:0; overflow:hidden;
  background:var(--paper-2);
  border:1px solid var(--paper-line);
  display:flex; align-items:flex-end; justify-content:flex-start;
  isolation:isolate;
}
.ph::after{ /* film grain / sheen */
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.018) 0 2px, transparent 2px 7px);
  mix-blend-mode:multiply; opacity:.7;
}
.ph__note{
  position:relative; z-index:2;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink-55);
  padding:14px 16px; margin:14px;
  border:1px solid var(--paper-line); background:rgba(247,243,236,.6);
  backdrop-filter:blur(2px); max-width:min(86%,300px); line-height:1.5;
}
/* light/warm variant */
.ph--warm{
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(166,133,92,.45), transparent 55%),
    radial-gradient(90% 80% at 20% 90%, rgba(106,31,27,.16), transparent 60%),
    linear-gradient(150deg, #EFE6D6, #E4D6BF 60%, #D8C6A8);
}
/* dark oak / whiskey-lit variant */
.ph--oak{
  background:
    radial-gradient(120% 95% at 72% 28%, rgba(196,140,74,.50), transparent 50%),
    radial-gradient(90% 90% at 30% 95%, rgba(106,31,27,.40), transparent 60%),
    linear-gradient(160deg, #2A1F16, #1A130D 70%, #120C08);
  border-color:rgba(237,228,214,.12);
}
.ph--oak .ph__note{
  color:var(--cream-50); border-color:var(--oak-line);
  background:rgba(20,15,11,.45);
}
.ph--oak::after{ background:
  repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 2px, transparent 2px 8px);
  mix-blend-mode:screen; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--pad);
  color:var(--cream);
  transition:background .6s var(--ease), color .5s var(--ease),
             padding .5s var(--ease), box-shadow .6s var(--ease),
             border-color .6s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(247,243,236,.92);
  backdrop-filter:saturate(120%) blur(10px);
  color:var(--ink);
  border-bottom-color:var(--paper-line);
  padding-block:13px;
}
.brand{
  font-family:var(--sans); font-weight:500;
  letter-spacing:.32em; text-transform:uppercase;
  font-size:14px;
}
.brand b{ font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:clamp(20px,2.4vw,40px); }
.nav-links a{
  font-family:var(--sans); font-weight:400; font-size:12.5px;
  letter-spacing:.16em; text-transform:uppercase;
  position:relative; padding:6px 0; opacity:.92;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:center;
  transition:transform .5s var(--ease);
}
.nav-links a:hover{ opacity:1; }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-cta{ border:1px solid currentColor; padding:.7em 1.4em !important; opacity:1 !important; }
.nav-cta::after{ display:none; }

.menu-toggle{
  display:none; background:none; border:0; cursor:pointer;
  font-family:var(--sans); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; color:inherit; align-items:center; gap:10px;
}
.menu-toggle .bars{ display:inline-block; width:24px; height:9px; position:relative; }
.menu-toggle .bars::before,.menu-toggle .bars::after{
  content:""; position:absolute; left:0; width:24px; height:1.5px; background:currentColor;
  transition:transform .4s var(--ease), top .4s var(--ease);
}
.menu-toggle .bars::before{ top:0; }
.menu-toggle .bars::after{ top:7px; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:70; background:var(--oak-900); color:var(--cream);
  display:flex; flex-direction:column; justify-content:center;
  padding:var(--pad); gap:6px;
  transform:translateY(-100%); transition:transform .7s var(--ease);
}
.drawer.open{ transform:none; }
.drawer a{
  font-family:var(--serif); font-size:clamp(30px,9vw,46px); line-height:1.25;
  letter-spacing:-.01em; padding:8px 0; border-bottom:1px solid var(--oak-line);
}
.drawer .drawer-close{
  position:absolute; top:20px; right:var(--pad); background:none; border:0; cursor:pointer;
  color:var(--cream); font-family:var(--sans); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase;
}
.drawer .drawer-foot{
  margin-top:36px; font-family:var(--sans); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--cream-50); border:0;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  color:var(--cream); overflow:hidden; isolation:isolate;
}
.hero__bg{
  position:absolute; inset:-8% -4% -4%; z-index:-2; will-change:transform;
  background:#100B07 url("assets/hero.png") center / cover no-repeat;
}
.hero__vignette{
  position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    linear-gradient(96deg, rgba(8,5,3,.90) 0%, rgba(8,5,3,.66) 32%, rgba(8,5,3,.22) 56%, rgba(8,5,3,0) 78%),
    linear-gradient(0deg, rgba(8,5,3,.72) 0%, rgba(8,5,3,0) 34%),
    radial-gradient(120% 130% at 50% 30%, transparent 46%, rgba(5,3,2,.5) 100%);
}
@media (max-width: 760px){
  .hero__bg{ background-position:62% center; }
  .hero__vignette{ background:
    linear-gradient(0deg, rgba(8,5,3,.84) 8%, rgba(8,5,3,.4) 52%, rgba(8,5,3,.62) 100%); }
}
.hero__note{
  position:absolute; right:var(--pad); bottom:24px; z-index:2;
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--cream-50); max-width:240px; text-align:right; line-height:1.6;
}
.hero__inner{ position:relative; z-index:1; padding-block:140px 90px; }
.hero h1{ margin:.06em 0 0; }
.hero__sub{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(22px,3vw,38px); color:var(--brass-lt); margin:.2em 0 0;
}
.hero__support{ margin:clamp(26px,3vw,38px) 0 0; max-width:46ch; color:var(--cream-70);
  font-size:clamp(15px,1.1vw,18px); }
.hero__tagline{
  font-family:var(--serif); font-size:clamp(19px,1.8vw,24px); font-style:italic;
  margin:18px 0 0; color:var(--cream);
  padding-left:18px; border-left:1px solid var(--brass);
}
.hero .actions{ margin-top:clamp(34px,4vw,46px); }
.scrollcue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  font-family:var(--sans); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--cream-50); display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scrollcue .line{ width:1px; height:46px; background:linear-gradient(var(--brass-lt),transparent); }
@media (prefers-reduced-motion: no-preference){
  .scrollcue .line{ animation:cuepulse 2.6s var(--ease) infinite; transform-origin:top; }
}
@keyframes cuepulse{ 0%,100%{ transform:scaleY(.4); opacity:.4 } 50%{ transform:scaleY(1); opacity:1 } }

/* ============================================================
   PHILOSOPHY
   ============================================================ */
.philosophy .grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,6vw,90px);
  align-items:center;
}
.philosophy .ph{ aspect-ratio:4/5; }
.statement{ font-family:var(--serif); font-weight:500; line-height:1.08;
  font-size:clamp(30px,4.4vw,58px); letter-spacing:-.012em; margin:0 0 clamp(26px,3vw,40px); }
.statement em{ font-style:italic; color:var(--brass); }

/* ============================================================
   COLLECTION
   ============================================================ */
.collection{ background:var(--paper-2); }
.coll-head{ display:flex; justify-content:space-between; align-items:flex-end;
  gap:24px; flex-wrap:wrap; margin-bottom:clamp(40px,5vw,70px); }
.coll-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,46px); }
.card{ position:relative; }
.card__media{ aspect-ratio:3/4; margin-bottom:26px; }
.card__media .ph{ width:100%; height:100%; transition:transform 1s var(--ease); }
.card:hover .card__media .ph{ transform:scale(1.025); }
.card__no{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--brass);
  margin-bottom:10px; }
.card h3{ margin:0 0 12px; }
.card .body-copy{ font-size:14.5px; }
.card .card__foot{ margin-top:20px; display:flex; justify-content:space-between;
  align-items:center; gap:16px; padding-top:18px; border-top:1px solid var(--paper-line); }
.card .price{ font-family:var(--serif); font-size:20px; color:var(--ink); }
.card .price span{ font-family:var(--sans); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-55); display:block; }
.card--flagship .card__no{ color:var(--oxblood); }

/* ============================================================
   MAKER'S STORY
   ============================================================ */
.maker .grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,96px);
  align-items:center; }
.maker .ph{ aspect-ratio:4/5; }
.pullquote{
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(24px,2.8vw,36px); line-height:1.3; letter-spacing:-.01em;
  margin:clamp(30px,4vw,46px) 0 0; padding-left:22px;
  border-left:2px solid var(--oxblood); color:var(--ink);
}

/* ============================================================
   WORKSHOP
   ============================================================ */
.workshop{ background:var(--paper-2); }
.workshop .ws-head{ max-width:680px; margin:0 auto clamp(44px,5vw,72px); text-align:center; }
.ws-grid{
  display:grid; gap:clamp(12px,1.4vw,20px);
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:minmax(120px,auto);
}
.ws-grid .ph{ width:100%; height:100%; }
.ws-grid .g1{ grid-column:span 4; grid-row:span 2; }
.ws-grid .g2{ grid-column:span 2; grid-row:span 1; }
.ws-grid .g3{ grid-column:span 2; grid-row:span 1; }
.ws-grid .g4{ grid-column:span 2; grid-row:span 1; }
.ws-grid .g5{ grid-column:span 4; grid-row:span 1; }

/* ============================================================
   LIFETIME REPAIRS  (dark)
   ============================================================ */
.repairs{ background:var(--oak-900); color:var(--cream); position:relative; overflow:hidden; }
.repairs .grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px);
  align-items:center; }
.repairs .ph{ aspect-ratio:5/4; }
.repairs .seal{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass-lt); display:inline-flex; align-items:center; gap:12px; margin-top:30px;
}
.repairs .seal::before{ content:""; width:30px; height:1px; background:var(--brass-lt); }

/* ============================================================
   LIMITED PRODUCTION
   ============================================================ */
.limited{ text-align:center; }
.limited .inner{ max-width:760px; margin-inline:auto; }
.limited .body-copy{ margin-inline:auto; }
.bignum{
  font-family:var(--serif); font-weight:500; line-height:.9;
  font-size:clamp(120px,22vw,300px); color:var(--oxblood);
  letter-spacing:-.03em; margin:clamp(30px,4vw,54px) 0 8px;
}
.bignum-cap{ font-family:var(--sans); font-size:12px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--ink-55); }

/* ============================================================
   LEATHER GOODS
   ============================================================ */
.goods{ background:var(--paper-2); }
/* Three companions (Wallet · Card Holder · A5 Notepad Sleeve) — three-up like the Collection */
.goods-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,46px); }
.goods .card__media{ aspect-ratio:3/4; }

/* ============================================================
   JOURNAL
   ============================================================ */
.journal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,46px); }
.article .a-media{ aspect-ratio:3/2; margin-bottom:22px; }
.article .a-media .ph{ width:100%; height:100%; transition:transform 1s var(--ease); }
.article:hover .a-media .ph{ transform:scale(1.03); }
.article .a-cat{ font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--brass); margin-bottom:10px; }
.article h3{ margin:0 0 12px; font-size:clamp(22px,2vw,28px); }
.article p{ color:var(--ink-70); font-size:14.5px; margin:0; }

/* ============================================================
   EMAIL
   ============================================================ */
.signup{ background:var(--paper-2); }
.signup .inner{ max-width:720px; margin-inline:auto; text-align:center; }
.signup .perks{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px 26px;
  margin:24px 0 36px; }
.signup .perks li{ list-style:none; font-family:var(--sans); font-size:11.5px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-55);
  display:flex; align-items:center; gap:10px; }
.signup .perks li::before{ content:""; width:5px; height:5px; background:var(--brass);
  border-radius:50%; }
.eform{ display:flex; gap:0; max-width:520px; margin-inline:auto;
  border-bottom:1px solid var(--ink); }
.eform input{
  flex:1; border:0; background:none; padding:14px 4px;
  font-family:var(--serif); font-size:20px; color:var(--ink);
}
.eform input::placeholder{ color:var(--ink-55); }
.eform input:focus{ outline:none; }
.eform button{
  background:none; border:0; cursor:pointer; padding:0 6px;
  font-family:var(--sans); font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--oxblood); display:flex; align-items:center; gap:.6em; white-space:nowrap;
}
.eform button .ar{ transition:transform .5s var(--ease); }
.eform button:hover .ar{ transform:translateX(5px); }
.eform-note{ font-family:var(--sans); font-size:11px; letter-spacing:.06em;
  color:var(--ink-55); margin-top:16px; }
.eform.sent{ border-color:var(--brass); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--oak-900); color:var(--cream); padding-block:clamp(64px,8vw,110px) 40px; }
.footer .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:clamp(40px,5vw,64px); border-bottom:1px solid var(--oak-line); }
.footer .brand-block .fbrand{ font-family:var(--serif); font-size:clamp(30px,3.6vw,46px);
  line-height:1.05; margin:0 0 18px; }
.footer .brand-block p{ color:var(--cream-70); max-width:34ch; font-size:14.5px; margin:0; }
.footer .brand-block .loc{ font-family:var(--mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--brass-lt); margin-top:22px; }
.footer .col h4{ font-family:var(--sans); font-weight:500; font-size:11px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--cream-50); margin:0 0 18px; }
.footer .col a{ display:block; color:var(--cream-70); font-size:14.5px; padding:6px 0;
  transition:color .4s var(--ease); }
.footer .col a:hover{ color:var(--cream); }
.footer .bottom{ display:flex; justify-content:space-between; align-items:center;
  gap:20px; flex-wrap:wrap; padding-top:30px; }
.footer .bottom span{ font-family:var(--sans); font-size:11px; letter-spacing:.1em;
  color:var(--cream-50); }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(26px);
    transition:opacity 1.15s var(--ease), transform 1.15s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
  .stagger > *{ opacity:0; transform:translateY(26px);
    transition:opacity 1.05s var(--ease), transform 1.05s var(--ease); }
  .stagger.in > *{ opacity:1; transform:none; }
  .stagger.in > *:nth-child(2){ transition-delay:.12s; }
  .stagger.in > *:nth-child(3){ transition-delay:.24s; }
  .stagger.in > *:nth-child(4){ transition-delay:.36s; }
  .stagger.in > *:nth-child(5){ transition-delay:.48s; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .nav-links{ display:none; }
  .menu-toggle{ display:inline-flex; }
  .philosophy .grid,
  .maker .grid,
  .repairs .grid{ grid-template-columns:1fr; gap:clamp(28px,6vw,44px); }
  .philosophy .ph,.maker .ph{ aspect-ratio:16/11; }
  .coll-grid{ grid-template-columns:1fr; max-width:460px; }
  .goods-grid{ grid-template-columns:1fr; max-width:480px; }
  .journal-grid{ grid-template-columns:1fr; max-width:460px; }
  .ws-grid{ grid-template-columns:repeat(2,1fr); }
  .ws-grid .g1{ grid-column:span 2; grid-row:span 1; aspect-ratio:16/10; }
  .ws-grid .g5{ grid-column:span 2; }
  .footer .top{ grid-template-columns:1fr 1fr; }
  .footer .brand-block{ grid-column:1 / -1; }
}
@media (max-width: 560px){
  .footer .top{ grid-template-columns:1fr; }
  .hero__note{ display:none; }
  .actions .btn{ width:100%; justify-content:center; }
  .eform{ flex-wrap:wrap; }
}
