:root{
  --bone:#F2EBDD;
  --paper:#FBF7EE;
  --ink:#221C14;
  --ink-soft:#6A6052;
  --red:#B22B1C;
  --red-deep:#8C2013;
  --sand:#DDCBA6;
  --tan:#C2A36F;
  --line:rgba(34,28,20,.13);
  --shadow:0 1px 2px rgba(34,28,20,.04), 0 14px 40px -22px rgba(34,28,20,.28);
  --display:"Fraunces", Georgia, serif;
  --body:"Hanken Grotesk", system-ui, sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--bone);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* subtle woven thread texture over the whole page */
body::before{
  content:"";
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(90deg, rgba(34,28,20,.022) 0 1px, transparent 1px 7px),
    repeating-linear-gradient(0deg, rgba(34,28,20,.022) 0 1px, transparent 1px 7px);
  opacity:.7;
}
/* ---------- PAGE LOADER ---------- */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bone);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .55s cubic-bezier(.4,0,.2,1), visibility .55s cubic-bezier(.4,0,.2,1);
}
#loader::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(90deg,rgba(34,28,20,.022) 0 1px,transparent 1px 7px),
    repeating-linear-gradient(0deg,rgba(34,28,20,.022) 0 1px,transparent 1px 7px);
}
#loader.ldr-done{opacity:0;visibility:hidden;pointer-events:none}
.ldr-inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:36px;
}
.ldr-brand{
  font-family:var(--display);font-size:2.8rem;font-weight:600;
  letter-spacing:-.02em;color:var(--ink);
  display:flex;align-items:center;gap:14px;
}
.ldr-brand .chip{width:52px;height:52px;font-size:1.15rem}
.ldr-threads{display:flex;flex-direction:column;gap:9px;width:160px}
.ldr-threads span{
  position:relative;display:block;height:2px;
  background:rgba(34,28,20,.1);border-radius:1px;overflow:hidden;
}
.ldr-threads span::after{
  content:"";position:absolute;inset-block:0;
  width:55%;left:-55%;
  background:linear-gradient(90deg,transparent,var(--red) 45%,var(--tan));
  border-radius:1px;
  animation:ldr-scan 1.5s cubic-bezier(.4,0,.6,1) infinite;
}
.ldr-threads span:nth-child(1)::after{animation-delay:0s}
.ldr-threads span:nth-child(2)::after{animation-delay:.13s}
.ldr-threads span:nth-child(3)::after{animation-delay:.26s}
.ldr-threads span:nth-child(4)::after{animation-delay:.39s}
.ldr-threads span:nth-child(5)::after{animation-delay:.52s}
.ldr-threads span:nth-child(6)::after{animation-delay:.65s}
@keyframes ldr-scan{
  0%  {left:-55%;opacity:0}
  8%  {opacity:1}
  85% {left:100%;opacity:1}
  86% {left:-55%;opacity:0}
  100%{left:-55%;opacity:0}
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:1}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-.01em;margin:0}
.eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--red);margin:0 0 14px}

/* ---------- HEADER ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(242,235,221,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:1.5rem;font-weight:600;letter-spacing:-.02em}
.chip{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:var(--red);color:#fff;font-weight:700;font-size:1.02rem;
  font-family:var(--body);letter-spacing:.01em;
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.18), 0 4px 12px -4px rgba(140,32,19,.6);
  position:relative;
}
.chip::after{
  content:"";position:absolute;inset:3px;border-radius:50%;
  background:repeating-conic-gradient(from 0deg, transparent 0 30deg, rgba(255,255,255,.12) 30deg 31deg);
}
.navlinks{display:flex;align-items:center;gap:34px;font-weight:500;font-size:.95rem}
.navlinks a{position:relative;color:var(--ink-soft);transition:color .2s}
.navlinks a:hover{color:var(--ink)}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--red);transition:width .25s}
.navlinks a:hover::after{width:100%}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:600;font-size:.95rem;
  padding:12px 22px;border-radius:999px;cursor:pointer;border:none;
  transition:transform .18s, box-shadow .18s, background .18s;
}
.btn-wa{background:var(--ink);color:var(--bone)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 12px 26px -12px rgba(34,28,20,.7)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{transform:translateY(-2px);background:var(--red-deep)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bone)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.25s}
.wa-mobile{display:none}

/* ---------- HERO ---------- */
.hero{position:relative;padding:88px 0 70px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.7rem,6vw,5rem)}
.hero h1 em{font-style:italic;color:var(--red)}
.hero .lead{font-size:1.16rem;color:var(--ink-soft);max-width:34ch;margin:24px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-since{margin-top:38px;display:flex;align-items:center;gap:16px;color:var(--ink-soft);font-size:.92rem}
.hero-since .yr{font-family:var(--display);font-size:2.6rem;color:var(--ink);line-height:1}
.hero-art{
  position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow);border:1px solid var(--line);
  background:
    linear-gradient(135deg, var(--sand), #efe6d2 55%, var(--tan));
}
.hero-art .weave{position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(90deg, rgba(140,32,19,.10) 0 2px, transparent 2px 11px),
    repeating-linear-gradient(0deg, rgba(34,28,20,.12) 0 2px, transparent 2px 11px);
  mix-blend-mode:multiply;}
.hero-bg-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.hero-art .stamp{
  position:absolute;right:18px;bottom:18px;width:108px;height:108px;border-radius:50%;
  background:var(--red);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--display);box-shadow:0 14px 34px -12px rgba(140,32,19,.7);
}
.hero-art .stamp b{font-size:2.6rem;line-height:.9}
.hero-art .stamp span{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--body);font-weight:600;margin-top:4px;opacity:.9}

/* ---------- TRUST STRIP ---------- */
.strip{border-block:1px solid var(--line);background:var(--paper)}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.strip-grid div{padding:26px 22px;border-left:1px solid var(--line)}
.strip-grid div:first-child{border-left:none}
.strip-ic{display:block;margin-bottom:12px;color:var(--red);line-height:1;font-size:1.3rem}
.strip b{font-family:var(--display);font-size:1.5rem;display:block}
.strip p{margin:4px 0 0;font-size:.9rem;color:var(--ink-soft)}

/* ---------- SECTION SHELL ---------- */
section{padding:88px 0;position:relative}
.sec-head{max-width:60ch;margin-bottom:46px}
.sec-head h2{font-size:clamp(2rem,4vw,3.1rem)}
.sec-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:16px}

/* ---------- PRODUCTS ---------- */
.cat-title{display:flex;align-items:baseline;gap:16px;margin:50px 0 24px}
.cat-title h3{font-size:1.7rem}
.cat-title .tag{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;
  border:1px solid var(--line);padding:5px 12px;border-radius:999px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .25s, box-shadow .25s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(34,28,20,.5)}
.swatch{aspect-ratio:5/4;position:relative;background:var(--sand)}
.card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.modal-photo{width:100%;height:100%;object-fit:cover;display:block}
.swatch .soon{
  position:absolute;top:12px;left:12px;background:rgba(251,247,238,.92);color:var(--ink-soft);
  font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  padding:5px 10px;border-radius:999px;border:1px solid var(--line);
}
.swatch .best{
  position:absolute;top:12px;right:12px;background:var(--red);color:#fff;
  font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;
  padding:5px 10px;border-radius:999px;
}
/* weave patterns as fabric stand-ins until real photos exist */
.w-plain{background:
  repeating-linear-gradient(0deg,rgba(34,28,20,.07) 0 1px,transparent 1px 5px),
  repeating-linear-gradient(90deg,rgba(34,28,20,.07) 0 1px,transparent 1px 5px),linear-gradient(135deg,#e9ddc4,#ddcba6)}
.w-honey{background:
  repeating-linear-gradient(0deg,rgba(34,28,20,.12) 0 2px,transparent 2px 14px),
  repeating-linear-gradient(90deg,rgba(34,28,20,.12) 0 2px,transparent 2px 14px),linear-gradient(135deg,#eee2c8,#dccba2)}
.w-stripe{background:repeating-linear-gradient(90deg,#d9c49a 0 10px,#cdb487 10px 12px,#e7dcc3 12px 22px)}
.w-check{background:
  repeating-linear-gradient(0deg,rgba(140,32,19,.18) 0 11px,transparent 11px 22px),
  repeating-linear-gradient(90deg,rgba(140,32,19,.18) 0 11px,transparent 11px 22px),linear-gradient(135deg,#ecdfc6,#dccaa3)}
.w-gauze{background:
  repeating-linear-gradient(0deg,rgba(34,28,20,.05) 0 1px,transparent 1px 9px),
  repeating-linear-gradient(90deg,rgba(34,28,20,.05) 0 1px,transparent 1px 9px),linear-gradient(135deg,#f4ecda,#e8ddc4)}
.w-rafia{background:
  repeating-linear-gradient(45deg,rgba(34,28,20,.09) 0 2px,transparent 2px 8px),linear-gradient(135deg,#e4d4ad,#cdb079)}
.w-dobby{background:
  repeating-linear-gradient(0deg,rgba(34,28,20,.10) 0 2px,transparent 2px 9px),
  repeating-linear-gradient(90deg,rgba(34,28,20,.10) 0 3px,transparent 3px 16px),linear-gradient(135deg,#e7dabd,#d3bd8d)}
.w-crudo{background:linear-gradient(135deg,#e8ddc3,#d8c7a0);
  background-image:repeating-linear-gradient(90deg,rgba(34,28,20,.05) 0 1px,transparent 1px 6px),linear-gradient(135deg,#e8ddc3,#d8c7a0)}
.w-black{background:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 1px,transparent 1px 6px),linear-gradient(135deg,#2b261f,#171310)}
.w-blackstripe{background:repeating-linear-gradient(90deg,#1c1813 0 10px,#332b21 10px 12px,#211c14 12px 22px)}
.card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.card-body h4{font-family:var(--display);font-size:1.22rem;margin:0 0 4px}
.card-body .spec{font-size:.88rem;color:var(--ink-soft);margin:0 0 16px;flex:1}
.card-body .spec b{color:var(--ink);font-weight:600}
.card-cta{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:var(--red);
  align-self:flex-start;padding:9px 0;border-bottom:1.5px solid transparent;transition:border-color .2s}
.card-cta:hover{border-color:var(--red)}

/* ---------- NOSOTROS (dark) ---------- */
.nosotros{background:var(--ink);color:var(--bone)}
.nosotros .eyebrow{color:var(--tan)}
.nosotros-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.nosotros h2{font-size:clamp(2rem,4vw,3rem);color:var(--paper)}
.nosotros p{color:rgba(242,235,221,.78);font-size:1.05rem;margin-top:18px}
.values{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.values span{border:1px solid rgba(242,235,221,.22);border-radius:999px;padding:10px 20px;font-weight:500;font-size:.95rem}
.timeline{display:grid;gap:22px}
.tl{display:grid;grid-template-columns:84px 1fr;gap:20px;padding:20px 0;border-bottom:1px solid rgba(242,235,221,.14)}
.tl:last-child{border-bottom:none}
.tl .yr{font-family:var(--display);font-size:1.7rem;color:var(--tan)}
.tl h5{margin:0 0 4px;font-size:1.05rem;font-family:var(--body);font-weight:600}
.tl p{margin:0;font-size:.92rem;color:rgba(242,235,221,.7)}

/* ---------- COMO COMPRAR ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{position:relative;padding:30px 22px;background:var(--paper);border:1px solid var(--line);border-radius:16px}
.step::before{counter-increment:s;content:counter(s);font-family:var(--display);font-size:2.4rem;color:var(--red);display:block;line-height:1;margin-bottom:14px}
.step h4{font-family:var(--body);font-weight:600;font-size:1.05rem;margin:0 0 6px}
.step p{margin:0;font-size:.92rem;color:var(--ink-soft)}

/* ---------- CONTACTO ---------- */
.contacto{background:var(--paper);border-top:1px solid var(--line)}
.cont-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-bottom:32px}
.cont-list{display:grid;gap:4px;margin-top:30px}
.cont-item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.cont-item .ic{width:42px;height:42px;border-radius:11px;background:var(--bone);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--line);font-size:1.1rem}
.cont-item small{display:block;color:var(--ink-soft);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.cont-item b{font-family:var(--display);font-size:1.18rem;font-weight:500}
.map-embed{border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.map-embed iframe{display:block;width:100%;height:360px;border:0}
.cont-card{background:var(--ink);color:var(--bone);border-radius:18px;padding:38px;box-shadow:var(--shadow)}
.cont-card h3{color:var(--paper);font-size:1.7rem}
.cont-card p{color:rgba(242,235,221,.78);margin:14px 0 26px}
.field{display:block;margin-bottom:16px}
.field label{font-size:.82rem;color:rgba(242,235,221,.7);display:block;margin-bottom:7px;font-weight:500}
.field input,.field textarea{
  width:100%;background:rgba(242,235,221,.06);border:1px solid rgba(242,235,221,.2);
  color:var(--bone);border-radius:10px;padding:12px 14px;font-family:var(--body);font-size:.96rem;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--tan)}
.field textarea{resize:vertical;min-height:84px}

/* ---------- FOOTER ---------- */
footer{background:var(--bone);border-top:1px solid var(--line);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:36px}
.foot-grid p{color:var(--ink-soft);font-size:.92rem;margin:14px 0 0;max-width:38ch}
.foot-grid h6{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 16px;font-weight:700}
.foot-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:.95rem;color:var(--ink-soft)}
.foot-grid ul a:hover{color:var(--red)}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem;color:var(--ink-soft)}

/* ---------- REVEAL ANIM ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
.hero h1,.hero .lead,.hero-cta,.hero-since{opacity:0;animation:up .8s ease forwards}
.hero h1{animation-delay:.05s}.hero .lead{animation-delay:.2s}.hero-cta{animation-delay:.34s}.hero-since{animation-delay:.48s}
.hero-art{opacity:0;animation:up .9s ease .25s forwards}
@keyframes up{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* ---------- MODAL PRODUCTO ---------- */
.card{cursor:pointer}
.card:hover .card-cta{border-color:var(--red)}
.modal-overlay{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(20,16,11,.55);backdrop-filter:blur(6px)}
.modal-overlay.open{display:flex;animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{position:relative;width:100%;max-width:920px;max-height:90vh;overflow:auto;background:var(--paper);
  border-radius:20px;border:1px solid var(--line);box-shadow:0 40px 90px -30px rgba(20,16,11,.7);
  display:grid;grid-template-columns:1.05fr .95fr;animation:pop .3s cubic-bezier(.2,.8,.3,1)}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:14px;right:14px;z-index:2;width:40px;height:40px;border-radius:50%;border:none;
  background:rgba(251,247,238,.92);color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:var(--shadow);transition:.25s}
.modal-close:hover{background:var(--ink);color:var(--bone);transform:rotate(90deg)}
.modal-gallery{padding:22px;display:flex;flex-direction:column;gap:14px;background:var(--bone);
  border-right:1px solid var(--line);border-radius:20px 0 0 20px}
.modal-main{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid var(--line);background-color:var(--sand)}
.modal-thumbs{display:flex;gap:10px}
.mthumb{flex:1;aspect-ratio:1;border-radius:10px;border:2px solid transparent;cursor:pointer;overflow:hidden;padding:0;
  background-color:var(--sand);transition:border-color .2s,transform .2s}
.mthumb:hover{transform:translateY(-2px)}
.mthumb.active{border-color:var(--red)}
.modal-info{padding:42px 36px 34px;display:flex;flex-direction:column}
.modal-info .eyebrow{margin-bottom:10px}
.modal-info h3{font-size:clamp(1.7rem,3vw,2.2rem)}
.modal-spec{color:var(--ink);font-weight:600;margin:12px 0 0;font-size:1rem}
.modal-desc{color:var(--ink-soft);margin:14px 0 0;font-size:1rem;flex:1}
.modal-actions{display:grid;gap:12px;margin-top:26px}
.modal-wa{background:#1FA855;color:#fff;justify-content:center}
.modal-wa:hover{background:#178a45;transform:translateY(-2px);box-shadow:0 12px 26px -12px rgba(31,168,85,.6)}
.modal-mail{background:var(--ink);color:var(--bone);justify-content:center}
.modal-mail:hover{background:#000;transform:translateY(-2px)}
.modal-note{font-size:.8rem;color:var(--ink-soft);margin:16px 0 0;text-align:center}

/* ---------- RESPONSIVE ---------- */
@media(max-width:720px){
  .modal{grid-template-columns:1fr;max-height:92vh}
  .modal-gallery{border-right:none;border-bottom:1px solid var(--line);border-radius:20px 20px 0 0}
  .modal-info{padding:28px 24px}
}
@media(max-width:980px){
  .hero-grid,.nosotros-grid,.cont-grid{grid-template-columns:1fr;gap:44px}
  .hero-art{max-width:440px;margin:0 auto}
  .strip-grid{grid-template-columns:repeat(2,1fr)}
  .strip-grid div:nth-child(3){border-left:none}
  .grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-grid>div:first-child{grid-column:1 / -1}
}
@media(max-width:680px){
  .navlinks{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:6px 0;box-shadow:var(--shadow)}
  .navlinks.open{display:flex}
  .navlinks a{padding:15px 24px;width:100%;color:var(--ink)}
  .navlinks a::after{display:none}
  .wa-mobile{display:block;color:var(--red);font-weight:600;border-top:1px solid var(--line);margin-top:4px}
  .nav>.btn-wa{display:none}
  .burger{display:flex}
  section{padding:62px 0}
  .hero{padding:46px 0 42px}
  .hero .lead{font-size:1.06rem}
  .sec-head{margin-bottom:34px}
  .cat-title{margin:34px 0 18px}
  .cat-title h3{font-size:1.45rem}
  .strip b{font-size:1.3rem}
  .foot-grid{gap:28px}
  .foot-bottom{flex-direction:column;gap:6px}
}
@media(max-width:480px){
  .wrap{padding:0 16px}
  .nav{height:64px}
  header .brand{font-size:1.3rem}
  .chip{width:34px;height:34px;font-size:.92rem}
  .navlinks{top:64px}
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .steps{grid-template-columns:repeat(2,1fr);gap:12px}
  .card-body{padding:13px 13px 16px}
  .card-body h4{font-size:1.02rem;line-height:1.15}
  .card-body .spec{font-size:.8rem;margin-bottom:10px}
  .card-cta{font-size:.82rem;padding:6px 0}
  .swatch .soon{font-size:.58rem;padding:4px 7px;top:8px;left:8px}
  .swatch .best{font-size:.56rem;padding:4px 7px;top:8px;right:8px}
  .step{padding:22px 16px}
  .step::before{font-size:2rem;margin-bottom:10px}
  .step h4{font-size:.98rem}
  .step p{font-size:.86rem}
  .hero-cta{gap:10px}
  .hero-cta .btn{flex:1;justify-content:center;padding:12px 14px}
  .hero-since .yr{font-size:2.1rem}
  .strip-grid div{padding:18px 14px}
  .strip b{font-size:1.15rem}
  .strip p{font-size:.82rem}
  .cont-card{padding:28px 22px}
  .fab{width:52px;height:52px;right:16px;bottom:16px}
}
@media(max-width:360px){
  .grid{gap:10px}
  .card-body h4{font-size:.95rem}
  .card-body .spec{font-size:.76rem}
}
