@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-ExtraBold.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("../fonts/Poppins/Poppins-Black.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../fonts/Roboto/static/Roboto-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../fonts/Roboto/static/Roboto-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../fonts/Roboto/static/Roboto-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../fonts/Roboto/static/Roboto-Black.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap}

:root{--bg:#ffffff;--surface:#ffffff;--text:#111827;--muted:#6b7280;--primary:#1f2933;--secondary:#111827;--accent:#22c55e;--border:#e5e7eb;--radius:18px;--radius-sm:14px;--shadow:0 18px 45px rgba(15,23,42,.10);--shadow-soft:0 10px 30px rgba(15,23,42,.08);--transition-fast:.18s ease-out;--transition-med:.28s cubic-bezier(.22,.61,.36,1)}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,Cantarell,"Noto Sans",Arial,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
button,a{cursor:pointer}

.container{width:100%;max-width:1100px;margin:0 auto;padding:24px}

.skip-link{position:absolute;left:-9999px;top:-9999px}
.skip-link:focus{left:16px;top:16px;background:var(--primary);color:#fff;padding:10px 12px;border-radius:8px;z-index:50}

.site-header{position:relative;z-index:2500;background:rgba(248,250,252,.92);border-bottom:1px solid rgba(226,232,240,.9);backdrop-filter:saturate(150%) blur(8px);transition:background var(--transition-med),border-color var(--transition-med),box-shadow var(--transition-med)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;gap:12px;max-width:1200px;margin:0 auto;transition:padding var(--transition-med)}
.site-header--scrolled{box-shadow:0 14px 40px rgba(15,23,42,.18);background:rgba(15,23,42,.94);border-color:transparent}
.site-header--scrolled .site-header__inner{padding:10px 18px}
.site-header--scrolled .nav__link,.site-header--scrolled .nav__dropdown-toggle{color:#e5e7eb}
.site-header--scrolled .nav__link[aria-current="page"]{color:#f9fafb;border-bottom-color:#f9fafb}
.site-header--scrolled .brand__logo{filter:brightness(1.05)}
.nav{margin-left:auto}
.brand{display:flex;align-items:center;gap:8px;text-decoration:none}
.brand__logo{height:64px;width:auto;transition:transform var(--transition-med),filter var(--transition-med)}
@media(min-width:1024px){.brand__logo{height:72px}}
.nav__toggle{appearance:none;border:none;background:transparent;padding:8px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--transition-fast);position:relative;z-index:90}
.nav__toggle:active{transform:scale(.96)}
.nav__icon{position:relative;width:22px;height:18px;display:inline-block}
.nav__icon-bar{position:absolute;left:0;right:0;height:2px;border-radius:999px;background:var(--secondary);transition:transform var(--transition-fast),opacity var(--transition-fast),top var(--transition-fast),bottom var(--transition-fast)}
.nav__icon-bar:nth-child(1){top:2px}
.nav__icon-bar:nth-child(2){top:8px}
.nav__icon-bar:nth-child(3){bottom:2px}
.nav__toggle--open .nav__icon-bar:nth-child(1){top:8px;transform:rotate(45deg)}
.nav__toggle--open .nav__icon-bar:nth-child(2){opacity:0}
.nav__toggle--open .nav__icon-bar:nth-child(3){bottom:8px;transform:rotate(-45deg)}
.site-header--scrolled .nav__icon-bar{background:#f9fafb}

.nav{position:relative}
.nav__menu{list-style:none;margin:0;padding:0;display:none;flex-direction:column;gap:8px}
.nav__menu.is-open{display:flex}
.nav__item{position:relative}
.nav__link{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;color:var(--text);text-decoration:none;font-weight:500;letter-spacing:.03em;font-size:.95rem;line-height:1;border-bottom:2px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}
.nav__link:hover{color:var(--primary);transform:translateY(-1px)}
.nav__link[aria-current="page"]{color:var(--primary);border-bottom:2px solid var(--primary)}

.nav__dropdown-toggle{appearance:none;background:transparent;border:none}
.nav__dropdown{position:absolute;right:0;top:100%;margin-top:2px;list-style:none;margin-left:0;margin-right:0;margin-bottom:0;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);min-width:260px;opacity:0;visibility:hidden;transform:translateY(6px);pointer-events:none;transition:opacity .16s ease-out,transform .16s ease-out,visibility 0s linear .16s;z-index:50}
.nav__dropdown::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}
.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown:focus-within .nav__dropdown,
.nav__item--dropdown.is-open .nav__dropdown{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;transition:opacity .16s ease-out,transform .16s ease-out,visibility 0s}
.nav__dropdown-item{}
.nav__dropdown-link{display:block;padding:8px 10px;border-radius:8px;color:var(--text);text-decoration:none;font-weight:700}
.nav__dropdown-link:focus,.nav__dropdown-link:hover{background:var(--bg)}

@media(min-width:768px){
  .nav__menu{position:static;inset:auto;width:auto;max-width:none;padding:0;display:flex;flex-direction:row;gap:18px;justify-content:flex-end;background:transparent;box-shadow:none;transform:none;opacity:1;visibility:visible}
  .nav__menu.is-open{display:flex}
  .nav__toggle{display:none}
}

@media(max-width:767.98px){
  body::before{content:"";position:fixed;inset:0;background:rgba(15,23,42,.52);opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition-med),visibility 0s linear var(--transition-med);z-index:1700}
  html.is-nav-open body{overflow:hidden}
  html.is-nav-open body::before{opacity:1;visibility:visible;pointer-events:auto;transition:opacity var(--transition-med),visibility 0s}
  .site-header{position:sticky;top:0;z-index:1800}
  html.is-nav-open .site-header{backdrop-filter:none}
  .nav__toggle{z-index:2100}
  .nav__menu{padding:80px 24px 24px;position:fixed;top:0;right:0;bottom:0;left:auto;height:100dvh;height:100vh;width:260px;max-width:80%;background:var(--surface);display:flex;flex-direction:column;gap:12px;box-shadow:-24px 0 60px rgba(15,23,42,.32);transform:translateX(100%);opacity:0;visibility:hidden;pointer-events:none;transition:transform var(--transition-med),opacity var(--transition-med),visibility 0s linear .28s;z-index:2000;overflow-y:auto}
  .nav__menu.is-open{transform:translateX(0);opacity:1;visibility:visible;pointer-events:auto;transition:transform var(--transition-med),opacity var(--transition-med),visibility 0s}

  .nav__dropdown{position:static;right:auto;top:auto;margin-top:8px;min-width:0;width:100%;padding:6px 0 0;background:transparent;border:0;border-radius:0;box-shadow:none;transform:none;opacity:1;visibility:visible;pointer-events:auto;display:none}
  .nav__dropdown::before{display:none}
  .nav__item--dropdown.is-open .nav__dropdown{display:block}
  .nav__dropdown-link{padding:10px 12px;border-radius:10px;font-weight:600}
}

.main{display:block}
.section{padding:32px 0;background:#ffffff}
.section--muted{background:#ececec}
.section--dark{background:#444444}
.section--dark .section__title{color:#fff}
.section--dark .section__subtitle{color:#e0e2e6}
.section__header{padding:0 24px;text-align:center;max-width:1000px;margin:0 auto}
.section__title{font-size:clamp(2.1rem,4vw,2.6rem);margin:0 0 8px;font-weight:800;letter-spacing:.02em}
.section__subtitle{color:var(--muted);font-size:1.02rem;max-width:52rem;margin:0 auto}

.counters{color:#fff;padding:34px 0;position:relative;overflow:hidden;isolation:isolate;background:radial-gradient(1200px circle at 18% 22%,rgba(34,197,94,.22),transparent 55%),radial-gradient(980px circle at 85% 30%,rgba(99,102,241,.20),transparent 55%),linear-gradient(180deg,#0b1220 0%,#070b12 100%)}
.counters::before{content:"";position:absolute;inset:-2px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 1px,transparent 1px 44px),repeating-linear-gradient(0deg,rgba(255,255,255,.06) 0 1px,transparent 1px 44px);opacity:.18;pointer-events:none;z-index:0}
.counters::after{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 55% 18%,rgba(255,255,255,.10),transparent 54%);filter:blur(18px);opacity:.55;pointer-events:none;z-index:0}
.counters__grid{max-width:1100px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr;gap:14px;text-align:center;position:relative;z-index:1}
@media(min-width:768px){.counters__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}}
.counter{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:18px 16px;border-radius:22px;border:1px solid rgba(148,163,184,.22);background:rgba(255,255,255,.04);box-shadow:0 18px 55px rgba(0,0,0,.38);backdrop-filter:blur(10px);position:relative;min-height:142px;transition:transform var(--transition-med),box-shadow var(--transition-med),border-color var(--transition-med),background var(--transition-med)}
.counter::before{content:"";position:absolute;left:14px;right:14px;top:12px;height:2px;border-radius:999px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.9) 20%,rgba(255,255,255,.9) 80%,transparent 100%);opacity:.85;pointer-events:none}
.counter:hover{transform:translateY(-4px);border-color:rgba(148,163,184,.38);background:rgba(255,255,255,.055);box-shadow:0 26px 72px rgba(0,0,0,.5)}
.counter__label{text-transform:uppercase;font-weight:700;letter-spacing:.18em;margin:0;line-height:1;font-size:.78rem;color:#fff}
.counter__value{font-size:clamp(2.05rem,5.8vw,4rem);font-weight:900;letter-spacing:-.02em;line-height:1;margin:0;font-variant-numeric:tabular-nums;color:#fff;background:none;-webkit-background-clip:border-box;background-clip:border-box;text-shadow:none}
.counter__subtitle{text-transform:uppercase;font-weight:700;letter-spacing:.14em;margin:0;line-height:1.25;font-size:.78rem;color:#fff;max-width:30ch}

.quality{background:var(--bg)}
.quality__hero{max-width:1204px;margin:0 auto;padding:0 24px}
.quality__hero-card{display:grid;grid-template-columns:1fr;gap:0;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);overflow:hidden}
@media(min-width:768px){.quality__hero-card{grid-template-columns:1fr 1fr}}
.quality__image{width:100%;height:100%;object-fit:cover;border-radius:0}
.quality__content{padding:24px}
.quality__eyebrow{color:var(--muted);font-weight:600;letter-spacing:.2px;margin:0 0 6px}
.quality__title{font-size:clamp(2.3rem,5vw,2.9rem);line-height:1.15;margin:0 0 14px;font-weight:800;color:var(--text)}

.cards--quality{grid-template-columns:1fr;gap:12px;justify-content:center;justify-items:center}
@media(min-width:640px){.cards--quality{grid-template-columns:repeat(2,minmax(240px,280px))}}
@media(min-width:1024px){.cards--quality{grid-template-columns:repeat(4,minmax(240px,280px))}}
.card--feature .card__title{font-weight:700}
.card--feature .card__media{aspect-ratio:3/2}
.card--feature .card__body{padding:12px}
.card--feature .card__title{font-size:16px;margin:0 0 6px}
.card--feature .card__text{font-size:14px}

.btn--soft{background:var(--bg);border-color:var(--border)}

.banner{padding:0;position:relative;isolation:isolate}
.banner__image{width:100%;height:clamp(260px,38vw,460px);object-fit:cover;border-radius:0}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.45) 0%,rgba(15,23,42,.25) 55%,rgba(15,23,42,.15) 100%);pointer-events:none;z-index:1}
.banner__overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center}
.banner__content{width:100%;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:14px}
.banner__headline{margin:0;color:#fff;font-weight:900;letter-spacing:.02em;text-transform:none;font-size:clamp(1.55rem,3.6vw,3rem);line-height:1.08;text-shadow:0 1px 0 rgba(0,0,0,.65),0 2px 0 rgba(0,0,0,.45),0 10px 22px rgba(0,0,0,.55),0 26px 64px rgba(0,0,0,.6);filter:drop-shadow(0 10px 28px rgba(0,0,0,.28));animation:banner-headline-enter .9s cubic-bezier(.22,.61,.36,1) both}

@keyframes banner-headline-enter{
  0%{opacity:0;transform:translateY(12px) scale(.985);filter:blur(5px) drop-shadow(0 0 0 rgba(0,0,0,0));text-shadow:0 1px 0 rgba(0,0,0,.25),0 8px 18px rgba(0,0,0,.2),0 18px 40px rgba(0,0,0,.15)}
  60%{opacity:1;transform:translateY(0) scale(1);filter:blur(0) drop-shadow(0 10px 28px rgba(0,0,0,.28));text-shadow:0 1px 0 rgba(0,0,0,.65),0 2px 0 rgba(0,0,0,.45),0 12px 26px rgba(0,0,0,.6),0 30px 70px rgba(0,0,0,.62)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0) drop-shadow(0 10px 28px rgba(0,0,0,.28));text-shadow:0 1px 0 rgba(0,0,0,.65),0 2px 0 rgba(0,0,0,.45),0 10px 22px rgba(0,0,0,.55),0 26px 64px rgba(0,0,0,.6)}
}

@media (prefers-reduced-motion: reduce){
  .banner__headline{animation:none}
}

.page-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px;padding:0 18px}
@media(min-width:1024px){.page-grid{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}}
.about__title{font-size:clamp(2.1rem,4.6vw,2.7rem);margin:0 0 10px;font-weight:800}
.about__subtitle{font-size:clamp(1.3rem,3.2vw,1.6rem);margin:18px 0 8px;font-weight:700}
.about__block-title{font-size:1.05rem;margin:8px 0;font-weight:700}
.about__text{margin:0 0 10px;color:var(--text);font-size:1.05rem;line-height:1.7}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:16px}
.panel__title{margin:0 0 10px;font-size:24px}
.panel__subtitle{margin:0 0 12px;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 12px}
.chip{display:inline-flex;align-items:center;padding:8px 12px;background:var(--secondary);color:#fff;border-radius:999px;font-weight:700;letter-spacing:.2px}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:768px){.gallery{grid-template-columns:repeat(4,1fr)}}
.gallery img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:12px}

.portfolio-media{display:flex;flex-direction:column;min-height:0}
.portfolio-media__main{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover}
@media(min-width:768px){.portfolio-media__main{aspect-ratio:4/3}}

.portfolio-thumbs{display:grid;grid-auto-flow:column;grid-auto-columns:72px;gap:10px;padding:12px;background:rgba(17,24,39,.02);border-top:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
@media(max-width:420px){.portfolio-thumbs{grid-auto-columns:64px}}
.portfolio-thumb{appearance:none;border:2px solid transparent;background:transparent;border-radius:14px;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}
.portfolio-thumb img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px}
.portfolio-thumb:hover{transform:translateY(-1px)}
.portfolio-thumb:focus-visible{outline:3px solid rgba(34,197,94,.35);outline-offset:3px}
.portfolio-thumb.is-active{border-color:var(--accent);box-shadow:0 10px 24px rgba(15,23,42,.18)}
.aside{display:grid;gap:24px}
@media(min-width:1024px){.aside{margin-top:24px}}
.feature__icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin:10px auto 0;border-radius:14px;background:rgba(34,197,94,.12);color:var(--accent);border:1px solid rgba(34,197,94,.22)}
.feature__icon svg{width:22px;height:22px;display:block}
.form{display:grid;gap:10px}
.input{padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--surface);font:inherit}
.input--textarea{resize:vertical}
.map iframe{width:100%;height:260px;border:0;border-radius:12px}
.contact-grid{display:grid;gap:24px;align-items:start}
@media(min-width:1024px){.contact-grid{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr)}}
.contact-info .section__title,.contact-info .section__subtitle{text-align:left;margin-left:0;margin-right:0}
.whatsapp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);padding:18px;display:grid;gap:10px}
.whatsapp-card__icon{width:44px;height:44px;border-radius:14px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.22);color:var(--accent);display:flex;align-items:center;justify-content:center}
.whatsapp-card__icon svg{width:22px;height:22px;display:block}
.whatsapp-card__title{margin:4px 0 0;font-size:1.1rem}
.whatsapp-card__text{margin:0 0 6px;color:var(--muted);font-size:.95rem}
.contact-list{margin-top:24px;display:grid;gap:14px}
.contact-item{display:flex;gap:12px;align-items:flex-start}
.contact-item p{margin:0;color:var(--text);font-size:.98rem;line-height:1.45}
.contact-icon{width:40px;height:40px;border-radius:12px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.22);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.contact-icon svg{width:20px;height:20px;display:block}
.contact-form-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);padding:18px}
.contact-form-wrapper .form{gap:12px}
.contact-form-wrapper .input,.contact-form-wrapper .input--textarea{width:100%}
.contact-form-wrapper .btn{width:100%}
.map-container{margin-top:24px}
.map-container iframe{width:100%;height:280px;border:0;border-radius:12px;display:block}
.contact-details-card{grid-column:1/-1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);padding:18px}
.contact-details-card__content{display:grid;gap:24px}
.contact-details-card .contact-list{margin-top:0}
.contact-details-card .map-container{margin-top:0}
.cookie-embed{position:relative}
.cookie-embed__placeholder{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-content:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;padding:14px;margin:0 0 10px}
.cookie-embed__placeholder p{margin:0;color:#334155;font-size:.9rem}
.cookie-embed__placeholder.is-hidden{display:none}

.cards{display:grid;grid-template-columns:1fr;gap:18px;padding:24px;align-items:stretch}
.cards--services{grid-template-columns:1fr;gap:12px;justify-content:center;justify-items:center}
@media(min-width:640px){.cards--services{grid-template-columns:repeat(2,minmax(240px,280px))}}
@media(min-width:1024px){.cards--services{grid-template-columns:repeat(3,minmax(240px,280px))}}
.cards--portfolio{grid-template-columns:1fr;gap:18px;justify-content:center}
@media(min-width:640px){.cards--portfolio{grid-template-columns:repeat(2,minmax(320px,380px));justify-content:center}}
@media(min-width:1024px){.cards--portfolio{grid-template-columns:repeat(4,minmax(240px,260px));justify-content:center}}

.cards.cards--quality{grid-template-columns:1fr;gap:12px;justify-content:center;justify-items:center}
@media(min-width:640px){.cards.cards--quality{grid-template-columns:repeat(2,minmax(240px,280px))}}
@media(min-width:1024px){.cards.cards--quality{grid-template-columns:repeat(4,minmax(240px,280px))}}

.cards.cards--diferenciais{grid-template-columns:1fr;gap:12px;justify-content:center;justify-items:center}
@media(min-width:640px){.cards.cards--diferenciais{grid-template-columns:repeat(2,minmax(240px,280px))}}
@media(min-width:1024px){.cards.cards--diferenciais{grid-template-columns:repeat(2,minmax(240px,280px))}}

.card{background:var(--surface);border:1px solid rgba(148,163,184,.3);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);overflow:hidden;position:relative;transition:transform var(--transition-med),box-shadow var(--transition-med),border-color var(--transition-med),background var(--transition-med);display:flex;flex-direction:column;height:100%}
.card__media{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform var(--transition-med),filter var(--transition-med)}
.card__body{padding:18px 18px 20px;text-align:center;display:flex;flex-direction:column;flex:1}
.card__title{font-size:1.05rem;margin:0 0 6px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card__text{color:var(--muted);margin:0 0 10px;font-size:.96rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 22px 50px rgba(15,23,42,.22);border-color:rgba(148,163,184,.6)}
.card:hover .card__media{transform:scale(1.05);filter:brightness(.9)}
.card--service .card__body{padding-top:16px}
.card--portfolio .card__status{color:var(--muted);font-size:12px;margin:0 0 6px}
.card--service{width:100%;justify-self:center}

/* Portfolio-specific sizing */
.card--portfolio .card__media{aspect-ratio:3/2}
.card--portfolio .card__body{padding:18px}
.card--portfolio .card__title{font-size:16px;line-height:1.25;white-space:normal;overflow:visible;text-overflow:clip}
.card--portfolio .card__text{font-size:16px}
.card--portfolio .card__status{font-size:13px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:999px;text-decoration:none;border:1px solid var(--border);color:var(--text)}
.card .btn{margin-top:auto}
.card--portfolio .btn{width:100%}
.btn--ghost{background:transparent}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(15,23,42,.15)}
.btn--whatsapp-filled{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--whatsapp-filled:hover{background:#16a34a;border-color:#16a34a}

.site-footer{padding:24px 0;border-top:1px solid rgba(15,23,42,.12);background:rgba(248,250,252,.92);backdrop-filter:saturate(130%) blur(3px)}
.footer-client-carousel{padding:12px 0 8px;background:#fff}
.site-footer__container{max-width:1120px}
.site-footer__top{display:grid;gap:18px;align-items:center}
.site-footer__brand{display:grid;gap:10px;justify-items:start}
.site-footer__logo{height:58px;width:auto}
.site-footer__text{margin:0;color:#0f172a;font-size:.94rem;line-height:1.45;max-width:560px;text-align:left}
.footer-links{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-start;margin:0}
.footer-links a{color:#0f172a;text-decoration:none;font-weight:700}
.footer-links a:hover{text-decoration:underline}
.site-footer__divider{border:0;border-top:1px solid rgba(15,23,42,.18);margin:18px 0 12px}
.site-footer__bottom{display:flex;gap:14px;align-items:center;justify-content:space-between}
.site-footer__copy{margin:0;color:#0f172a;font-size:.9rem;text-align:left}
.site-footer__dev{display:inline-flex;align-items:center;justify-content:center}
.site-footer__dev img{height:28px;width:auto;display:block}
@media(min-width:860px){
  .site-footer__top{grid-template-columns:minmax(0,1fr) auto}
  .footer-links{justify-content:flex-end}
}
@media(max-width:600px){
  .site-footer__bottom{flex-direction:column;align-items:flex-start}
}
.footer-logos{margin:0 auto 14px;max-width:1100px}
.logo-carousel{display:grid;grid-template-columns:1fr;align-items:center;gap:10px}
.logo-carousel__viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-radius:16px;-ms-overflow-style:none}
.logo-carousel__viewport::-webkit-scrollbar{display:none}
.logo-carousel__track{list-style:none;margin:0;padding:8px;display:flex;gap:12px;align-items:center}
.logo-carousel__item{flex:0 0 auto;scroll-snap-align:center}
.logo-card{width:140px;height:76px;border-radius:16px;border:1px solid rgba(148,163,184,.28);background:linear-gradient(180deg,rgba(15,23,42,.03),rgba(15,23,42,.01));display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(15,23,42,.08)}
.logo-card img{max-width:92%;max-height:78%;width:auto;height:auto;object-fit:contain;display:block;filter:contrast(1.05) saturate(1.02)}
@media(max-width:420px){.logo-card{width:118px;height:68px}.logo-carousel__track{gap:10px}}

.instagram-button{position:fixed;right:16px;bottom:92px;background:linear-gradient(135deg,#f58529 0%,#dd2a7b 35%,#8134af 70%,#515bd4 100%);color:#fff;text-decoration:none;width:64px;height:64px;padding:0;border-radius:50%;box-shadow:var(--shadow);z-index:60;display:flex;align-items:center;justify-content:center;font-weight:700;letter-spacing:.2px;transform:translateZ(0);animation:whatsapp-float 2.2s ease-in-out infinite;isolation:isolate}
.instagram-button::before{content:"";position:absolute;inset:-10px;border-radius:50%;background:rgba(221,42,123,.35);filter:blur(.2px);opacity:.65;transform:scale(.85);animation:whatsapp-pulse 2.2s ease-out infinite;pointer-events:none;z-index:0}
.instagram-button__icon{width:34px;height:34px;display:block;position:relative;z-index:1}
.instagram-button:hover{animation:none;transform:translateY(-2px)}
.instagram-button:hover::before{animation:none;opacity:.25;transform:scale(.95)}
.instagram-button:focus{outline:3px solid rgba(221,42,123,.35)}

.whatsapp-button{position:fixed;right:16px;bottom:16px;background:var(--accent);color:#fff;text-decoration:none;width:64px;height:64px;padding:0;border-radius:50%;box-shadow:var(--shadow);z-index:60;display:flex;align-items:center;justify-content:center;font-weight:700;letter-spacing:.2px;transform:translateZ(0);animation:whatsapp-float 2.2s ease-in-out infinite;isolation:isolate}
.whatsapp-button::before{content:"";position:absolute;inset:-10px;border-radius:50%;background:rgba(34,197,94,.35);filter:blur(.2px);opacity:.65;transform:scale(.85);animation:whatsapp-pulse 2.2s ease-out infinite;pointer-events:none;z-index:0}
.whatsapp-button__icon{width:36px;height:36px;display:block;position:relative;z-index:1}
.whatsapp-button:hover{animation:none;transform:translateY(-2px)}
.whatsapp-button:hover::before{animation:none;opacity:.25;transform:scale(.95)}
.whatsapp-button:focus{outline:3px solid #c0f2df}

@keyframes whatsapp-pulse{
  0%{transform:scale(.85);opacity:.65}
  70%{transform:scale(1.15);opacity:0}
  100%{transform:scale(1.15);opacity:0}
}

@keyframes whatsapp-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-3px)}
}

@media (prefers-reduced-motion: reduce){
  .instagram-button,.instagram-button::before,.whatsapp-button,.whatsapp-button::before{animation:none}
}

.alert{position:relative;margin:0 0 14px;padding:12px 14px 12px 16px;border-radius:12px;border:1px solid transparent;font-weight:600;font-size:.94rem;line-height:1.45;box-shadow:0 8px 20px rgba(15,23,42,.08)}
.alert::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:12px 0 0 12px}
.alert--success{color:#0f5132;background:#ecfdf3;border-color:#b7ebcf}
.alert--success::before{background:#22c55e}
.alert--error{color:#7f1d1d;background:#fff1f2;border-color:#fecdd3}
.alert--error::before{background:#ef4444}

.form__label{display:block;font-weight:700;margin-bottom:6px;font-size:0.9rem}
.form__row{display:grid;gap:16px}
@media(min-width:640px){.form__row{grid-template-columns:1fr 1fr}}
.input--error{border-color:#ef4444;background:#fff5f5}
.input--error:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px rgba(239,68,68,.15)}
.form__error{display:block;margin-top:6px;color:#b91c1c;font-size:.84rem;font-weight:600;line-height:1.3}
.form__notice{margin:2px 0 6px;color:#475569;font-size:.86rem;line-height:1.45}
.form__notice a{color:var(--primary);font-weight:700}

.legal__container{max-width:980px}
.legal__panel{margin-bottom:14px}
.legal__panel p{margin:0;color:#1f2937}
.legal__list{margin:8px 0 0;padding-left:18px;display:grid;gap:8px;color:#1f2937}
.legal__update{margin:14px 4px 0;color:#64748b;font-size:.88rem;text-align:right}

.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:120;opacity:0;visibility:hidden;transform:translateY(12px);pointer-events:none;transition:opacity var(--transition-med),transform var(--transition-med),visibility 0s linear var(--transition-med)}
.cookie-banner.is-visible{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;transition:opacity var(--transition-med),transform var(--transition-med),visibility 0s}
.cookie-banner__content{max-width:980px;margin:0 auto;background:#0f172a;color:#e2e8f0;border:1px solid rgba(148,163,184,.35);border-radius:16px;box-shadow:0 20px 55px rgba(2,6,23,.45);padding:14px}
.cookie-banner__title{margin:0 0 4px;font-size:1rem;font-weight:800;color:#fff}
.cookie-banner__text{margin:0;color:#cbd5e1;font-size:.9rem;line-height:1.4}
.cookie-banner__links{margin:10px 0 0;display:flex;gap:12px;flex-wrap:wrap}
.cookie-banner__links a{color:#86efac;text-decoration:none;font-weight:700}
.cookie-banner__links a:hover{text-decoration:underline}
.cookie-banner__actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner__btn{min-height:40px}
.cookie-banner .btn--ghost{color:#fff;border-color:rgba(226,232,240,.45);background:transparent}
.cookie-banner .btn--ghost:hover{background:rgba(148,163,184,.16);color:#fff}
@media(min-width:768px){
  .cookie-banner{left:20px;right:20px;bottom:20px}
}
.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn--primary:hover{background:var(--secondary);border-color:var(--secondary)}
.page--portfolio .section__title{font-size:clamp(36px,6vw,48px)}
.page--portfolio .section__subtitle{font-size:1.05rem}

.reveal{opacity:0;transform:translateY(14px);transition:opacity var(--transition-med),transform var(--transition-med)}
.reveal--visible{opacity:1;transform:translateY(0)}
