/* ============================================================
   E-BRIK Ferramenta — Styles
   ============================================================ */

:root{
  --navy-900:#081a33;
  --navy-800:#0c2243;
  --navy-700:#102a52;
  --navy-600:#173667;
  --gold:#c9a253;
  --gold-light:#e3c585;
  --gold-deep:#a8843c;
  --cream:#f5f1e8;
  --cream-2:#ebe4d4;
  --ink:#0a1626;
  --white:#ffffff;
  --muted:#8b97ab;

  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --font-serif:'Playfair Display',Georgia,serif;

  --radius:18px;
  --radius-sm:12px;
  --shadow:0 24px 60px -22px rgba(8,16,38,.55);
  --shadow-gold:0 18px 44px -16px rgba(168,132,60,.45);
  --ease:cubic-bezier(.4,.14,.2,1);
  --container:1240px;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--navy-800);
  color:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
section{position:relative}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 28px}

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-light));
  box-shadow:0 0 12px rgba(201,162,83,.6);
}

/* ---------- Back to top ---------- */
.to-top{
  position:fixed;right:26px;bottom:26px;z-index:90;
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-gold);
  opacity:0;visibility:hidden;transform:translateY(20px) scale(.8);
  transition:opacity .35s var(--ease),transform .35s var(--ease);
}
.to-top.is-show{opacity:1;visibility:visible;transform:none}
.to-top:hover{transform:translateY(-4px)}
.to-top svg{width:22px;height:22px;fill:none;stroke:var(--navy-900);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Typography helpers ---------- */
.text-gold{
  background:linear-gradient(100deg,var(--gold-deep) 0%,var(--gold-light) 28%,#fff6e0 42%,var(--gold-light) 56%,var(--gold-deep) 100%);
  background-size:280% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{to{background-position:-280% center}}
.eyebrow{
  display:inline-block;font-family:var(--font-body);font-weight:700;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
  position:relative;padding-left:34px;
}
.eyebrow::before{
  content:"";position:absolute;left:0;top:50%;width:24px;height:2px;
  background:var(--gold);transform:translateY(-50%);
}
.eyebrow--dark{color:var(--gold-deep)}
.eyebrow--dark::before{background:var(--gold-deep)}

.section{padding:120px 0}
.section__head{max-width:680px;margin:0 auto 64px;text-align:center}
.section__head .eyebrow{padding-left:0}
.section__head .eyebrow::before{display:none}
.section__title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2rem,4vw,3.1rem);line-height:1.12;
  letter-spacing:-.02em;color:var(--white);
}
.section__intro{margin-top:18px;color:var(--muted);font-size:1.05rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  padding:16px 30px;border-radius:100px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease),color .3s var(--ease);
  white-space:nowrap;
}
.btn--sm{padding:11px 22px;font-size:.86rem}
.btn--gold{
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 55%,var(--gold-deep));
  color:var(--navy-900);box-shadow:var(--shadow-gold);
}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 24px 50px -14px rgba(201,162,83,.6)}
.btn--ghost{
  border:1.5px solid rgba(227,197,133,.4);color:var(--cream);
}
.btn--ghost:hover{border-color:var(--gold);background:rgba(201,162,83,.1);transform:translateY(-3px)}
.btn--dark{
  background:var(--navy-900);color:var(--cream);
  border:1.5px solid rgba(255,255,255,.08);
}
.btn--dark:hover{background:var(--navy-700);transform:translateY(-3px)}

/* ---------- Preloader ---------- */
.preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--navy-900);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s ease,visibility .6s ease;
}
.preloader.is-done{opacity:0;visibility:hidden}
.preloader__mark img{
  width:84px;height:auto;
  animation:pulseMark 1.4s var(--ease) infinite;
}
@keyframes pulseMark{
  0%,100%{transform:scale(1);opacity:.55}
  50%{transform:scale(1.12);opacity:1}
}

/* ---------- Header ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 0;
  transition:padding .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease);
}
.header.is-scrolled{
  padding:12px 0;
  background:rgba(8,21,37,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 10px 40px -18px rgba(0,0,0,.7);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}

.brand{display:flex;align-items:center;gap:12px}
.brand__mark{width:42px;height:42px;object-fit:contain;transition:transform .4s var(--ease)}
.brand:hover .brand__mark{transform:rotate(-8deg) scale(1.06)}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{
  font-family:var(--font-display);font-weight:800;font-size:1.35rem;
  letter-spacing:.04em;color:var(--white);
}
.brand__sub{
  font-family:var(--font-serif);font-style:italic;font-size:.82rem;
  color:var(--gold);letter-spacing:.04em;margin-top:2px;
}

.nav{display:flex;align-items:center;gap:22px;flex-wrap:nowrap}
.nav a{
  font-weight:600;font-size:.93rem;color:var(--cream);white-space:nowrap;
  position:relative;padding:4px 0;transition:color .25s ease;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--gold);transition:width .3s var(--ease);
}
.nav a:hover{color:var(--gold)}
.nav a:hover::after{width:100%}

.header__actions{display:flex;align-items:center;gap:16px}

.lang{display:flex;border:1px solid rgba(227,197,133,.25);border-radius:100px;overflow:hidden}
.lang__btn{
  padding:7px 13px;font-size:.78rem;font-weight:700;
  color:var(--muted);transition:background .25s,color .25s;
}
.lang__btn.is-active{background:var(--gold);color:var(--navy-900)}
.lang__btn:not(.is-active):hover{color:var(--gold)}

.burger{display:none;flex-direction:column;gap:5px;width:34px;height:34px;align-items:center;justify-content:center}
.burger span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.3s var(--ease)}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:150px 0 90px;overflow:hidden;
  background:
    radial-gradient(900px 600px at 78% 18%,rgba(23,54,103,.85),transparent 60%),
    radial-gradient(700px 500px at 8% 92%,rgba(201,162,83,.1),transparent 60%),
    linear-gradient(160deg,var(--navy-900),var(--navy-800) 55%,var(--navy-700));
}
.hero__bg{position:absolute;inset:0;pointer-events:none}
.gear{position:absolute;color:var(--gold);opacity:.07}
.gear--1{width:200px;top:14%;right:6%;animation:spin 38s linear infinite}
.gear--2{width:120px;bottom:16%;left:4%;animation:spin 26s linear infinite reverse}
.gear--3{width:150px;top:60%;right:14%;opacity:.05;animation:floaty 9s ease-in-out infinite}
.gear--4{width:90px;top:24%;left:10%;opacity:.06;animation:spin 30s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floaty{50%{transform:translateY(-22px) rotate(12deg)}}

.hero__inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;
  position:relative;z-index:2;
}
.hero__title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.5rem,5vw,4.3rem);line-height:1.06;
  letter-spacing:-.025em;color:var(--white);margin:6px 0 22px;
}
.hero__title span{display:block}
.hero__lead{
  font-size:1.12rem;color:#c4cddd;max-width:480px;margin-bottom:34px;
}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:50px}

.hero__stats{display:flex;gap:38px;flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat__num{
  font-family:var(--font-display);font-weight:800;font-size:2.4rem;
  color:var(--gold);line-height:1;display:inline}
.stat__plus{
  font-family:var(--font-display);font-weight:800;font-size:1.6rem;
  color:var(--gold);vertical-align:top}
.stat__label{font-size:.82rem;color:var(--muted);margin-top:8px;max-width:130px}

.hero__visual{position:relative}
.hero__frame{
  position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);border:1px solid rgba(227,197,133,.16);
}
.hero__frame img{width:100%;height:520px;object-fit:cover}
.hero__frame::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,21,37,.5),transparent 45%);
}
.hero__badge{
  position:absolute;left:20px;bottom:20px;z-index:3;
  display:flex;align-items:center;gap:12px;
  background:rgba(8,21,37,.85);backdrop-filter:blur(8px);
  border:1px solid rgba(227,197,133,.25);
  padding:14px 18px;border-radius:14px;
}
.hero__badge img{width:34px}
.hero__badge strong{font-family:var(--font-display);color:var(--white);display:block;font-size:1rem}
.hero__badge span{font-size:.78rem;color:var(--gold)}

.hero__scroll{
  position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  width:26px;height:42px;border:2px solid rgba(227,197,133,.4);
  border-radius:14px;z-index:3;
}
.hero__scroll span{
  position:absolute;left:50%;top:8px;width:4px;height:8px;
  background:var(--gold);border-radius:2px;transform:translateX(-50%);
  animation:scrollDot 1.8s var(--ease) infinite;
}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,14px)}}

/* ---------- Subpage hero (shorter than .hero) ---------- */
.subhero{
  position:relative;padding:160px 0 90px;overflow:hidden;
  background:
    radial-gradient(900px 600px at 78% 18%,rgba(23,54,103,.85),transparent 60%),
    radial-gradient(700px 500px at 8% 92%,rgba(201,162,83,.1),transparent 60%),
    linear-gradient(160deg,var(--navy-900),var(--navy-800) 55%,var(--navy-700));
}
.subhero .hero__inner{align-items:center}
.subhero .hero__title{font-size:clamp(2rem,4.2vw,3.4rem)}
.subhero .hero__frame img{height:440px}
@media (max-width:1080px){
  .subhero .hero__frame img{height:380px}
}
@media (max-width:680px){
  .subhero{padding:130px 0 70px}
  .subhero .hero__frame img{height:320px}
}

/* Active nav link */
.nav a.is-active{color:var(--gold)}
.nav a.is-active::after{width:100%}

/* ---------- Trust bar ---------- */
.trustbar{
  background:linear-gradient(90deg,var(--navy-900),var(--navy-700) 50%,var(--navy-900));
  border-top:1px solid rgba(227,197,133,.16);
  border-bottom:1px solid rgba(227,197,133,.16);
  padding:18px 0;
}
.trustbar__list{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;flex-wrap:nowrap;overflow-x:auto;
  scrollbar-width:none;
}
.trustbar__list::-webkit-scrollbar{display:none}
.trustbar__item{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.86rem;
  color:var(--cream);white-space:nowrap;flex-shrink:0;
}
.trustbar__item svg{
  width:22px;height:22px;fill:none;stroke:var(--gold);
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  flex-shrink:0;
}
@media (max-width:880px){
  .trustbar__list{justify-content:flex-start;padding-bottom:4px}
  .trustbar__item{font-size:.8rem}
}

/* ---------- Mobile fixed bottom bar ---------- */
.mobilebar{
  display:none;
  position:fixed;left:10px;right:10px;bottom:10px;z-index:90;
  background:rgba(8,21,37,.96);backdrop-filter:blur(14px);
  border:1px solid rgba(227,197,133,.25);
  border-radius:16px;
  box-shadow:0 22px 50px -16px rgba(0,0,0,.7);
  padding:8px;gap:6px;
}
.mobilebar__btn{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:8px 6px;border-radius:11px;
  font-family:var(--font-display);font-weight:600;font-size:.72rem;
  color:var(--cream);transition:background .25s,color .25s;
}
.mobilebar__btn svg{
  width:22px;height:22px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
}
.mobilebar__btn:active{background:rgba(255,255,255,.06)}
.mobilebar__btn--wa{
  color:var(--navy-900);
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 60%,var(--gold-deep));
}
.mobilebar__btn--wa:active{filter:brightness(.95)}
@media (max-width:720px){
  .mobilebar{display:flex}
  body{padding-bottom:80px}
  .to-top{bottom:96px}
  .cookie{bottom:80px}
}

/* ---------- About ---------- */
.about{background:var(--navy-800)}
.about__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center}
.about__media{position:relative}
.about__media img{
  width:100%;height:540px;object-fit:cover;border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid rgba(227,197,133,.14);
}
.about__media-tag{
  position:absolute;right:-18px;bottom:34px;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--navy-900);font-family:var(--font-display);font-weight:700;
  padding:16px 24px;border-radius:14px;box-shadow:var(--shadow-gold);
  max-width:220px;font-size:.95rem;
}
.about__copy p{color:#bcc6d6;margin-bottom:16px}
.ticks{margin:26px 0 30px}
.ticks li{
  position:relative;padding-left:34px;margin-bottom:12px;
  color:var(--cream);font-weight:500;
}
.ticks li::before{
  content:"";position:absolute;left:0;top:3px;width:20px;height:20px;
  border-radius:50%;background:var(--gold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/72% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/72% no-repeat;
}

/* Served-area sentence in About */
.about__served{
  margin-top:18px;padding:14px 18px;border-radius:10px;
  background:rgba(201,162,83,.08);border-left:3px solid var(--gold);
  font-size:.92rem;color:var(--cream);
}
.about__served strong{color:var(--gold-light)}

/* ---------- Departments ---------- */
.depts{background:var(--navy-900)}
.depts__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.dept{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.05);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
}
.dept:hover{transform:translateY(-10px);box-shadow:var(--shadow);border-color:rgba(201,162,83,.35)}
.dept__img{height:230px;overflow:hidden}
.dept__img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
}
.dept:hover .dept__img img{transform:scale(1.09)}
.dept__body{padding:26px 26px 30px;position:relative}
.dept__no{
  position:absolute;right:24px;top:-26px;
  font-family:var(--font-display);font-weight:800;font-size:2.6rem;
  color:var(--gold);opacity:.85;
}
.dept__body h3{
  font-family:var(--font-display);font-weight:700;font-size:1.22rem;
  color:var(--white);margin-bottom:10px;
}
.dept__body p{color:var(--muted);font-size:.95rem}

/* ---------- Products listing ---------- */
.products__grid{
  grid-template-columns:repeat(auto-fit,minmax(260px,320px));
  justify-content:center;
}
.products-search{
  position:relative;max-width:440px;margin:0 auto 36px;
}
.products-search svg{
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:20px;height:20px;fill:none;stroke:var(--muted);stroke-width:2;
  stroke-linecap:round;pointer-events:none;
}
.products-search input{
  width:100%;padding:15px 20px 15px 50px;border-radius:100px;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.1);
  color:var(--white);font-family:inherit;font-size:1rem;
  transition:border-color .25s,background .25s;
}
.products-search input::placeholder{color:var(--muted)}
.products-search input:focus{outline:0;border-color:var(--gold);background:var(--navy-800)}
.products-empty{
  text-align:center;color:var(--muted);font-size:1rem;margin:0 0 36px;
}
.dept__tag{
  display:inline-block;margin-bottom:8px;
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);
}
.pcard__meta{
  display:flex;flex-wrap:wrap;gap:6px 10px;align-items:center;
  margin:2px 0 8px;font-size:.78rem;
}
.pcard__brand{font-weight:700;color:var(--gold-light)}
.pcard__code{
  color:var(--muted);font-weight:600;
  padding:2px 8px;border:1px solid rgba(255,255,255,.12);border-radius:100px;
}
.dept__oos{
  position:absolute;top:14px;left:14px;z-index:2;
  background:rgba(231,76,60,.92);color:#fff;
  font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.dept__img{position:relative}

/* Product card image carousel */
.pcard__media{position:relative;height:230px;overflow:hidden;background:var(--navy-700)}
.pcard__track{
  display:flex;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none;
}
.pcard__track::-webkit-scrollbar{display:none}
.pcard__track img{
  flex:0 0 100%;width:100%;height:100%;object-fit:cover;scroll-snap-align:center;
}
.pcard__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:34px;height:34px;border-radius:50%;
  background:rgba(8,21,37,.55);color:#fff;font-size:1.3rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s,background .25s;z-index:2;
}
.pcard__media:hover .pcard__nav{opacity:1}
.pcard__nav:hover{background:var(--gold);color:var(--navy-900)}
.pcard__nav--prev{left:10px}
.pcard__nav--next{right:10px}
.pcard__dots{
  position:absolute;bottom:10px;left:0;right:0;z-index:2;
  display:flex;gap:6px;justify-content:center;
}
.pcard__dots span{
  width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.45);
  transition:background .25s,transform .25s;
}
.pcard__dots span.is-active{background:var(--gold);transform:scale(1.25)}
@media (hover:none){ .pcard__nav{display:none} }
@media (max-width:560px){ .pcard__media{height:200px} }
.dept__link{
  display:inline-block;margin-top:14px;
  font-weight:700;font-size:.9rem;color:var(--gold);
  transition:color .25s;
}
.dept:hover .dept__link{color:var(--gold-light,#e3c585)}
.dept--cta{
  cursor:pointer;display:flex;align-items:center;
  background:linear-gradient(155deg,var(--navy-700),var(--navy-800));
  border-color:rgba(201,162,83,.3);
}
.dept--cta .dept__body{padding:32px 28px;text-align:center}
.dept__cta-icon{
  width:40px;height:40px;margin:0 auto 14px;display:block;
  fill:none;stroke:var(--gold);stroke-width:1.6;
}

/* ---------- Tinting ---------- */
.tint{
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 60%,var(--gold-deep));
  color:var(--navy-900);overflow:hidden;
}
.tint__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.tint__copy .section__title{color:var(--navy-900)}
.tint__lead{font-size:1.15rem;color:#3b2e10;margin:6px 0 30px;max-width:460px}
.tint__lead strong{color:var(--navy-900)}
.tint__points{display:flex;gap:40px;margin-bottom:34px}
.tint__point{display:flex;flex-direction:column}
.tint__big{
  font-family:var(--font-display);font-weight:800;font-size:3rem;
  color:var(--navy-900);line-height:1;display:inline}
.tint__big-plus{
  font-family:var(--font-display);font-weight:800;font-size:1.8rem;
  color:var(--navy-900);vertical-align:top}
.tint__point span:last-child{font-weight:600;color:#4a3a14;margin-top:8px}
.tint .btn--gold{background:var(--navy-900);color:var(--cream);box-shadow:0 18px 40px -16px rgba(8,16,38,.6)}
.tint .btn--gold:hover{background:var(--navy-700)}

.tint__media{position:relative;height:480px}
.tint__media img{
  position:absolute;border-radius:var(--radius);object-fit:cover;
  box-shadow:0 30px 60px -24px rgba(8,16,38,.55);
  border:4px solid rgba(255,255,255,.6);
}
.tint__media img:first-child{width:68%;height:78%;top:0;right:0}
.tint__media-2{width:52%;height:55%;bottom:0;left:0}

/* ---------- Why ---------- */
.why{background:var(--navy-800)}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.feature{
  background:var(--navy-700);border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius);padding:36px 28px;
  transition:transform .4s var(--ease),border-color .4s var(--ease);
}
.feature:hover{transform:translateY(-8px);border-color:rgba(201,162,83,.35)}
.feature__icon{
  width:58px;height:58px;border-radius:14px;margin-bottom:22px;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  display:flex;align-items:center;justify-content:center;
}
.feature__icon svg{width:30px;height:30px;fill:none;stroke:var(--navy-900);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.feature h3{
  font-family:var(--font-display);font-weight:700;font-size:1.12rem;
  color:var(--white);margin-bottom:10px;
}
.feature p{color:var(--muted);font-size:.93rem}

/* ---------- Band ---------- */
.band{padding:130px 0;overflow:hidden;text-align:center}
.band__bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  z-index:0;
}
.band__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(8,21,37,.92),rgba(12,34,67,.82));
}
.band__inner{position:relative;z-index:2;max-width:640px}
.band__inner h2{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.9rem,3.6vw,2.8rem);color:var(--white);
  letter-spacing:-.02em;margin-bottom:16px;
}
.band__inner p{color:#c4cddd;margin-bottom:30px;font-size:1.05rem}

/* ---------- Brands ---------- */
.brands{background:var(--navy-900);padding:90px 0}
.brands__marquee{
  overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.brands__track{
  display:flex;align-items:center;width:max-content;
  animation:brandscroll 50s linear infinite;
}
.brands__marquee:hover .brands__track{animation-play-state:paused}
@keyframes brandscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.brands__track .bm{
  flex:0 0 auto;margin-right:30px;
  display:inline-flex;align-items:center;justify-content:center;
  height:78px;padding:0 30px;border-radius:14px;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);
  font-family:var(--font-display);font-weight:700;font-size:1.35rem;letter-spacing:.06em;
  color:var(--muted);opacity:.85;transition:color .3s,opacity .3s,background .3s,border-color .3s;
}
.brands__track .bm:hover{color:var(--gold);opacity:1}
.brands__track .bm.has-logo{
  background:#fff;border-color:#fff;opacity:1;
  box-shadow:0 10px 26px -14px rgba(0,0,0,.6);
}
.brands__track .bm.has-logo .bm__name{display:none}
.brands__track .bm img{height:46px;width:auto;max-width:360px;object-fit:contain;display:block}
@media (prefers-reduced-motion:reduce){
  .brands__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;row-gap:22px}
}

/* ---------- Gallery ---------- */
.gallery{background:var(--navy-800)}
.gallery__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px;gap:18px;
}
.gallery__item{
  border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;
  position:relative;border:1px solid rgba(255,255,255,.05);
}
.gallery__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease),filter .4s;
}
.gallery__item::after{
  content:"+";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:2.4rem;color:var(--white);
  background:rgba(8,21,37,.55);opacity:0;transition:opacity .4s var(--ease);
}
.gallery__item:hover img{transform:scale(1.1)}
.gallery__item:hover::after{opacity:1}
.gallery__item--tall{grid-row:span 2}
.gallery__item--wide{grid-column:span 2}

/* ---------- Contact ---------- */
.contact{background:var(--navy-900)}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:stretch}
.contact__info{
  background:var(--navy-700);border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius);padding:42px;
}
.info{display:flex;gap:18px;margin-bottom:30px}
.info__icon{
  flex-shrink:0;width:50px;height:50px;border-radius:12px;
  background:rgba(201,162,83,.12);border:1px solid rgba(201,162,83,.3);
  display:flex;align-items:center;justify-content:center;
}
.info__icon svg{width:24px;height:24px;fill:none;stroke:var(--gold);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.info h4{
  font-family:var(--font-display);font-weight:700;font-size:1.02rem;
  color:var(--white);margin-bottom:4px;
}
.info p{color:var(--muted);font-size:.95rem}
.info a:hover{color:var(--gold)}
.contact__btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}

.contact__map{
  border-radius:var(--radius);overflow:hidden;min-height:440px;
  border:1px solid rgba(227,197,133,.16);box-shadow:var(--shadow);
}
.contact__map iframe{width:100%;height:100%;min-height:440px;border:0;filter:grayscale(.3) contrast(1.05)}

/* ---------- Footer ---------- */
.footer{background:var(--navy-900);padding:70px 0 0;border-top:1px solid rgba(255,255,255,.05)}
.footer__inner{
  display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:48px;
  padding-bottom:54px;
}
.footer__brand p{color:var(--muted);font-size:.93rem;margin-top:18px;max-width:330px}
.footer h4{
  font-family:var(--font-display);font-weight:700;font-size:1rem;
  color:var(--white);margin-bottom:18px;
}
.footer__nav{display:flex;flex-direction:column;gap:11px}
.footer__nav a{color:var(--muted);font-size:.93rem;transition:color .25s}
.footer__nav a:hover{color:var(--gold)}
.footer__contact p{color:var(--muted);font-size:.93rem;margin-bottom:8px}
.footer__contact a:hover{color:var(--gold)}
.footer__bar{border-top:1px solid rgba(255,255,255,.06);padding:22px 0}
.footer__bar-inner{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:.82rem;color:var(--muted);
}
.footer__social{display:flex;gap:12px;margin-top:18px}
.footer__social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.06);color:var(--muted);
  transition:color .25s,background .25s;
}
.footer__social a:hover{color:var(--navy-900);background:var(--gold)}
.footer__social svg{width:20px;height:20px}

/* ---------- Related links (Cerchi anche...) ---------- */
.related-section{background:var(--navy-900)}
.related-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1100px;margin:0 auto;
}
.related-card{
  display:flex;flex-direction:column;gap:6px;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.06);
  border-left:3px solid var(--gold);
  border-radius:10px;padding:18px 20px;text-decoration:none;
  transition:transform .3s var(--ease),border-color .3s,background .3s;
}
.related-card:hover{
  transform:translateY(-3px);border-color:var(--gold);
  background:var(--navy-600);
}
.related-card__title{
  font-family:var(--font-display);font-weight:700;font-size:.95rem;
  color:var(--white);line-height:1.3;
}
.related-card__desc{
  font-size:.8rem;color:var(--muted);line-height:1.45;
}
@media (max-width:880px){
  .related-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .related-grid{grid-template-columns:1fr}
}

/* ---------- FAQ ---------- */
.faq{background:var(--navy-800)}
.faq__list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq__item{
  background:var(--navy-700);border:1px solid rgba(255,255,255,.06);
  border-radius:14px;overflow:hidden;
  transition:border-color .25s,background .25s;
}
.faq__item[open]{border-color:rgba(201,162,83,.4);background:var(--navy-600)}
.faq__item summary{
  list-style:none;cursor:pointer;padding:18px 24px;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  color:var(--cream);display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"+";display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  background:rgba(201,162,83,.15);color:var(--gold);
  font-size:1.4rem;line-height:1;font-weight:700;flex-shrink:0;
  transition:transform .3s var(--ease),background .25s;
}
.faq__item[open] summary::after{transform:rotate(45deg);background:rgba(201,162,83,.28)}
.faq__item p{
  padding:0 24px 22px;color:var(--muted);font-size:.96rem;line-height:1.65;
}
.faq__item p a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.faq__item p a:hover{color:var(--gold-light)}

/* ---------- Business card ---------- */
.vcard{
  background:linear-gradient(165deg,var(--navy-900),var(--navy-800) 60%,var(--navy-700));
  overflow:hidden;text-align:center;
}
.vcard__glow{
  position:absolute;top:46%;left:50%;width:680px;height:680px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(201,162,83,.22),transparent 62%);
  pointer-events:none;animation:glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse{50%{opacity:.5;transform:translate(-50%,-50%) scale(1.12)}}

.vcard__stage{
  display:flex;flex-direction:column;align-items:center;gap:30px;
  perspective:1600px;
}
.vcard__flip{
  position:relative;width:clamp(300px,84vw,540px);aspect-ratio:1366/768;
  transform-style:preserve-3d;cursor:pointer;border-radius:18px;
  transition:transform 1s var(--ease);
}
.vcard__flip:focus-visible{outline:2px solid var(--gold);outline-offset:8px}

/* The whole card spins 180° — the real flip. */
@media (hover:hover){ .vcard__flip:hover{transform:rotateY(180deg)} }
.vcard__flip.is-flipped{transform:rotateY(180deg)}

/* Faces are nudged apart on the Z axis: two perfectly coplanar surfaces
   z-fight on the GPU, and that flicker is what bled the front through
   mirrored. translateZ separates them so the back stays clean. */
.vcard__face{
  position:absolute;inset:0;border-radius:18px;overflow:hidden;
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  box-shadow:0 40px 80px -28px rgba(0,0,0,.8),0 0 0 1px rgba(227,197,133,.22);
}
.vcard__front{transform:rotateY(0deg) translateZ(1px)}
.vcard__back{
  transform:rotateY(180deg) translateZ(1px);
  background:
    radial-gradient(420px 300px at 50% 30%,rgba(23,54,103,.9),transparent 70%),
    linear-gradient(150deg,var(--navy-800),var(--navy-900));
  display:flex;align-items:center;justify-content:center;
  padding:clamp(20px,4vw,40px);
}
.vcard-back__col{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:0}
.vcard-back__name{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.4rem,4vw,2rem);letter-spacing:.04em;color:#fff;line-height:1;
}
.vcard-back__sub{
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(.76rem,1.9vw,.98rem);color:var(--gold);margin-top:3px;
}
.vcard-back__list{
  list-style:none;margin:clamp(10px,2.2vw,15px) 0 0;padding:0;
  display:flex;flex-direction:column;gap:clamp(3px,.8vw,5px);
  font-size:clamp(.7rem,1.8vw,.88rem);color:var(--muted);
}
.vcard-back__list a{color:#fff}
.vcard-back__list a:hover{color:var(--gold)}
.vcard-back__hours{
  margin-top:clamp(8px,1.8vw,12px);
  font-size:clamp(.6rem,1.5vw,.75rem);font-weight:600;letter-spacing:.04em;
  color:var(--gold);
}
.vcard-back__social{display:flex;gap:9px;margin-top:clamp(8px,1.6vw,12px)}
.vcard-back__social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:clamp(26px,5.5vw,32px);height:clamp(26px,5.5vw,32px);border-radius:50%;
  background:rgba(255,255,255,.08);color:#fff;transition:color .25s,background .25s;
}
.vcard-back__social a:hover{color:var(--navy-900);background:var(--gold)}
.vcard-back__social svg{width:60%;height:60%}

.vcard__front{
  background:
    radial-gradient(420px 300px at 78% 22%,rgba(23,54,103,.9),transparent 70%),
    linear-gradient(150deg,var(--navy-800),var(--navy-900));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:24px;
}
.vcard__front::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.08) 48%,transparent 58%);
  background-size:280% 100%;animation:cardSheen 5.5s linear infinite;
}
@keyframes cardSheen{to{background-position:-280% 0}}
.vcard__gear{position:absolute;color:var(--gold);opacity:.1}
.vcard__gear--a{width:120px;top:-26px;right:-22px;animation:spin 30s linear infinite}
.vcard__gear--b{width:96px;bottom:-20px;left:-16px;animation:spin 24s linear infinite reverse}
.vcard__gear--c{width:64px;top:18%;left:14%;opacity:.07;animation:spin 36s linear infinite}
.vcard__logo{display:flex;align-items:center;gap:14px;z-index:2}
.vcard__logo img{width:clamp(46px,9vw,64px);height:auto}
.vcard__name{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2rem,6vw,3.2rem);letter-spacing:.04em;color:#fff;
}
.vcard__tag{
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(1rem,2.6vw,1.5rem);color:var(--gold);z-index:2;
}
.vcard__since{
  margin-top:10px;z-index:2;
  font-size:clamp(.62rem,1.7vw,.8rem);font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);
}
.vcard__hint{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.85rem;font-weight:600;color:var(--gold);letter-spacing:.04em;
}
.vcard__hint svg{
  width:18px;height:18px;fill:none;stroke:var(--gold);
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  animation:spin 4s linear infinite;
}

/* ---------- Map consent ---------- */
.contact__map{position:relative}
.map-consent{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;padding:32px;text-align:center;
  background:linear-gradient(160deg,var(--navy-700),var(--navy-900));
}
.map-consent.is-hidden{
  opacity:0;visibility:hidden;
  transition:opacity .45s ease,visibility .45s;
}
.map-consent svg{
  width:42px;height:42px;fill:none;stroke:var(--gold);
  stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
}
.map-consent p{color:var(--muted);font-size:.92rem;max-width:300px}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:0;right:0;bottom:0;z-index:300;padding:18px;
  transform:translateY(135%);transition:transform .55s var(--ease);
  pointer-events:none;
}
.cookie.is-show{transform:none;pointer-events:auto}
.cookie__inner{
  max-width:940px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  background:rgba(8,21,37,.97);backdrop-filter:blur(14px);
  border:1px solid rgba(227,197,133,.25);border-radius:16px;
  padding:18px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.75);
}
.cookie__text{color:#c4cddd;font-size:.9rem;flex:1;min-width:240px}
.cookie__btns{display:flex;gap:10px;flex-shrink:0}
@media (max-width:560px){
  .cookie__inner{flex-direction:column;align-items:stretch;text-align:center}
  .cookie__btns{justify-content:center}
  .cookie__btns .btn{flex:1}
}

/* ---------- B2B form (Professionisti) ---------- */
.profform-section{background:var(--navy-800)}
.profform{
  max-width:760px;margin:0 auto;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);padding:42px;
  box-shadow:var(--shadow);
}
.profform__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px 22px;
}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field>span{
  font-family:var(--font-display);font-weight:600;font-size:.84rem;
  color:var(--cream);letter-spacing:.02em;
}
.field input,.field select,.field textarea{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:13px 15px;
  color:var(--cream);font-family:var(--font-body);font-size:.95rem;
  transition:border-color .25s,background .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);background:rgba(201,162,83,.06);
}
.field textarea{resize:vertical;min-height:96px;font-family:var(--font-body)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 7'%3E%3Cpath fill='%23c9a253' d='M0 0l6 7 6-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:10px;padding-right:36px}
.profform__note{color:var(--muted);font-size:.82rem;margin:18px 0 18px}
.profform button[type=submit]{width:100%;justify-content:center}
@media (max-width:680px){
  .profform{padding:26px 22px}
  .profform__grid{grid-template-columns:1fr}
}

/* Clickable dept cards (used on Professionisti / Soluzioni sections) */
a.dept{display:block;color:inherit;text-decoration:none}

/* Soluzioni per professionisti */
.sol{background:var(--navy-800)}
.sol__cta{display:flex;justify-content:center;margin-top:48px}

/* ---------- Product page ---------- */
.product__crumbs{
  font-size:.82rem;color:var(--muted);margin-bottom:14px;
}
.product__crumbs a{color:var(--gold)}
.product__crumbs a:hover{text-decoration:underline}
.product__specs{
  list-style:none;display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 30px;
}
.product__specs li{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:100px;padding:8px 16px;font-size:.86rem;color:var(--cream);
}
.product__specs strong{color:var(--gold);font-weight:700;margin-right:6px}
.product__chip--ok{
  background:rgba(46,204,113,.1);border-color:rgba(46,204,113,.4);
}
.product__chip--ok strong{color:#5ed28a}
.product__note{
  font-size:.86rem;color:var(--muted);margin-top:18px;
  padding:14px 18px;border-left:3px solid var(--gold);
  background:rgba(201,162,83,.05);border-radius:0 10px 10px 0;
}
.product__details{max-width:760px;margin:0 auto}
.product__table{
  width:100%;border-collapse:collapse;
  background:var(--navy-700);border-radius:var(--radius);overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
}
.product__table th,.product__table td{
  padding:14px 22px;text-align:left;font-size:.95rem;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.product__table tr:last-child th,.product__table tr:last-child td{border-bottom:0}
.product__table th{
  color:var(--gold);font-family:var(--font-display);font-weight:600;
  width:38%;background:rgba(0,0,0,.15);
}
.product__table td{color:var(--cream)}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(8,16,38,.96);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox img{
  max-width:88vw;max-height:84vh;border-radius:10px;
  box-shadow:var(--shadow);
}
.lightbox__close{
  position:absolute;top:24px;right:30px;font-size:2.6rem;
  color:var(--cream);line-height:1;
}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:56px;height:56px;border-radius:50%;
  background:rgba(201,162,83,.16);border:1px solid rgba(201,162,83,.4);
  font-size:1.8rem;color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s;
}
.lightbox__nav:hover{background:rgba(201,162,83,.32)}
.lightbox__prev{left:24px}
.lightbox__next{right:24px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal:nth-child(2){transition-delay:.08s}
.reveal:nth-child(3){transition-delay:.16s}
.reveal:nth-child(4){transition-delay:.24s}
.reveal:nth-child(5){transition-delay:.12s}
.reveal:nth-child(6){transition-delay:.2s}
.reveal:nth-child(7){transition-delay:.1s}
.reveal:nth-child(8){transition-delay:.18s}

/* ============================================================
   Catalogo Prodotti — Mega Menu (desktop) + accordion (mobile)
   Reuses the site navy/gold tokens, button + card styling.
   ============================================================ */
.nav__cat{display:flex;align-items:center}
.nav__cat-trigger{
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
  font-weight:600;font-size:.93rem;color:var(--cream);
  padding:4px 0;position:relative;transition:color .25s ease;
}
.nav__cat-trigger::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--gold);transition:width .3s var(--ease);
}
.nav__cat:hover .nav__cat-trigger,
.nav__cat.is-active .nav__cat-trigger{color:var(--gold)}
.nav__cat:hover .nav__cat-trigger::after,
.nav__cat.is-active .nav__cat-trigger::after{width:100%}
.caret{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s var(--ease);flex:0 0 auto}
.nav__cat:hover .nav__cat-trigger .caret{transform:rotate(180deg)}

.megamenu{
  position:absolute;left:0;right:0;top:100%;
  background:rgba(8,21,37,.97);backdrop-filter:blur(16px);
  border-top:1px solid rgba(201,162,83,.18);
  border-bottom:1px solid rgba(201,162,83,.28);
  box-shadow:0 30px 60px -24px rgba(0,0,0,.7);
  opacity:0;visibility:hidden;transform:translateY(10px);pointer-events:none;
  transition:opacity .28s var(--ease),transform .28s var(--ease),visibility .28s;
  z-index:99;max-height:80vh;overflow-y:auto;
}
.nav__cat:hover .megamenu,
.nav__cat:focus-within .megamenu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.megamenu__inner{padding:26px 28px 32px}
.megamenu__bar{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding-bottom:22px;margin-bottom:22px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.megamenu__search{position:relative;flex:1 1 320px;min-width:240px}
.megamenu__search svg{
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:19px;height:19px;fill:none;stroke:var(--muted);stroke-width:2;
  stroke-linecap:round;pointer-events:none;
}
.megamenu__search input{
  width:100%;padding:13px 20px 13px 48px;border-radius:100px;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.1);
  color:var(--white);font-family:inherit;font-size:.95rem;
  transition:border-color .25s,background .25s;
}
.megamenu__search input::placeholder{color:var(--muted)}
.megamenu__search input:focus{outline:0;border-color:var(--gold);background:var(--navy-800)}
.megamenu__all{flex:0 0 auto}

/* Catalog search autocomplete dropdown */
.catsugg{
  position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:40;
  background:var(--navy-800);border:1px solid rgba(201,162,83,.3);
  border-radius:14px;box-shadow:0 24px 50px -18px rgba(0,0,0,.7);
  overflow:hidden auto;max-height:330px;
}
.catsugg__item{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:11px 16px;border-bottom:1px solid rgba(255,255,255,.05);
}
.catsugg__item:last-child{border-bottom:0}
.catsugg__item:hover,.catsugg__item.is-active{background:rgba(201,162,83,.13)}
.catsugg__label{color:var(--cream);font-weight:600;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.catsugg__note{color:var(--muted);font-size:.73rem;white-space:nowrap;flex:0 0 auto}

.megamenu__layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:24px;align-items:stretch}
.megamenu__cats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.megacat{
  display:flex;align-items:center;gap:13px;min-width:0;
  padding:13px 14px;border-radius:var(--radius-sm);
  border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.015);
  transition:background .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease);
}
.megacat:hover{background:rgba(201,162,83,.08);border-color:rgba(201,162,83,.35);transform:translateY(-2px)}
.megacat__icon{
  flex:0 0 auto;width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(201,162,83,.12);
}
.megacat__icon svg{width:22px;height:22px;fill:none;stroke:var(--gold);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.megacat__text{display:flex;flex-direction:column;gap:2px;min-width:0}
.megacat__title{font-family:var(--font-display);font-weight:600;font-size:.93rem;color:var(--white);line-height:1.2}
.megacat__subs{font-size:.74rem;color:var(--muted);line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.megamenu__promo{
  display:flex;flex-direction:column;
  padding:24px;border-radius:var(--radius-sm);
  background:linear-gradient(160deg,var(--navy-600),var(--navy-700));
  border:1px solid rgba(201,162,83,.22);
}
.megamenu__promo-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.megamenu__promo-title{font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--white);margin:10px 0 8px;line-height:1.25}
.megamenu__promo-text{font-size:.86rem;color:#c4cddd;line-height:1.5;margin-bottom:auto}
.megamenu__promo-cta{display:flex;flex-direction:column;gap:9px;margin-top:18px}
.megamenu__promo-cta .btn{justify-content:center;width:100%}

/* Mobile accordion (hidden on desktop) */
.nav__acc{display:none}
.nav__acc-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
  font-family:var(--font-body);font-weight:700;font-size:1.05rem;color:var(--cream);
  padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);text-align:left;
}
.nav__acc-head .caret,.nav__acc-cat-head .caret{transition:transform .3s var(--ease)}
.nav__acc.is-open>.nav__acc-head .caret{transform:rotate(180deg)}
.nav__acc-panel{display:none;padding:6px 0 4px}
.nav__acc.is-open>.nav__acc-panel{display:block}
.nav__acc-search{margin:14px 0}
.nav__acc-search input{font-size:1rem;padding:13px 18px 13px 46px}
.nav__acc-allbtn{justify-content:center;width:100%;margin-bottom:8px}
.nav__acc-cat{border-bottom:1px solid rgba(255,255,255,.06)}
.nav__acc-cat-head{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  font-weight:600;font-size:.98rem;color:var(--cream);padding:13px 0;
}
.nav__acc-cat-head .megacat__icon{width:34px;height:34px;border-radius:9px}
.nav__acc-cat-head .megacat__icon svg{width:18px;height:18px}
.nav__acc-cat-head>span:nth-child(2){flex:1}
.nav__acc-cat.is-open>.nav__acc-cat-head .caret{transform:rotate(180deg)}
.nav__acc-sub{display:none;padding:2px 0 12px 45px;flex-direction:column;gap:1px}
.nav__acc-cat.is-open>.nav__acc-sub{display:flex}
.nav__acc-sublink{font-size:.9rem;color:var(--muted);padding:7px 0}
.nav__acc-sublink:hover{color:var(--gold)}
.nav__acc-sublink--all{color:var(--gold);font-weight:600}

/* ============================================================
   Catalog hub + category pages
   ============================================================ */
.catgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.catcard{
  display:flex;flex-direction:column;padding:26px;
  border-radius:var(--radius);background:var(--navy-700);
  border:1px solid rgba(255,255,255,.05);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
}
.catcard:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:rgba(201,162,83,.35)}
.catcard__icon{
  width:54px;height:54px;border-radius:14px;margin-bottom:18px;
  display:flex;align-items:center;justify-content:center;background:rgba(201,162,83,.12);
}
.catcard__icon svg{width:28px;height:28px;fill:none;stroke:var(--gold);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.catcard h3{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--white);margin-bottom:10px}
.catcard p{color:var(--muted);font-size:.92rem;margin-bottom:16px;flex:1}
.catcard__link{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--gold);transition:gap .25s,color .25s;display:inline-flex;gap:6px}
.catcard:hover .catcard__link{color:var(--gold-light)}

.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.chips--left{justify-content:flex-start}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 16px;border-radius:100px;font-size:.86rem;font-weight:500;
  background:var(--navy-700);border:1px solid rgba(255,255,255,.08);color:var(--cream);
}
.chip--cust{background:rgba(201,162,83,.1);border-color:rgba(201,162,83,.3);color:var(--gold-light)}
a.chip:hover{border-color:var(--gold);color:var(--gold)}

.cat-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.cat-meta .chip{font-size:.8rem;padding:7px 14px}

.catsection{padding:70px 0}
.catsection--alt{background:var(--navy-900)}
.catsection__head{max-width:680px;margin:0 auto 40px;text-align:center}
.catsection__head .eyebrow{padding-left:0}
.catsection__head .eyebrow::before{display:none}
.catsection__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,2.8vw,2.1rem);color:var(--white);line-height:1.18}
.catsection__intro{margin-top:14px;color:var(--muted);font-size:1rem}

.catbrands{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 26px;
  max-width:760px;margin:0 auto;
}
.catbrands span{color:var(--cream);font-family:var(--font-display);font-weight:600;font-size:1rem;opacity:.85}

/* Mobile nav dimmed backdrop (behind the slide-in panel) */
.nav-backdrop{
  position:fixed;inset:0;z-index:98;
  background:rgba(4,10,20,.62);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),visibility .3s var(--ease);
}
.nav-backdrop.is-show{opacity:1;visibility:visible}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .nav{display:none}
  .burger{display:flex}
  .header__cta{display:none}
  .depts__grid{grid-template-columns:repeat(2,1fr)}
  .why__grid{grid-template-columns:repeat(2,1fr)}
  .hero__inner{grid-template-columns:1fr;gap:48px}
  .hero__frame img{height:420px}
  .about__grid,.tint__grid,.contact__grid{grid-template-columns:1fr;gap:44px}
  .about__media img{height:420px}
  .tint__media{height:380px;margin-top:10px}
  .footer__inner{grid-template-columns:1fr 1fr;gap:36px}

  /* mobile nav panel */
  .nav.is-open{
    display:flex;flex-direction:column;gap:0;
    position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);
    background:#081a33;background:var(--navy-900);
    padding:96px 28px 40px;
    box-shadow:-20px 0 60px -20px rgba(0,0,0,.7);
    z-index:99;overflow-y:auto;overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
  }
  .nav.is-open>a{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:1.05rem}

  /* Catalog: hide desktop trigger/panel, show the accordion */
  .nav__cat{display:block}
  .nav__cat-trigger,.megamenu{display:none}
  .nav.is-open .nav__acc{display:block}
  /* accordion uses buttons/links — neutralise the generic nav link padding */
  .nav.is-open .nav__acc-panel a{border-bottom:0;font-size:inherit}
  .nav.is-open .nav__acc-sublink{padding:7px 0}
  .nav.is-open .nav__acc-allbtn{padding:11px 22px}
  .nav.is-open .nav__acc-allbtn,
  .nav.is-open .nav__acc-sublink--all{color:var(--gold)}
}

@media (min-width:1081px) and (max-width:1280px){
  .nav{gap:16px}
  .nav a,.nav__cat-trigger{font-size:.86rem}
  .header__cta{display:none}
}

@media (max-width:680px){
  .container{padding:0 20px}
  .nav.is-open{width:100%;padding:90px 24px 40px}
  .megamenu__promo-cta{flex-direction:column}
  .section{padding:80px 0}
  .section__head{margin-bottom:44px}
  .hero{padding:130px 0 80px}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{justify-content:center}
  .hero__stats{gap:24px}
  .stat__num{font-size:1.9rem}
  .hero__frame img{height:340px}
  .depts__grid,.why__grid,.gallery__grid{grid-template-columns:1fr}
  .gallery__grid{grid-auto-rows:200px}
  .gallery__item--tall{grid-row:span 1}
  .gallery__item--wide{grid-column:span 1}
  .tint__points{gap:26px}
  .tint__media img:first-child{width:78%}
  .about__media-tag{right:0;max-width:180px;font-size:.85rem;padding:13px 18px}
  .contact__info{padding:30px 24px}
  .footer__inner{grid-template-columns:1fr;gap:32px}
  .footer__bar-inner{justify-content:center;text-align:center}
  .lightbox__nav{width:46px;height:46px}
  .marquee__track span{font-size:.85rem}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   COMPACT POLISH — denser spacing, slightly tighter type.
   Placed at the very end so it cleanly overrides earlier base
   rules at each breakpoint. Only numeric tweaks — no structural
   changes, so anything not overridden falls back to the original.
   ============================================================ */

/* --- Spacing / typography baseline --- */
.section            { padding: 96px 0; }
.section__head      { margin-bottom: 52px; }
.section__title     { font-size: clamp(1.85rem, 3.6vw, 2.7rem); line-height: 1.14; }
.section__intro     { font-size: 1rem; margin-top: 14px; }
.eyebrow            { font-size: .74rem; margin-bottom: 14px; padding-left: 30px; }
.eyebrow::before    { width: 22px; }
.btn                { padding: 14px 26px; font-size: .9rem; }
.btn--sm            { padding: 10px 20px; font-size: .82rem; }

/* --- Hero --- */
.hero               { padding: 130px 0 80px; }
.hero__inner        { gap: 50px; }
.hero__title        { font-size: clamp(2.2rem, 4.7vw, 3.8rem); margin: 6px 0 20px; }
.hero__lead         { font-size: 1.04rem; max-width: 460px; margin-bottom: 30px; }
.hero__actions      { gap: 14px; margin-bottom: 38px; }
.hero__stats        { gap: 32px; }
.stat__num          { font-size: 2.05rem; }
.stat__label        { font-size: .78rem; margin-top: 7px; }
.hero__frame img    { height: 480px; }

/* --- Subhero (Tintometro, Professionisti, profession pages) --- */
.subhero            { padding: 130px 0 75px; }
.subhero .hero__frame img { height: 420px; }

/* --- Trust bar --- */
.trustbar           { padding: 14px 0; }
.trustbar__item     { font-size: .82rem; gap: 9px; }
.trustbar__item svg { width: 20px; height: 20px; }

/* --- About --- */
.about__grid        { gap: 52px; }
.about__media img   { height: 480px; }
.about__copy p      { font-size: .98rem; }
.ticks              { margin: 22px 0 26px; }
.ticks li           { font-size: .98rem; margin-bottom: 10px; }

/* --- Departments / Soluzioni cards --- */
.depts__grid        { gap: 22px; }
.dept__img          { height: 210px; }
.dept__body         { padding: 22px 22px 26px; }
.dept__body h3      { font-size: 1.12rem; }
.dept__body p       { font-size: .9rem; }
.dept__no           { font-size: 2.2rem; right: 22px; top: -22px; }

/* --- Tintometro module --- */
.tint__lead         { font-size: 1.05rem; margin: 6px 0 26px; }
.tint__points       { gap: 34px; margin-bottom: 28px; }
.tint__big          { font-size: 2.6rem; }

/* --- Why us features --- */
.why__grid          { gap: 22px; }
.feature            { padding: 30px 24px; }
.feature__icon      { width: 52px; height: 52px; margin-bottom: 18px; }
.feature h3         { font-size: 1.05rem; margin-bottom: 8px; }
.feature p          { font-size: .9rem; }

/* --- Mandaci una foto band --- */
.band               { padding: 104px 0; }
.band__inner h2     { font-size: clamp(1.7rem, 3.2vw, 2.5rem); margin-bottom: 14px; }
.band__inner p      { font-size: 1rem; margin-bottom: 24px; }

/* --- Brands strip --- */
.brands             { padding: 78px 0; }
.brands__track .bm  { margin-right: 24px; font-size: 1.2rem; height: 70px; padding: 0 24px; }
.brands__track .bm img { height: 40px; max-width: 300px; }

/* --- Gallery --- */
.gallery__grid      { gap: 16px; grid-auto-rows: 200px; }

/* --- Contact --- */
.contact__grid      { gap: 40px; }
.contact__info      { padding: 36px; }
.info               { gap: 16px; margin-bottom: 24px; }
.info__icon         { width: 44px; height: 44px; }
.info__icon svg     { width: 22px; height: 22px; }
.info h4            { font-size: .98rem; }
.info p             { font-size: .92rem; }
.contact__map,
.contact__map iframe{ min-height: 400px; }

/* --- Professionisti form --- */
.profform           { padding: 36px; }
.profform__grid     { gap: 14px 20px; }
.field input,
.field select,
.field textarea     { padding: 11px 13px; font-size: .92rem; }

/* --- Footer --- */
.footer             { padding: 56px 0 0; }
.footer__inner      { padding-bottom: 42px; gap: 40px; }
.footer h4          { margin-bottom: 14px; }

/* --- Business card --- */
.vcard__stage       { gap: 24px; }

/* --- Sol section CTA --- */
.sol__cta           { margin-top: 36px; }

/* When a depts__grid has exactly 6 cards (Soluzioni on home, Per chi on
   the Professionisti page), break it as 3×2 rather than the default 4×2
   which leaves an awkward orphan row of 2. */
.depts__grid:has(> :nth-child(6):last-child) { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) {
  .depts__grid:has(> :nth-child(6):last-child) { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .depts__grid:has(> :nth-child(6):last-child) { grid-template-columns: 1fr; }
}

/* ============================================================
   Mobile polish — keep things breathing on small screens.
   ============================================================ */
@media (max-width: 1080px) {
  .hero__inner             { gap: 40px; }
  .hero__frame img         { height: 400px; }
  .subhero .hero__frame img{ height: 380px; }
  .about__media img        { height: 440px; }
}
@media (max-width: 680px) {
  .section                 { padding: 60px 0; }
  .section__head           { margin-bottom: 36px; }
  .hero                    { padding: 110px 0 56px; }
  .subhero                 { padding: 100px 0 50px; }
  .hero__title             { margin-bottom: 16px; }
  .hero__lead              { font-size: 1rem; margin-bottom: 24px; }
  .hero__actions           { margin-bottom: 30px; }
  .hero__stats             { gap: 22px; }
  .stat__num               { font-size: 1.7rem; }
  .stat__label             { font-size: .72rem; max-width: 110px; }
  .hero__frame img         { height: 300px; }
  .subhero .hero__frame img{ height: 280px; }
  .about__grid             { gap: 36px; }
  .about__media img        { height: 340px; }
  .dept__img               { height: 200px; }
  .dept__body              { padding: 20px 20px 24px; }
  .band                    { padding: 76px 0; }
  .feature                 { padding: 24px 20px; }
  .feature__icon           { width: 46px; height: 46px; margin-bottom: 14px; }
  .contact__info           { padding: 24px 22px; }
  .profform                { padding: 24px 22px; }
  .gallery__grid           { gap: 12px; grid-auto-rows: 180px; }
  .footer__inner           { padding-bottom: 30px; gap: 28px; }
  .footer                  { padding: 48px 0 0; }
  .vcard__stage            { gap: 18px; }
  .brands                  { padding: 56px 0; }
  .brands__track .bm       { margin-right: 16px; font-size: 1rem; height: 60px; padding: 0 18px; }
  .brands__track .bm img   { height: 34px; max-width: 240px; }
}

/* ============================================================
   Mobile compaction — phones only. Slightly smaller images and
   headings so pages read cleaner / less "zoomed in".
   Desktop is untouched (everything here is inside phone queries).
   ============================================================ */
@media (max-width: 680px) {
  /* Headings a notch smaller */
  .hero__title              { font-size: 1.85rem; }
  .subhero .hero__title     { font-size: 1.65rem; }
  .section__title           { font-size: 1.5rem; }
  .catsection__title        { font-size: 1.38rem; }
  .band__inner h2           { font-size: 1.5rem; }
  .hero__lead               { font-size: .95rem; }
  .section__intro,
  .catsection__intro        { font-size: .92rem; }
  .dept__body h3            { font-size: 1.05rem; }

  /* Images shorter so they don't dominate the screen */
  .hero__frame img          { height: 240px; }
  .subhero .hero__frame img { height: 210px; }
  .about__media img         { height: 270px; }
  .dept__img                { height: 168px; }

  /* Catalog chips + cards tighter */
  .chip                     { font-size: .8rem; padding: 8px 13px; }
  .cat-meta                 { gap: 8px; margin-top: 18px; }
  .cat-meta .chip           { font-size: .74rem; padding: 6px 12px; }
  .chips                    { gap: 8px; }
  .catsection              { padding: 52px 0; }
  .catsection__head         { margin-bottom: 28px; }
  .catcard                  { padding: 22px; }
  .catcard__icon            { width: 48px; height: 48px; margin-bottom: 14px; }
  .catcard h3               { font-size: 1.08rem; }
  .catbrands                { gap: 12px 20px; }
  .catbrands span           { font-size: .92rem; }
}

@media (max-width: 430px) {
  .hero__frame img          { height: 210px; }
  .subhero .hero__frame img { height: 188px; }
  .about__media img         { height: 240px; }
  .dept__img                { height: 158px; }
  .hero__title              { font-size: 1.65rem; }
  .subhero .hero__title     { font-size: 1.5rem; }
  .section__title           { font-size: 1.4rem; }
}
