/* ------------------------------
   Fonts
------------------------------ */
@font-face{
  font-family: "PrintologiaDisplay";
  src: url("../assets/fonts/font.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* “PRINTOLOGIA” usa esta, todo lo demás Michroma */
:root{
  --bg: #ffffff;
  --ink: #0b0d10;
  --muted: #6b7280;
  --line: rgba(0,0,0,.10);

  /* CMYK */
  --c: #00B7EB;
  --m: #FF2DAA;
  --y: #FFD400;
  --k: #111111;

  --radius: 18px;
  --radius2: 26px;
  --shadow: 0 20px 70px rgba(0,0,0,.08);
  --shadow2: 0 10px 30px rgba(0,0,0,.08);

  --max: 1180px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  background: radial-gradient(circle at 20% 20%, rgba(0,183,235,.05), transparent 40%), radial-gradient(circle at 80% 0%, rgba(255,45,170,.05), transparent 45%), var(--bg);
  color: var(--ink);
  font-family: "Michroma", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .2px;
}

img{ max-width: 100%; display: block; }

.container{
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
}

.brand-text{
  font-family: "PrintologiaDisplay", "Michroma", sans-serif;
  letter-spacing: 1px;
}

.inline-brand{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.inline-brand img{
  width: 20px;
  height: 20px;
  object-fit: contain;
}

/* ------------------------------
   Topbar
------------------------------ */
.topbar{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.42);
  backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid rgba(255,255,255,.24);
  box-shadow: 0 16px 40px rgba(0,0,0,.06);
}

.topbar__inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 18px;
}

.brand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.brand__logo{
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: grayscale(1) contrast(1.1);
}

.brand__name{
  font-size: 18px;
  line-height: 1;
}

/* Nav */
.nav{
  display: flex;
  align-items: center;
  gap: 18px;
}
.nav__link{
  color: rgba(0,0,0,.72);
  text-decoration: none;
  font-size: 12px;
  padding: 10px 10px;
  border-radius: 999px;
  transition: background .2s ease, color .2s ease;
}
.nav__link:hover{
  background: rgba(0,0,0,.04);
  color: rgba(0,0,0,.92);
}

.nav__cta{
  font-size: 12px;
  text-decoration: none;
  color: rgba(0,0,0,.92);
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.14);
  background:
    linear-gradient(white, white) padding-box,
    linear-gradient(90deg, var(--c), var(--m), var(--y), var(--k)) border-box;
  transition: transform .15s ease, box-shadow .2s ease;
}
.nav__cta:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow2);
}

.burger{
  display: none;
  border: 1px solid rgba(0,0,0,.14);
  background: white;
  border-radius: 12px;
  padding: 10px;
  cursor: pointer;
}
.burger span{
  display: block;
  width: 18px;
  height: 2px;
  background: rgba(0,0,0,.75);
  margin: 4px 0;
}

/* ------------------------------
   Hero
------------------------------ */
.hero{
  position: relative;
  padding: 82px 0 32px;
  overflow: hidden;
}

.hero::before{
  content:"";
  position: absolute;
  inset: -220px -160px auto -160px;
  height: 520px;
  background:
    radial-gradient(closest-side, rgba(0,183,235,.18), transparent 70%),
    radial-gradient(closest-side, rgba(255,45,170,.16), transparent 70%),
    radial-gradient(closest-side, rgba(255,212,0,.18), transparent 70%);
  filter: blur(2px);
  pointer-events: none;
}

.hero__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
  text-align: center;
  justify-items: center;
}

.hero__copy{
  position: relative;
  z-index: 1;
  padding: 24px 26px;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,0,0,.06);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  width: 100%;
  text-align: center;
}

.eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  width: fit-content;
  font-size: 11px;
  color: rgba(0,0,0,.65);
}

.dot{
  width: 9px; height: 9px; border-radius: 99px;
  display: inline-block;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.dot.c{ background: var(--c); }
.dot.m{ background: var(--m); }
.dot.y{ background: var(--y); }
.dot.k{ background: var(--k); }

.hero__title{
  margin: 18px auto 12px;
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.05;
  letter-spacing: 0;
}
.hero__brand{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  padding-bottom: 10px;
  font-size: 1.08em;
}
.hero__brand.inline-brand img{
  width: 44px;
  height: 44px;
}

/* Animated CMYK underline under PRINTOLOGIA */
.hero__brand::after{
  content:"";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 3px;
  width: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--c), var(--m), var(--y), var(--k), var(--c));
  background-size: 220% 100%;
  animation: inkShift 6s linear infinite;
  opacity: .95;
}

@keyframes inkShift{
  0%{ background-position: 0% 50%; }
  100%{ background-position: 220% 50%; }
}

@keyframes cmykShift{
  0%{ background-position: 0% 50%; }
  50%{ background-position: 140% 50%; }
  100%{ background-position: 260% 50%; }
}

@keyframes titleShine{
  0%{ background-position: 0% 50%; }
  50%{ background-position: 140% 50%; }
  100%{ background-position: 260% 50%; }
}

.hero__subtitle{
  display: block;
  margin-top: 12px;
  font-family: "Michroma", sans-serif;
  font-size: clamp(12px, 1.2vw, 14px);
  line-height: 1.6;
  color: rgba(0,0,0,.70);
}

.hero__desc{
  margin: 18px auto 0;
  color: rgba(0,0,0,.72);
  font-size: 13px;
  line-height: 1.9;
  max-width: 74ch;
  width: 100%;
}

.hero__actions{
  display: flex;
  gap: 12px;
  margin-top: 22px;
  flex-wrap: wrap;
  justify-content: center;
}

.btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 12px;
  cursor: pointer;
  user-select: none;
  border: 1px solid rgba(0,0,0,.14);
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  overflow: hidden;
}

.btn--primary{
  color: white;
  border-color: transparent;
  background: linear-gradient(120deg, var(--k), #1b1f28);
  box-shadow: var(--shadow2);
}
.btn--primary:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}

.btn--ghost{
  color: rgba(0,0,0,.84);
  background: rgba(255,255,255,.9);
}
.btn--ghost:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow2);
}

.btn--full{ width: 100%; }

.btn__shine{
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(0,183,235,.35), rgba(255,45,170,.25), rgba(255,212,0,.30), transparent);
  transform: translateX(-120%);
  animation: shine 2.6s ease-in-out infinite;
  opacity: .65;
}
@keyframes shine{
  0%, 55% { transform: translateX(-120%); }
  70% { transform: translateX(120%); }
  100% { transform: translateX(120%); }
}

.hero__stats{
  margin: 24px auto 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  max-width: 640px;
}
.stat{
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.9);
}
.stat__num{
  font-size: 14px;
  letter-spacing: .8px;
}
.stat__label{
  margin-top: 6px;
  font-size: 10px;
  color: rgba(0,0,0,.62);
  line-height: 1.6;
}

/* Right visual */
.hero__visual .frame{
  position: relative;
  padding: 18px;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,0,0,.10);
  background:
    linear-gradient(white, white) padding-box,
    radial-gradient(circle at 25% 20%, rgba(0,183,235,.18), transparent 55%),
    radial-gradient(circle at 80% 30%, rgba(255,45,170,.14), transparent 55%),
    radial-gradient(circle at 60% 85%, rgba(255,212,0,.14), transparent 55%);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.frame__topline{
  position: absolute;
  inset: 0 auto auto 0;
  height: 2px;
  width: 100%;
  background: linear-gradient(90deg, var(--c), var(--m), var(--y), var(--k));
  opacity: .65;
}

.stack{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}

.card{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.10);
  background: white;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  transform: translateZ(0);
}
.card img{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  background: #f6f6f6;
}
.card--big{
  grid-column: 1 / span 2;
}
.card--big img{
  aspect-ratio: 1 / 1;
}

.card figcaption{
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 12px 14px;
  font-size: 10px;
  color: rgba(0,0,0,.70);
}

.chip{
  font-size: 10px;
  width: 18px;
  height: 18px;
  border-radius: 99px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #0b0d10;
  border: 1px solid rgba(0,0,0,.12);
}
.chip.c{ background: rgba(0,183,235,.35); }
.chip.m{ background: rgba(255,45,170,.26); }
.chip.y{ background: rgba(255,212,0,.35); }
.chip.k{ background: rgba(0,0,0,.10); }

.tag{
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background:
    linear-gradient(white,white) padding-box,
    linear-gradient(90deg, rgba(0,183,235,.8), rgba(255,45,170,.7), rgba(255,212,0,.8), rgba(0,0,0,.8)) border-box;
  font-size: 10px;
  color: rgba(0,0,0,.75);
}

/* CMYK lines on hero */
.ink-lines{
  position: absolute;
  inset: auto 16px 16px 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  opacity: .7;
}
.line{
  height: 3px;
  border-radius: 999px;
  filter: blur(.1px);
}
.line.c{ background: linear-gradient(90deg, transparent, rgba(0,183,235,.9)); }
.line.m{ background: linear-gradient(90deg, transparent, rgba(255,45,170,.85)); }
.line.y{ background: linear-gradient(90deg, transparent, rgba(255,212,0,.95)); }
.line.k{ background: linear-gradient(90deg, transparent, rgba(0,0,0,.75)); }

.hero__divider{
  margin-top: 54px;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(0,0,0,.10), transparent);
}

/* ------------------------------
   Sections
------------------------------ */
.section{
  padding: 74px 0;
}
.section--soft{
  background:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,0)),
    radial-gradient(circle at 12% 15%, rgba(0,183,235,.10), transparent 55%),
    radial-gradient(circle at 86% 30%, rgba(255,45,170,.08), transparent 55%),
    radial-gradient(circle at 55% 90%, rgba(255,212,0,.09), transparent 55%);
  border-top: 1px solid rgba(0,0,0,.06);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.section__head{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 26px;
}
.section__title{
  margin: 0;
  font-size: 22px;
  letter-spacing: .5px;
}
.section__desc{
  margin: 0;
  color: rgba(0,0,0,.68);
  font-size: 12px;
  line-height: 1.9;
  max-width: 78ch;
}
.section__cta{
  margin-top: 8px;
}

.section--services{
  background:
    linear-gradient(180deg, rgba(0,183,235,.04), rgba(255,45,170,.03), rgba(0,0,0,.02));
}
.section--services .section__head{
  align-items: center;
  text-align: center;
  margin-bottom: 22px;
}
.section--services .section__title{
  font-size: 24px;
}
.section--services .section__desc{
  color: rgba(0,0,0,.64);
  margin: 0 auto;
}

.grid3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}

.feature{
  position: relative;
  padding: 20px 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(0,0,0,.08);
  background:
    linear-gradient(130deg, rgba(255,255,255,.96), rgba(255,255,255,.90)),
    radial-gradient(circle at 20% 20%, rgba(0,183,235,.10), transparent 60%),
    radial-gradient(circle at 80% 15%, rgba(255,45,170,.08), transparent 60%),
    radial-gradient(circle at 60% 80%, rgba(255,212,0,.12), transparent 60%);
  box-shadow: 0 16px 34px rgba(0,0,0,.05);
  overflow: hidden;
}
.feature::after{
  content:"";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.6);
  pointer-events: none;
}
.feature__icon{
  display: inline-flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(0,0,0,.04);
}
.swatch{
  width: 14px; height: 14px; border-radius: 4px;
  border: 1px solid rgba(0,0,0,.10);
}
.swatch:nth-child(1){ background: rgba(0,183,235,.55); }
.swatch:nth-child(2){ background: rgba(255,45,170,.40); }
.swatch:nth-child(3){ background: rgba(255,212,0,.55); }
.swatch:nth-child(4){ background: rgba(0,0,0,.12); }

.mark{
  width: 40px; height: 14px; border-radius: 999px;
  background: linear-gradient(90deg, var(--c), var(--m), var(--y), var(--k));
  opacity: .75;
}

.grid{
  width: 34px; height: 22px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.12);
  background:
    linear-gradient(90deg, rgba(0,0,0,.06) 1px, transparent 1px) 0 0/8px 8px,
    linear-gradient(rgba(0,0,0,.06) 1px, transparent 1px) 0 0/8px 8px;
}

.feature h3{
  margin: 0 0 8px;
  font-size: 14px;
}
.feature p{
  margin: 0;
  color: rgba(0,0,0,.68);
  font-size: 12px;
  line-height: 1.8;
}

.banner{
  margin-top: 18px;
  padding: 18px 16px;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,0,0,.10);
  background:
    linear-gradient(white,white) padding-box,
    linear-gradient(90deg, rgba(0,183,235,.7), rgba(255,45,170,.55), rgba(255,212,0,.7), rgba(0,0,0,.65)) border-box;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  box-shadow: var(--shadow2);
}

.banner__brand{
  font-size: 18px;
  margin-bottom: 6px;
}
.banner p{
  margin: 0;
  font-size: 12px;
  color: rgba(0,0,0,.68);
  line-height: 1.8;
}

/* ------------------------------
   Gallery
------------------------------ */
.gallery{
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 12px;
}

.catalog-cta{
  margin-top: 16px;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  background: rgba(255,255,255,.94);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  box-shadow: var(--shadow2);
}
.catalog-cta p{
  margin: 0;
  font-size: 12px;
  color: rgba(0,0,0,.70);
  line-height: 1.7;
  max-width: 74ch;
}
.catalog-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.catalog-actions .btn--catalog{
  flex: 1 1 240px;
  justify-content: center;
  padding: 12px 16px;
  font-size: 13px;
  border-radius: 999px;
  box-shadow: var(--shadow2);
}
.catalog-actions .btn--catalog.btn--primary{
  background: linear-gradient(120deg, #0b0d10, #1b1f28);
}
.catalog-actions .btn--catalog.btn--ghost{
  background:
    linear-gradient(white, white) padding-box,
    linear-gradient(90deg, var(--c), var(--m), var(--y), var(--k)) border-box;
  border-color: transparent;
  color: rgba(0,0,0,.85);
}

.item{
  text-decoration: none;
  color: inherit;
  border-radius: var(--radius);
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.95);
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(0,0,0,.05);
  transition: transform .18s ease, box-shadow .22s ease;
}
.item:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.item img{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  background: #f6f6f6;
}
.item__meta{
  padding: 12px 12px 14px;
}
.item__name{
  font-size: 12px;
  letter-spacing: .4px;
}
.item__hint{
  margin-top: 6px;
  font-size: 10px;
  color: rgba(0,0,0,.62);
  line-height: 1.6;
}

/* ------------------------------
   Contact
------------------------------ */
.section--contact{
  background:
    linear-gradient(180deg, rgba(0,183,235,.05), rgba(255,45,170,.04), rgba(255,212,0,.05));
}
.contact{
  display: block;
}
.contact__titleOuter{
  margin: 0 0 14px;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: .4px;
  padding-left: 12px;
  color: transparent;
  background: linear-gradient(120deg, var(--c), var(--m), var(--y), var(--k), var(--c));
  background-size: 280% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  animation: titleShine 3.2s ease-in-out infinite alternate;
  display: inline-block;
}
.contact__content{
  width: 100%;
  max-width: var(--max);
  border-radius: var(--radius2);
  padding: 24px;
  border: 1px solid rgba(0,0,0,.08);
  background:
    linear-gradient(120deg, rgba(255,255,255,.94), rgba(255,255,255,.90)),
    radial-gradient(circle at 20% 20%, rgba(0,183,235,.12), transparent 60%),
    radial-gradient(circle at 80% 30%, rgba(255,45,170,.10), transparent 60%),
    radial-gradient(circle at 60% 80%, rgba(255,212,0,.12), transparent 60%);
  box-shadow: var(--shadow);
}
.contact__header{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: nowrap;
  border-bottom: 1px solid rgba(0,0,0,.08);
  padding-bottom: 14px;
  margin-bottom: 16px;
}
.contact__brand{
  font-size: 24px;
  gap: 10px;
  letter-spacing: .5px;
}
.contact__brand img{
  width: 32px;
  height: 32px;
}
.contact__tagline{
  margin: 0;
  font-size: 12px;
  color: rgba(0,0,0,.65);
  max-width: 100%;
  line-height: 1.7;
  flex: 1;
}
.contact__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.contact__card{
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.95);
  box-shadow: var(--shadow2);
}
.contact__label{
  font-size: 10px;
  color: rgba(0,0,0,.60);
  margin-bottom: 6px;
}
.contact__value{
  font-size: 13px;
  color: rgba(0,0,0,.88);
  word-break: break-word;
  overflow-wrap: anywhere;
}
.contact__cta{
  margin-top: 16px;
  padding: 16px;
  border-radius: 16px;
  border: 1px dashed rgba(0,0,0,.14);
  background: rgba(255,255,255,.92);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.contact__cta-title{
  font-size: 13px;
  color: rgba(0,0,0,.88);
  margin-bottom: 6px;
}
.contact__cta p{
  margin: 0;
  font-size: 11px;
  color: rgba(0,0,0,.66);
  line-height: 1.7;
}
.contact__cta .btn{
  min-width: 200px;
}

.contact__cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 16px;
}

.info{
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.9);
}
.info__label{
  font-size: 10px;
  color: rgba(0,0,0,.58);
}
.info__value{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(0,0,0,.82);
  word-break: break-word;
}

.note{
  margin-top: 14px;
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.85);
  position: relative;
  overflow: hidden;
}
.note__bar{
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, var(--c), var(--m), var(--y), var(--k));
  opacity: .85;
}
.note p{
  margin: 0;
  padding-left: 10px;
  font-size: 11px;
  line-height: 1.9;
  color: rgba(0,0,0,.70);
}

.contact__form{
  padding: 16px;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,0,0,.10);
  background:
    linear-gradient(white,white) padding-box,
    radial-gradient(circle at 25% 20%, rgba(0,183,235,.10), transparent 60%),
    radial-gradient(circle at 80% 30%, rgba(255,45,170,.08), transparent 60%),
    radial-gradient(circle at 55% 85%, rgba(255,212,0,.10), transparent 60%);
  box-shadow: var(--shadow2);
}

.form__head{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.form__title{
  font-size: 12px;
  color: rgba(0,0,0,.75);
}
.form__brand{
  font-size: 14px;
}

.field{
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.field span{
  font-size: 10px;
  color: rgba(0,0,0,.62);
}
.field input, .field textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.14);
  padding: 12px 12px;
  font-family: "Michroma", sans-serif;
  font-size: 12px;
  outline: none;
  background: rgba(255,255,255,.95);
  transition: box-shadow .2s ease, border-color .2s ease;
  resize: none;
}
.field input:focus, .field textarea:focus{
  border-color: rgba(0,0,0,.22);
  box-shadow:
    0 0 0 4px rgba(0,183,235,.12),
    0 0 0 7px rgba(255,45,170,.08);
}
.contact__form .btn--full{
  margin-top: 14px;
}

.row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.fineprint{
  margin: 12px 2px 0;
  font-size: 10px;
  color: rgba(0,0,0,.55);
  line-height: 1.7;
}

/* ------------------------------
   Footer
------------------------------ */
.footer{
  border-top: 1px solid rgba(0,0,0,.08);
  background: white;
}
.footer__inner{
  padding: 22px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}
.footer__brand{
  display: flex;
  align-items: center;
  gap: 10px;
}
.footer__dots .dot{
  width: 8px; height: 8px;
  border-radius: 99px;
  display: inline-block;
}
.footer__small{
  margin-top: 8px;
  font-size: 10px;
  color: rgba(0,0,0,.58);
}

.footer__right{
  display: flex;
  gap: 14px;
}
.footer__right a{
  color: rgba(0,0,0,.68);
  text-decoration: none;
  font-size: 11px;
  padding: 8px 10px;
  border-radius: 999px;
}
.footer__right a:hover{
  background: rgba(0,0,0,.04);
  color: rgba(0,0,0,.9);
}

.footer__bottom{
  border-top: 1px solid rgba(0,0,0,.06);
}
.footer__bottomInner{
  padding: 14px 0;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  color: rgba(0,0,0,.58);
  font-size: 10px;
}
.footer__bottomInner span{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.footer__bottomInner .inline-brand{
  align-items: center;
}

/* ------------------------------
   Reveal Animations
------------------------------ */
.reveal{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}
.delay-1{ transition-delay: .08s; }
.delay-2{ transition-delay: .16s; }

/* ------------------------------
   Responsive
------------------------------ */
@media (max-width: 980px){
  .hero__grid{ grid-template-columns: 1fr; }
  .hero__copy{ padding: 18px 16px; }
  .hero__stats{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .gallery{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .grid3{ grid-template-columns: 1fr; }
  .contact__cards{ grid-template-columns: 1fr; }
  .contact__cta{ flex-direction: column; align-items: flex-start; }
  .contact__cta .btn{ width: 100%; }
}

@media (max-width: 900px){
  .contact__header{
    flex-direction: column;
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .contact__tagline{
    text-align: left;
  }
}

@media (max-width: 760px){
  .nav{ display: none; }
  .burger{ display: inline-block; }

  .footer__inner{
    flex-direction: column;
    align-items: flex-start;
  }
  .footer__bottomInner{
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px){
  .hero__stats{ grid-template-columns: 1fr; }
  .hero__actions{ width: 100%; justify-content: center; }
  .hero__actions .btn{ flex: 1 1 100%; justify-content: center; }
  .gallery{ grid-template-columns: 1fr; }
  .catalog-actions .btn--catalog{ flex: 1 1 100%; }
  .contact__titleOuter{ padding-left: 4px; text-align: left; }
  .contact__header{ flex-direction: column; align-items: flex-start; flex-wrap: wrap; }
  .contact__tagline{ text-align: left; }
}
