/* ============================================================
   AP Interior Solutions — sections & components
   ============================================================ */

/* ---------------- HERO ---------------- */
.hero{min-height:100svh;display:flex;align-items:flex-end;position:relative;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:-8% 0 0 0;z-index:-2;will-change:transform}
.hero-bg img{width:100%;height:116%;object-fit:cover;object-position:center 60%}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(120% 80% at 75% 15%,rgba(11,12,11,0) 0%,rgba(11,12,11,.35) 55%,rgba(11,12,11,.9) 100%),
    linear-gradient(180deg,rgba(8,9,8,.74) 0%,rgba(8,9,8,.30) 30%,rgba(8,9,8,.55) 68%,var(--ink) 100%);
}
.hero-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut) clamp(96px,15vh,170px);
  display:grid;gap:46px;grid-template-columns:1fr;align-items:end}
@media(min-width:980px){.hero-inner{grid-template-columns:minmax(0,1.55fr) minmax(280px,.85fr)}}
.hero h1{font-size:clamp(2.7rem,6.4vw,5.7rem);font-weight:700;letter-spacing:-.038em;max-width:16ch}
.hero .lead{max-width:54ch;margin-top:1.4em;color:#dfe1d8}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:2.1em}
.hero-phone{display:flex;flex-direction:column;gap:6px;align-self:end;padding-bottom:6px}
.hero-phone .pe{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:.82rem;color:var(--lime)}
.hero-phone .pn{font-size:clamp(1.8rem,3vw,2.7rem);font-weight:700;letter-spacing:-.02em;line-height:1;color:#fff}
.hero-phone .pl{color:var(--muted);font-family:"Barlow Condensed",sans-serif;letter-spacing:.12em;text-transform:uppercase;font-size:.92rem}
.hero-phone .pn:hover{color:var(--lime)}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted);
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.25em;font-size:.7rem}
.scroll-cue .dot{width:22px;height:36px;border:1.5px solid var(--line-strong);border-radius:14px;position:relative}
.scroll-cue .dot::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:3px;background:var(--lime);transform:translateX(-50%);animation:cue 1.6s infinite}
@keyframes cue{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* trust strip */
.trust{display:flex;flex-wrap:wrap;gap:14px 30px;align-items:center;border-top:1px solid var(--line);
  padding-top:26px;margin-top:8px}
.trust .ti{display:flex;align-items:center;gap:10px;color:var(--muted);font-family:"Barlow Condensed",sans-serif;
  text-transform:uppercase;letter-spacing:.14em;font-size:.95rem}
.trust .ti svg{width:20px;height:20px;color:var(--lime)}

/* ---------------- LEAD FORM BAND ---------------- */
.leadband{position:relative;background:var(--ink-2);overflow:hidden}
.leadband .photo{position:absolute;inset:0;z-index:0}
.leadband .photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) brightness(.4)}
.leadband::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(8,9,8,.93) 0%,rgba(8,9,8,.78) 45%,rgba(84,171,4,.30) 100%)}
.leadband .wrap{position:relative;z-index:2}
.leadgrid{display:grid;gap:clamp(34px,5vw,80px);align-items:center}
@media(min-width:920px){.leadgrid{grid-template-columns:1fr 1.05fr}}
.lead-copy h2{margin-top:.35em;max-width:14ch}
.lead-points{list-style:none;padding:0;margin:1.6em 0 0;display:grid;gap:14px}
.lead-points li{display:flex;gap:12px;align-items:flex-start;color:var(--muted)}
.lead-points svg{width:22px;height:22px;color:var(--lime);flex:none;margin-top:2px}
.lead-points b{color:var(--fg)}

.form-card{background:rgba(13,15,11,.72);border:1px solid var(--line-strong);backdrop-filter:blur(10px);
  border-radius:22px;padding:clamp(26px,3.4vw,44px);box-shadow:var(--shadow)}
.form-card h3{margin-bottom:.2em}
.form-card .sub{color:var(--muted);margin-bottom:1.4em;font-size:.98rem}
.field{margin-bottom:16px;position:relative}
.field label{display:block;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.14em;font-size:.85rem;color:var(--muted);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;background:rgba(255,255,255,.04);border:1.5px solid var(--line);border-radius:12px;
  color:var(--fg);font:inherit;padding:.85em 1em;transition:border-color .25s,background .25s}
.field textarea{min-height:108px;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%236BD804' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--lime);background:rgba(107,216,4,.06)}
.field.err input,.field.err select,.field.err textarea{border-color:#ff6b5e}
.field .msg{color:#ff8a80;font-size:.8rem;margin-top:6px;display:none}
.field.err .msg{display:block}
.row-2{display:grid;gap:16px}
@media(min-width:560px){.row-2{grid-template-columns:1fr 1fr}}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.form-card .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.78rem;color:var(--muted-2);margin:14px 0 0;text-align:center}
.form-success{display:none;text-align:center;padding:18px 0}
.form-success.show{display:block;animation:pop .5s cubic-bezier(.2,1.4,.4,1)}
.form-success .ok{width:74px;height:74px;border-radius:50%;background:var(--lime);color:#06250a;
  display:grid;place-items:center;margin:0 auto 18px}
.form-success .ok svg{width:38px;height:38px}
@keyframes pop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:none}}
.form-card.sent .form-body{display:none}

/* ---------------- STAT COUNTERS ---------------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{background:var(--ink-2);padding:clamp(26px,3vw,40px) 22px;text-align:center}
.stat .num{font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1}
.stat .num .u{color:var(--lime)}
.stat .lab{margin-top:10px;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.16em;font-size:.88rem;color:var(--muted)}

/* ---------------- SERVICE CARDS ---------------- */
.svc-grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:620px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.svc-grid{grid-template-columns:repeat(4,1fr)}}
.svc{position:relative;border-radius:20px;overflow:hidden;min-height:380px;display:flex;
  align-items:flex-end;color:#fff;border:1px solid var(--line);
  transform-style:preserve-3d;transition:transform .3s ease,box-shadow .3s ease;will-change:transform}
.svc .bg{position:absolute;inset:0;z-index:0}
.svc .bg img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.svc::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(7,8,7,0) 28%,rgba(7,8,7,.55) 60%,rgba(6,7,6,.96) 100%)}
.svc .body{position:relative;z-index:2;padding:26px;transform:translateZ(40px)}
.svc .ic{width:48px;height:48px;border-radius:12px;background:rgba(107,216,4,.16);border:1px solid var(--lime);
  display:grid;place-items:center;color:var(--lime);margin-bottom:16px}
.svc .ic svg{width:24px;height:24px}
.svc h3{font-size:1.32rem}
.svc p{color:#cdd0c6;font-size:.92rem;margin:.5em 0 0;max-height:0;opacity:0;overflow:hidden;
  transition:max-height .5s ease,opacity .4s ease,margin .4s}
.svc:hover{box-shadow:0 40px 80px -40px #000}
.svc:hover .bg img{transform:scale(1.07)}
.svc:hover p{max-height:140px;opacity:1;margin-top:.7em}
.svc .num-tag{position:absolute;top:20px;right:22px;z-index:2;font-family:"Barlow Condensed",sans-serif;
  font-size:.92rem;letter-spacing:.2em;color:var(--lime)}

/* ---------------- EDITORIAL FEATURE ---------------- */
.feature{display:grid;gap:clamp(34px,5vw,72px);align-items:center}
@media(min-width:920px){.feature{grid-template-columns:1fr 1fr}.feature.flip .feat-media{order:2}}
.feat-copy .lead{margin-bottom:1.6em}
.feat-list{list-style:none;padding:0;margin:0 0 2em;display:grid;gap:12px}
.feat-list li{display:flex;gap:12px;align-items:center;color:var(--muted)}
.feat-list svg{width:20px;height:20px;color:var(--lime);flex:none}
.feat-media{position:relative}
.feat-stack{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.feat-stack img{width:100%;height:100%;object-fit:cover;border-radius:16px}
.feat-stack .tall{grid-row:span 2;height:100%}
.feat-stack .lo{height:200px}
.feat-badge{position:absolute;z-index:4;background:var(--lime);color:#06250a;border-radius:16px;
  padding:18px 22px;box-shadow:var(--shadow);bottom:-22px;left:-10px;max-width:200px}
.feat-badge .bn{font-size:1.9rem;font-weight:700;line-height:1}
.feat-badge .bl{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;font-weight:600}
.feat-single img{width:100%;border-radius:18px;aspect-ratio:4/3;object-fit:cover}

/* ---------------- BEFORE / AFTER SLIDER ---------------- */
.ba{position:relative;width:100%;aspect-ratio:16/10;border-radius:18px;overflow:hidden;
  user-select:none;touch-action:none;border:1px solid var(--line);box-shadow:var(--shadow);cursor:ew-resize}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after-wrap{position:absolute;inset:0;clip-path:inset(0 50% 0 0)}
.ba .after-wrap img{width:100%;height:100%}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--lime);z-index:3;transform:translateX(-50%)}
.ba .handle .grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;
  border-radius:50%;background:var(--lime);color:#06250a;display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.ba .handle .grip svg{width:26px;height:26px}
.ba .tag{position:absolute;top:16px;z-index:3;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.18em;font-size:.78rem;background:rgba(7,8,7,.7);padding:.5em .9em;border-radius:60px;backdrop-filter:blur(6px)}
.ba .tag.b{left:16px}.ba .tag.a{right:16px;color:var(--lime)}

/* ---------------- WHY CHOOSE US ---------------- */
.why{background:var(--paper);color:var(--paper-ink)}
.why .eyebrow{color:var(--lime-deep)}
.why .eyebrow::before{background:var(--lime-deep)}
.why h2{color:var(--paper-ink)}
.why-grid{display:grid;gap:28px;margin-top:48px}
@media(min-width:860px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-card{padding:34px 30px;background:rgba(255,255,255,.5);border:1px solid rgba(22,24,15,.10);border-radius:18px;
  transition:transform .35s,box-shadow .35s,background .35s}
.why-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(22,24,15,.4);background:#fff}
.why-card .ic{width:56px;height:56px;border-radius:14px;background:var(--paper-ink);color:var(--lime);
  display:grid;place-items:center;margin-bottom:20px}
.why-card .ic svg{width:28px;height:28px}
.why-card h3{color:var(--paper-ink);margin-bottom:.4em}
.why-card p{color:#4b4e40;margin:0;font-size:.98rem}

/* ---------------- GALLERY + LIGHTBOX ---------------- */
.gal-filters{display:flex;flex-wrap:wrap;gap:10px;margin:34px 0 36px}
.gal-filters button{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.14em;
  font-size:.95rem;color:var(--muted);background:transparent;border:1.5px solid var(--line-strong);
  padding:.6em 1.3em;border-radius:60px;cursor:pointer;transition:.25s}
.gal-filters button:hover{color:var(--fg);border-color:var(--fg)}
.gal-filters button.on{background:var(--lime);border-color:var(--lime);color:#06250a}
.gal{columns:1;column-gap:16px}
@media(min-width:600px){.gal{columns:2}}
@media(min-width:980px){.gal{columns:3}}
.gal figure{break-inside:avoid;margin:0 0 16px;position:relative;border-radius:14px;overflow:hidden;cursor:pointer;
  border:1px solid var(--line);transition:opacity .4s,transform .4s}
.gal figure img{width:100%;display:block;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.gal figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,7,6,.85));opacity:0;transition:.35s}
.gal figure figcaption{position:absolute;left:16px;bottom:14px;z-index:2;opacity:0;transform:translateY(8px);
  transition:.35s;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.88rem}
.gal figure .plus{position:absolute;top:14px;right:14px;z-index:2;width:38px;height:38px;border-radius:50%;
  background:var(--lime);color:#06250a;display:grid;place-items:center;opacity:0;transform:scale(.6);transition:.35s}
.gal figure:hover img{transform:scale(1.06)}
.gal figure:hover::after,.gal figure:hover figcaption,.gal figure:hover .plus{opacity:1;transform:none}
.gal figure.hide{display:none}

.lightbox{position:fixed;inset:0;z-index:90;background:rgba(5,6,5,.95);display:none;
  align-items:center;justify-content:center;padding:5vw;backdrop-filter:blur(6px)}
.lightbox.open{display:flex;animation:fade .3s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:100%;max-height:86vh;border-radius:10px;box-shadow:0 40px 90px rgba(0,0,0,.7)}
.lb-btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid var(--line-strong);color:#fff;
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:.25s}
.lb-btn:hover{background:var(--lime);color:#06250a;border-color:var(--lime)}
.lb-btn svg{width:26px;height:26px}
.lb-close{top:24px;right:24px}.lb-prev{left:3vw}.lb-next{right:3vw}
.lb-cap{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:var(--muted);
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.9rem}

/* ---------------- SERVICE AREA / MAP ---------------- */
.area{background:var(--ink-2)}
.area-grid{display:grid;gap:clamp(30px,4vw,60px);align-items:center}
@media(min-width:920px){.area-grid{grid-template-columns:.9fr 1.1fr}}
.area .chips{display:flex;flex-wrap:wrap;gap:10px;margin:1.7em 0 2em}
.area .chips span{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;
  font-size:.92rem;color:var(--fg);background:rgba(255,255,255,.05);border:1px solid var(--line);
  padding:.5em 1em;border-radius:60px}
.map-frame{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line-strong);
  box-shadow:var(--shadow);aspect-ratio:16/11;background:#10120e}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.35) contrast(.92) brightness(.92)}
.map-frame::after{content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),inset 0 -60px 80px -50px rgba(7,8,7,.9)}
.map-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);z-index:2;pointer-events:none;
  color:var(--lime);filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}
.map-pin svg{width:46px;height:46px}
.map-card{position:absolute;left:16px;bottom:16px;z-index:2;background:rgba(10,12,9,.86);backdrop-filter:blur(8px);
  border:1px solid var(--line-strong);border-radius:14px;padding:14px 18px;max-width:230px}
.map-card .mc-n{font-weight:600}
.map-card .mc-s{color:var(--muted);font-size:.85rem;font-family:"Barlow Condensed",sans-serif;
  text-transform:uppercase;letter-spacing:.12em}

/* ---------------- FOOTER ---------------- */
.foot{background:#070807;border-top:1px solid var(--line);position:relative}
.foot-cta{text-align:center;padding-block:clamp(56px,8vh,96px);border-bottom:1px solid var(--line)}
.foot-cta h2{max-width:18ch;margin:0 auto .3em}
.foot-cta .lead{max-width:46ch;margin:0 auto 2em}
.foot-cta .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.foot-grid{display:grid;gap:40px;padding-block:clamp(48px,7vh,80px)}
@media(min-width:820px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr}}
.foot h4{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.18em;
  font-size:1rem;color:var(--muted);margin-bottom:18px;font-weight:600}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.foot ul a,.foot .ci{color:var(--fg);transition:color .25s;display:inline-flex;align-items:center;gap:10px}
.foot ul a:hover{color:var(--lime)}
.foot .ci svg{width:18px;height:18px;color:var(--lime);flex:none}
.foot .big-num{font-size:1.6rem;font-weight:700;letter-spacing:-.02em}
.foot .big-num:hover{color:var(--lime)}
.foot-brand p{color:var(--muted);max-width:34ch}
.foot-bottom{border-top:1px solid var(--line);padding-block:24px;display:flex;flex-wrap:wrap;gap:12px;
  justify-content:space-between;align-items:center;color:var(--muted-2);font-size:.85rem}

/* ---------------- FLOATING WHATSAPP + MOBILE BAR ---------------- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:55;width:60px;height:60px;border-radius:50%;
  background:var(--wa);color:#fff;display:grid;place-items:center;box-shadow:0 14px 34px rgba(37,211,102,.45);
  transition:transform .3s;animation:wapulse 2.6s infinite}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px}
@keyframes wapulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:54;display:none;
  grid-template-columns:1fr 1fr;gap:1px;background:var(--line);transform:translateY(110%);transition:transform .4s}
.mobile-bar.show{transform:none}
.mobile-bar a{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-weight:600;font-size:1.02rem}
.mobile-bar .m-call{background:var(--lime);color:#06250a}
.mobile-bar .m-wa{background:var(--wa);color:#04230f}
.mobile-bar a svg{width:20px;height:20px}
@media(max-width:760px){.mobile-bar{display:grid}.wa-float{bottom:84px}}
