/* ==============================================
   XL XTRALARGE V2 — Complete Stylesheet FIXED
   ============================================== */

/* ---------- TOKENS ---------- */
:root{
    --xl:#FF6B35;--xl-dk:#E85A22;--xl-lt:#FF8C42;
    --xl-glow:rgba(255,107,53,.12);--xl-glow2:rgba(255,107,53,.25);
    --ink:#0f172a;--ink2:#475569;--ink3:#94a3b8;--ink4:#cbd5e1;
    --bg:#ffffff;--bg2:#f8fafc;--bg3:#f1f5f9;
    --dark:#0f172a;--dark2:#1e293b;
    --border:#e2e8f0;
    --r:12px;--r-lg:20px;--r-xl:28px;--r-full:9999px;
    --sh-sm:0 2px 8px rgba(0,0,0,.06);
    --sh-md:0 8px 24px rgba(0,0,0,.08);
    --sh-lg:0 16px 48px rgba(0,0,0,.1);
    --sh-xl:0 24px 64px rgba(0,0,0,.14);
    --ease:cubic-bezier(.4,0,.2,1);
    --font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    --font2:'Space Grotesk','Inter',sans-serif;
    --hdr:80px;
}

/* ---------- RESET ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--hdr)}
body{font-family:var(--font);color:var(--ink);line-height:1.6;background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit}

/* ---------- LOADER ---------- */
.loader-wrap{position:fixed;inset:0;z-index:100000;background:#fff;display:flex;align-items:center;justify-content:center;transition:opacity .5s var(--ease);animation:loaderFallback 3s ease forwards}
.loader-wrap.done{opacity:0;pointer-events:none;animation:none}
@keyframes loaderFallback{0%,80%{opacity:1;pointer-events:auto}100%{opacity:0;pointer-events:none}}
.loader-spinner{width:110px;height:110px;position:relative;display:grid;place-items:center}
.loader-spinner::before{content:'';position:absolute;inset:0;border-radius:50%;border:3px solid var(--border);border-top-color:var(--xl);animation:spin .9s linear infinite}
.loader-logo{width:60px;height:60px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:var(--sh-sm);z-index:1}
.loader-logo img{width:60%;height:auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;width:100%;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid transparent;transition:all .25s var(--ease);height:var(--hdr)}
.site-header.scrolled{border-bottom-color:var(--border);box-shadow:var(--sh-sm);height:68px}
.header__inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;height:100%}

/* Logo */
.header__logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.logo-circle{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--xl),var(--xl-lt));display:grid;place-items:center;position:relative;box-shadow:0 4px 14px var(--xl-glow2);flex-shrink:0;transition:transform .25s var(--ease)}
.logo-circle::before{content:'';position:absolute;inset:3px;background:#fff;border-radius:50%}
.logo-circle img{width:60%;height:auto;position:relative;z-index:1}
.header__logo:hover .logo-circle{transform:scale(1.08)}
.logo-text{line-height:1.1}
.logo-text strong{display:block;font-family:var(--font2);font-size:1.4rem;color:var(--xl);letter-spacing:-.02em}
.logo-text small{font-size:.78rem;color:var(--ink3);text-transform:uppercase;letter-spacing:.1em}

/* Nav */
.header__nav{display:flex;align-items:center;gap:2.5rem}
.header__nav>a,.nav-drop>a{font-weight:600;font-size:1.05rem;color:var(--ink2);position:relative;padding:.4rem 0;transition:color .15s}
.header__nav>a::after,.nav-drop>a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2.5px;background:var(--xl);border-radius:2px;transition:width .25s var(--ease)}
.header__nav>a:hover,.nav-drop>a:hover{color:var(--xl)}
.header__nav>a:hover::after,.nav-drop>a:hover::after{width:100%}
.nav-divider{
    display:block;
    margin:1.2rem 0 .5rem;
    font-size:.7rem;
    letter-spacing:.08em;
    color:#94a3b8;
    font-weight:600;
}

/* Dropdown */
.nav-drop{position:relative}
.nav-drop__menu{position:absolute;top:calc(100% + 1rem);left:50%;transform:translateX(-50%) translateY(-6px);opacity:0;visibility:hidden;transition:all .25s var(--ease);background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:1.25rem;min-width:320px;z-index:100}
.nav-drop:hover .nav-drop__menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop__label{font-size:.78rem;font-weight:700;color:var(--xl);text-transform:uppercase;letter-spacing:.1em;padding:.5rem .75rem;border-bottom:1px solid var(--border);margin-bottom:.5rem}
.nav-drop__menu>a{display:block;padding:.65rem .75rem;border-radius:var(--r);font-size:.95rem;font-weight:500;color:var(--ink2);transition:all .15s}
.nav-drop__menu>a::after{display:none}
.nav-drop__menu>a:hover{background:var(--xl-glow);color:var(--xl);transform:translateX(4px)}

/* Actions */
.header__actions{display:flex;align-items:center;gap:.75rem}
.lang-switch{width:44px;height:44px;border-radius:var(--r-full);border:2px solid var(--border);background:transparent;font-weight:700;font-size:.9rem;color:var(--ink2);cursor:pointer;transition:all .25s var(--ease);display:grid;place-items:center}
.lang-switch:hover{border-color:var(--xl);color:var(--xl);background:var(--xl-glow)}
.admin-link{width:44px;height:44px;border-radius:var(--r-full);background:var(--bg2);border:1px solid var(--border);display:grid;place-items:center;color:var(--ink3);transition:all .25s var(--ease)}
.admin-link:hover{background:var(--xl);color:#fff;border-color:var(--xl)}

/* Burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:all .25s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   HERO — FIXED: Smaller text + fade animation on title
   ============================================================ */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;width:100%;height:100%}
.hero__slide{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity 1.5s var(--ease)}
.hero__slide.active{opacity:1}
.hero__slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(15,23,42,.72),rgba(255,107,53,.45))}
.hero__content{position:relative;z-index:2;text-align:center;color:#fff;max-width:900px;width:100%;padding:0 2rem}
.hero__badge{display:inline-block;padding:.6rem 1.6rem;border-radius:var(--r-full);background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);font-size:.95rem;font-weight:600;letter-spacing:.05em;margin-bottom:1.5rem}

/* Title — smaller + fade in/out animation */
.hero__title{font-family:var(--font2);font-size:clamp(3rem,8vw,6.5rem);font-weight:800;line-height:.9;letter-spacing:-.04em;margin-bottom:1.2rem;animation:heroTitlePulse 6s ease-in-out infinite}
.hero__title span{display:block;background:linear-gradient(135deg,#fff,var(--xl-lt));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Fade in/out animation for the title */
@keyframes heroTitlePulse{
    0%{opacity:0;transform:translateY(15px)}
    12%{opacity:1;transform:translateY(0)}
    75%{opacity:1;transform:translateY(0)}
    92%{opacity:0;transform:translateY(-10px)}
    100%{opacity:0;transform:translateY(15px)}
}

.hero__tagline{font-size:clamp(1.1rem,2.5vw,1.5rem);font-style:italic;opacity:.9;font-weight:300;margin-bottom:.8rem}
.hero__desc{font-size:clamp(1rem,1.6vw,1.15rem);opacity:.82;max-width:620px;margin:0 auto 2.5rem;line-height:1.7}
.hero__btns{display:flex;gap:1.25rem;justify-content:center;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5}
.hero__scroll-line{width:1px;height:40px;background:rgba(255,255,255,.35);position:relative;overflow:hidden}
.hero__scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;background:#fff;animation:scrollDown 2s ease infinite}
@keyframes scrollDown{0%{top:-100%}100%{top:200%}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2.5rem;border-radius:var(--r-full);font-weight:700;font-size:1rem;cursor:pointer;transition:all .25s var(--ease);border:2px solid transparent}
.btn--primary{background:linear-gradient(135deg,var(--xl),var(--xl-lt));color:#fff;border-color:var(--xl);box-shadow:0 4px 18px var(--xl-glow2)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 10px 32px var(--xl-glow2)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--lg{padding:1.1rem 3rem;font-size:1.05rem}
.btn--block{width:100%}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--dark);color:#fff;padding:1.2rem 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:2.2rem;animation:marquee 45s linear infinite;font-weight:700;font-size:1rem;letter-spacing:.04em;text-transform:uppercase}
.marquee__track i{color:var(--xl);font-size:.55rem;font-style:normal;vertical-align:middle}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-33.33%)}}

/* ============================================================
   SECTIONS
   ============================================================ */
.sec{padding:7rem 3rem;scroll-margin-top:var(--hdr)}
.sec--alt{background:var(--bg2)}
.sec--dark{background:var(--dark);color:#fff}
.wrap{max-width:1440px;margin:0 auto}
.sec__header{text-align:center;margin-bottom:4rem}
.sec__label{display:inline-block;font-size:.9rem;font-weight:700;color:var(--xl);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem;padding:.5rem 1.4rem;border-radius:var(--r-full);background:var(--xl-glow)}
.sec--dark .sec__label{background:rgba(255,107,53,.18)}
.sec__header h2{font-family:var(--font2);font-size:clamp(2.4rem,5vw,3.5rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.75rem}
.sec__header p{font-size:1.2rem;color:var(--ink2);max-width:620px;margin:0 auto}
.sec--dark .sec__header p{color:rgba(255,255,255,.65)}
.text-center{text-align:center}

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:2rem;margin-top:2.5rem}
.svc{background:#fff;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;border:1px solid var(--border);transition:all .3s var(--ease)}
.svc:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);border-color:var(--xl-glow)}
.svc__img{height:300px;overflow:hidden;position:relative}
.svc__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.svc:hover .svc__img img{transform:scale(1.08)}
.svc__icon{position:absolute;top:1rem;left:1rem;width:56px;height:56px;border-radius:var(--r);background:rgba(255,255,255,.92);backdrop-filter:blur(8px);display:grid;place-items:center;font-size:1.6rem;box-shadow:var(--sh-sm)}
.svc__body{padding:1.75rem}
.svc__body h3{font-size:1.35rem;font-weight:700;margin-bottom:.5rem;transition:color .15s}
.svc:hover .svc__body h3{color:var(--xl)}
.svc__body p{font-size:1rem;color:var(--ink2);line-height:1.7;margin-bottom:1rem}
.svc__link{font-size:.95rem;font-weight:700;color:var(--xl);transition:letter-spacing .3s var(--ease)}
.svc:hover .svc__link{letter-spacing:.04em}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about__frame{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-xl)}
.about__frame img{width:100%;height:auto;display:block}
.about__badge{position:absolute;bottom:1.5rem;right:1.5rem;background:var(--xl);color:#fff;padding:1.2rem 1.8rem;border-radius:var(--r-lg);text-align:center;box-shadow:0 8px 24px rgba(255,107,53,.4)}
.about__badge strong{display:block;font-family:var(--font2);font-size:2.4rem;font-weight:800;line-height:1}
.about__badge span{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em}
.about__placeholder{width:100%;height:480px;border-radius:var(--r-xl);background:linear-gradient(135deg,var(--xl),var(--xl-lt));display:grid;place-items:center;color:#fff;font-size:1.3rem;font-weight:600}
.about__text h2{font-family:var(--font2);font-size:clamp(2.2rem,3.5vw,3rem);font-weight:800;margin-bottom:1.5rem;color:#fff}
.about__text p{color:rgba(255,255,255,.75);font-size:1.15rem;margin-bottom:1.2rem;line-height:1.8}
.about__stats{display:flex;gap:3rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.15)}
.about__stats div{text-align:center}
.about__stats strong{display:block;font-family:var(--font2);font-size:3rem;font-weight:800;color:var(--xl-lt);line-height:1}
.about__stats span{font-size:.95rem;color:rgba(255,255,255,.55);display:block;margin-top:.3rem}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio-pills{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:3rem}
.pill{padding:.7rem 1.6rem;border-radius:var(--r-full);font-weight:600;font-size:.95rem;background:#fff;border:1px solid var(--border);color:var(--ink2);transition:all .25s var(--ease)}
.pill:hover,.pill--active{background:var(--xl);color:#fff;border-color:var(--xl);box-shadow:0 4px 12px var(--xl-glow2)}

.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.port-item{position:relative;border-radius:var(--r-lg);overflow:hidden;height:380px;display:block;transition:all .3s var(--ease)}
.port-item:first-child{grid-column:span 2;height:480px}
.port-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.port-item:hover img{transform:scale(1.08)}
.port-item__over{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;background:linear-gradient(180deg,transparent 30%,rgba(15,23,42,.88) 100%);color:#fff;opacity:0;transition:opacity .3s var(--ease)}
.port-item:hover .port-item__over{opacity:1}
.port-item:hover{transform:translateY(-5px);box-shadow:var(--sh-xl)}
.port-item__over small{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--xl-lt);margin-bottom:.4rem}
.port-item__over h3{font-size:1.4rem;font-weight:700}
.port-item__arrow{font-size:1.6rem;margin-top:.6rem;opacity:.7;transition:transform .3s var(--ease)}
.port-item:hover .port-item__arrow{transform:translateX(8px)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.contact__info h2{font-family:var(--font2);font-size:clamp(2.2rem,3.5vw,3rem);font-weight:800;margin-bottom:1rem}
.contact__info>p{color:var(--ink2);font-size:1.15rem;margin-bottom:2.5rem}
.offices{display:flex;flex-direction:column;gap:1rem}
.office{display:flex;align-items:center;gap:1.2rem;padding:1.3rem;border-radius:var(--r);background:var(--bg);border:1px solid var(--border);transition:all .25s var(--ease)}
.office:hover{border-color:var(--xl);box-shadow:var(--sh-sm)}
.office__flag{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--border);flex-shrink:0}
.office div{display:flex;flex-direction:column}
.office strong{color:var(--xl);font-size:1.05rem}
.office span{font-size:.95rem;color:var(--ink2)}

/* Form */
.contact-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.75rem;display:grid;gap:1.25rem}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:1.15rem 1.3rem;border:2px solid var(--border);border-radius:var(--r);font-size:1.05rem;font-family:var(--font);color:var(--ink);background:var(--bg2);transition:all .25s var(--ease)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--xl);outline:none;box-shadow:0 0 0 4px var(--xl-glow);background:#fff}
.contact-form select{cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FF6B35' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.contact-form textarea{resize:vertical;min-height:150px}

/* ============================================================
   FOOTER — FIXED: Logo inside circle
   ============================================================ */
.site-footer{
    background:var(--dark);
    color:#fff;
    padding:5rem 3rem 2rem;
}

.footer__top{
    display:grid;
    grid-template-columns:1.5fr 2.5fr;
    gap:4rem;
    margin-bottom:3.5rem;
}

.footer__brand{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}

/* ✅ Footer logo circle igual ao header */
.footer__brand .footer-logo-circle{
    width:52px;
    height:52px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--xl),var(--xl-lt));
    display:grid;
    place-items:center;
    position:relative;
    box-shadow:0 4px 14px var(--xl-glow2);
    flex-shrink:0;
}

.footer__brand .footer-logo-circle::before{
    content:'';
    position:absolute;
    inset:3px;
    background:var(--dark);
    border-radius:50%;
    z-index:1;
}

/* ✅ Logo proporcional e perfeito dentro do círculo */
.footer__brand .footer-logo-circle img{
    width:26px;
    height:26px;
    object-fit:contain;
    position:relative;
    z-index:2;
}

.footer__brand p{
    color:rgba(255,255,255,.5);
    font-size:1rem;
    margin-top:1rem;
    max-width:300px;
    line-height:1.7;
}

.footer__cols{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:2.5rem;
}

.footer__cols h4{
    font-size:.95rem;
    font-weight:700;
    margin-bottom:1.2rem;
    color:var(--xl-lt);
}

.footer__cols a,
.footer__cols span{
    display:block;
    color:rgba(255,255,255,.55);
    font-size:.95rem;
    margin-bottom:.6rem;
    transition:color .15s;
}

.footer__cols a:hover{
    color:#fff;
}

.social-row{
    display:flex;
    gap:.75rem;
    margin-top:.75rem;
}

.social-row a{
    width:42px;
    height:42px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    display:grid;
    place-items:center;
    color:rgba(255,255,255,.6);
    transition:all .25s var(--ease);
}

.social-row a:hover{
    background:var(--xl);
    color:#fff;
    transform:translateY(-3px);
}

.footer__bottom{
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:2rem;
    text-align:center;
    font-size:.9rem;
    color:rgba(255,255,255,.35);
}

.admin__side nav {
    display:flex;
    flex-direction:column;
    gap:.5rem;
}

.admin__side nav a {
    display:block;
    padding:.75rem 1rem;
    border-radius:12px;
    color:#cbd5e1;
    text-decoration:none;
}

.admin__side nav a:hover {
    background:rgba(255,255,255,.06);
    color:#fff;
}

.admin__side nav a.active {
    background:rgba(255,255,255,.12);
    color:#fff;
}

.admin {
    display:flex;
    min-height:100vh;
}

.admin__side {
    width:260px;
    flex-shrink:0;
}

.admin__main {
    flex:1;
    padding:2.5rem;
}

/* ============================================================
   INNER PAGES
   ============================================================ */
.inner-hero{padding:8rem 3rem 4rem;background:var(--dark);color:#fff;text-align:center}
.inner-hero h1{font-family:var(--font2);font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:800;margin-bottom:.5rem}
.inner-hero p{color:rgba(255,255,255,.6);font-size:1.15rem}
.inner-hero__crumbs{margin-bottom:1.5rem;font-size:.95rem;color:rgba(255,255,255,.4)}
.inner-hero__crumbs a{color:var(--xl-lt);transition:opacity .15s}
.inner-hero__crumbs a:hover{opacity:.75}

/* Card grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:2rem}
.card-item{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);transition:all .3s var(--ease);display:block}
.card-item:hover{transform:translateY(-8px);box-shadow:var(--sh-lg)}
.card-item__img{height:300px;overflow:hidden}
.card-item__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card-item:hover .card-item__img img{transform:scale(1.08)}
.card-item__body{padding:1.5rem}
.card-item__body h3{font-size:1.25rem;font-weight:700;margin-bottom:.3rem;transition:color .15s}
.card-item:hover .card-item__body h3{color:var(--xl)}
.card-item__body span{font-size:.92rem;color:var(--ink3)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}
.gallery-item{display:block;position:relative;border-radius:var(--r);overflow:hidden;height:340px;transition:transform .3s var(--ease)}
.gallery-item img{width:100%;height:100%;object-fit:cover}
.gallery-item__over{position:absolute;inset:0;display:grid;place-items:center;background:rgba(15,23,42,.45);color:#fff;font-size:2.5rem;font-weight:300;opacity:0;transition:opacity .25s var(--ease)}
.gallery-item:hover .gallery-item__over{opacity:1}
.gallery-item:hover{transform:scale(1.03)}

/* ============================================================
   ADMIN
   ============================================================ */
.auth-page{min-height:100vh;display:grid;place-items:center;background:var(--bg3)}
.auth-card{background:#fff;border-radius:var(--r-xl);padding:3rem;max-width:420px;width:100%;box-shadow:var(--sh-lg);text-align:center}
.auth-logo{width:64px;height:auto;margin:0 auto 1.2rem}
.auth-card h2{font-family:var(--font2);margin-bottom:1.75rem;font-size:1.6rem}
.auth-card form{display:grid;gap:1.1rem}
.auth-card input{width:100%;padding:1.1rem;border:2px solid var(--border);border-radius:var(--r);font-size:1rem}
.auth-card input:focus{border-color:var(--xl);outline:none;box-shadow:0 0 0 4px var(--xl-glow)}
.auth-back{display:block;margin-top:1.5rem;color:var(--xl);font-weight:600;font-size:.95rem}

.admin{display:flex;min-height:100vh}
.admin__side{width:260px;background:var(--dark);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.admin__brand{display:flex;align-items:center;gap:.75rem;padding:1.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.admin__brand img{width:32px;height:auto}
.admin__brand span{font-weight:700;font-size:1rem}
.admin__side nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.3rem}
.admin__side nav a{display:block;padding:.8rem 1rem;border-radius:var(--r);font-size:.95rem;color:rgba(255,255,255,.65);transition:all .15s}
.admin__side nav a:hover,.admin__side nav a.active{background:rgba(255,255,255,.1);color:#fff}
.admin__user{padding:1.2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;font-size:.88rem}
.admin__user a{color:var(--xl-lt)}
.admin__main{flex:1;background:var(--bg3);padding:2.5rem}
.admin__main h1{font-family:var(--font2);font-size:1.8rem;margin-bottom:1.75rem}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2.5rem}
.metric{background:#fff;padding:2rem;border-radius:var(--r-lg);border:1px solid var(--border);text-align:center}
.metric strong{display:block;font-family:var(--font2);font-size:2.5rem;font-weight:800;color:var(--xl)}
.metric span{font-size:.88rem;color:var(--ink2);margin-top:.3rem;display:block}

.card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);padding:2rem;margin-bottom:1.5rem}
.card h3{font-size:1.15rem;margin-bottom:1.4rem}
.form-stack{display:grid;gap:1.1rem;max-width:650px}
.form-stack input,.form-stack textarea,.form-stack select{width:100%;padding:.95rem;border:2px solid var(--border);border-radius:var(--r);font-size:.95rem}
.form-stack input:focus,.form-stack textarea:focus,.form-stack select:focus{border-color:var(--xl);outline:none}
table{width:100%;border-collapse:collapse}
th,td{padding:1rem;text-align:left;border-bottom:1px solid var(--border);font-size:.95rem}
th{font-weight:700;color:var(--ink2);background:var(--bg2)}

.alert{padding:1rem 1.5rem;border-radius:var(--r);margin-bottom:1.5rem;font-size:.95rem;font-weight:500}
.alert--ok{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.alert--error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.anim-up{opacity:0;transform:translateY(28px);animation:animUp .65s var(--ease) forwards;animation-play-state:paused}
.anim-up.visible{animation-play-state:running}
@keyframes animUp{to{opacity:1;transform:translateY(0)}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
    .about-grid,.contact-grid{grid-template-columns:1fr;gap:3rem}
    .portfolio-grid{grid-template-columns:1fr 1fr}
    .port-item:first-child{grid-column:span 2}
    .footer__top{grid-template-columns:1fr}
    .footer__cols{grid-template-columns:repeat(3,1fr)}
    .services-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
}
@media(max-width:768px){
    .burger{display:flex}
    .header__inner{padding:0 1.5rem}
    .header__nav{display:none;position:fixed;top:var(--hdr);left:0;right:0;background:#fff;flex-direction:column;padding:1.5rem;gap:.75rem;box-shadow:var(--sh-lg);border-top:1px solid var(--border);max-height:calc(100vh - var(--hdr));overflow-y:auto}
    .header__nav.open{display:flex}
    .nav-drop__menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--bg2);min-width:0}
    .sec{padding:5rem 1.5rem}
    .services-grid,.card-grid{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:1fr 1fr}
    .gallery-item{height:240px}
    .portfolio-grid{grid-template-columns:1fr}
    .port-item:first-child{grid-column:auto;height:300px}
    .port-item{height:280px}
    .svc__img{height:240px}
    .card-item__img{height:240px}
    .form-2col{grid-template-columns:1fr}
    .about__stats{gap:2rem}
    .contact-form{padding:1.75rem}
    .footer__cols{grid-template-columns:1fr 1fr}
    .admin__side{display:none}
    .inner-hero{padding:7rem 1.5rem 3rem}
}
@media(max-width:480px){
    .sec{padding:4rem 1.25rem}
    .about__stats{flex-direction:column;align-items:center}
    .hero__title{font-size:clamp(2.5rem,8vw,4rem)}
    .footer__cols{grid-template-columns:1fr}
    .hero__content{padding:0 1.25rem}
    .gallery-grid{grid-template-columns:1fr}
    .gallery-item{height:280px}
}
/* Hero text fade out after 5 seconds */
.hero__content.fade-out{
    opacity:0;
    transform:translateY(-20px);
    transition:opacity 1.2s ease, transform 1.2s ease;
}
/* ============================================================
   A11Y
   ============================================================ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
/* ============================================================
   ACTION BUTTONS — Colar no final do v2-styles.css
   ============================================================ */
.action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: var(--r);
    font-size: .82rem;
    transition: all .2s var(--ease);
    border: 1px solid transparent;
}

.action-btn--edit {
    background: rgba(59,130,246,.08);
    color: #3b82f6;
    border-color: rgba(59,130,246,.15);
}
.action-btn--edit:hover {
    background: #3b82f6;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(59,130,246,.3);
}

.action-btn--warn {
    background: rgba(245,158,11,.08);
    color: #f59e0b;
    border-color: rgba(245,158,11,.15);
}
.action-btn--warn:hover {
    background: #f59e0b;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(245,158,11,.3);
}

.action-btn--ok {
    background: rgba(16,185,129,.08);
    color: #10b981;
    border-color: rgba(16,185,129,.15);
}
.action-btn--ok:hover {
    background: #10b981;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(16,185,129,.3);
}

.action-btn--danger {
    background: rgba(239,68,68,.08);
    color: #ef4444;
    border-color: rgba(239,68,68,.15);
}
.action-btn--danger:hover {
    background: #ef4444;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(239,68,68,.3);
}
/* ============================================================
   IMAGE MANAGER — Colar no final do v2-styles.css
   ============================================================ */

/* Tabs */
.img-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}
.img-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--r-full);font-weight:600;font-size:.95rem;background:#fff;border:2px solid var(--border);color:var(--ink2);transition:all .25s var(--ease)}
.img-tab:hover{border-color:var(--xl);color:var(--xl)}
.img-tab--active{background:var(--xl);color:#fff;border-color:var(--xl);box-shadow:0 4px 12px var(--xl-glow2)}
.img-tab--active:hover{color:#fff}

/* Upload zone */
.upload-zone{border:2px dashed var(--border);border-radius:var(--r-lg);padding:2.5rem;text-align:center;transition:all .25s var(--ease);cursor:pointer;background:var(--bg2)}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--xl);background:var(--xl-glow)}
.upload-zone p{color:var(--ink2);font-size:.95rem;margin:0}

/* Upload preview */
.upload-preview{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}
.upload-preview__item{position:relative;width:100px;height:100px;border-radius:var(--r);overflow:hidden;border:2px solid var(--border)}
.upload-preview__item img{width:100%;height:100%;object-fit:cover}
.upload-preview__item .remove-preview{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;background:rgba(239,68,68,.9);color:#fff;border:none;font-size:.7rem;cursor:pointer;display:grid;place-items:center}

/* Image grid */
.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}

/* Image card */
.img-card{background:#fff;border-radius:var(--r);border:1px solid var(--border);overflow:hidden;transition:all .25s var(--ease)}
.img-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.img-card--featured{border-color:var(--xl);box-shadow:0 0 0 2px var(--xl-glow2)}
.img-card__preview{position:relative;height:150px;overflow:hidden;background:var(--bg3)}
.img-card__preview img{width:100%;height:100%;object-fit:cover;transition:transform .3s var(--ease)}
.img-card:hover .img-card__preview img{transform:scale(1.05)}
.img-card__badge{position:absolute;top:.5rem;left:.5rem;background:var(--xl);color:#fff;padding:.2rem .6rem;border-radius:var(--r-full);font-size:.72rem;font-weight:700}
.img-card__info{padding:.6rem .75rem;display:flex;justify-content:space-between;align-items:center}
.img-card__name{font-size:.78rem;color:var(--ink2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}
.img-card__size{font-size:.72rem;color:var(--ink3)}
.img-card__actions{padding:0 .75rem .6rem;display:flex;gap:.4rem;justify-content:flex-end}

/* Portfolio category grid */
.portfolio-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.portfolio-cat-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:var(--r);border:2px solid var(--border);background:#fff;transition:all .25s var(--ease)}
.portfolio-cat-item:hover{border-color:var(--xl);box-shadow:var(--sh-sm)}
.portfolio-cat-item--active{border-color:var(--xl);background:var(--xl-glow)}
.portfolio-cat-item img{width:56px;height:56px;border-radius:var(--r);object-fit:cover;flex-shrink:0}
.portfolio-cat-item__info{display:flex;flex-direction:column;min-width:0}
.portfolio-cat-item__info strong{font-size:.95rem;color:var(--ink)}
.portfolio-cat-item__info span{font-size:.8rem;color:var(--ink3)}

/* Subfolder grid */
.subfolder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.subfolder-item{border-radius:var(--r);border:2px solid var(--border);overflow:hidden;background:#fff;transition:all .25s var(--ease);display:block}
.subfolder-item:hover{border-color:var(--xl);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.subfolder-item--active{border-color:var(--xl);background:var(--xl-glow)}
.subfolder-item img{width:100%;height:120px;object-fit:cover}
.subfolder-item__info{padding:.6rem .75rem}
.subfolder-item__info strong{display:block;font-size:.88rem;color:var(--ink);margin-bottom:.15rem}
.subfolder-item__info span{font-size:.78rem;color:var(--ink3)}

@media(max-width:768px){
    .img-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
    .portfolio-cat-grid{grid-template-columns:1fr}
    .subfolder-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
}