/*
Theme Name: Practical Productions
Theme URI: https://practicalpro.com
Author: Practical Productions
Author URI: https://practicalpro.com
Description: Custom WordPress theme for Practical Productions — Layout 08 Layered Overlap design. Events that drive revenue.
Version: 2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: practicalpro
*/

/* ============================================
   RESET & BASE
   ============================================ */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Montserrat',sans-serif;background:#f0f2f5;color:#383A35;overflow-x:hidden}
img{max-width:100%;height:auto}
a{transition:.3s}

/* ============================================
   NAVIGATION
   ============================================ */
.site-nav{position:fixed;top:.8rem;left:1.5rem;right:1.5rem;z-index:1000;padding:.85rem 2rem;display:flex;justify-content:space-between;align-items:center;background:rgba(56,58,53,.85);backdrop-filter:blur(20px);border-radius:14px;border:1px solid rgba(255,255,255,.06);transition:all .4s}
.site-nav.scrolled{background:rgba(255,255,255,.95);border-color:rgba(0,0,0,.06);box-shadow:0 4px 20px rgba(0,0,0,.08)}
.site-nav .logo img{height:30px;width:auto;transition:filter .4s}
.site-nav.scrolled .logo img{filter:brightness(.25)}

.nav-r{display:flex;gap:1.8rem;align-items:center}
.nav-r a{color:rgba(255,255,255,.6);font-size:.7rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;transition:.3s}
.nav-r a:hover,.nav-r a.active{color:#fff}
.site-nav.scrolled .nav-r a{color:#696C71}
.site-nav.scrolled .nav-r a:hover,.site-nav.scrolled .nav-r a.active{color:#383A35}

.nav-cta{background:#2563eb;color:#fff;padding:.55rem 1.4rem;font-size:.65rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:none;border-radius:10px;cursor:pointer;transition:.3s;text-decoration:none;display:inline-block}
.nav-cta:hover{background:#1d4ed8}

.mobile-toggle{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:4px}
.mobile-toggle span{width:20px;height:2px;background:rgba(255,255,255,.7);border-radius:2px;transition:.3s}
.site-nav.scrolled .mobile-toggle span{background:#383A35}

/* ============================================
   HERO SECTIONS
   ============================================ */
.hero{min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;background-size:cover;background-position:center;background-attachment:fixed}
.page-hero{min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;background-size:cover;background-position:center}
.hero-ov,.page-hero-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(56,58,53,.45),rgba(56,58,53,.85))}
.hero-c,.page-hero-c{position:relative;z-index:10;max-width:900px;padding:5rem 2rem 4rem}

.badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.35);padding:.4rem 1.1rem;border-radius:100px;font-size:.55rem;font-weight:600;color:#93c5fd;letter-spacing:2px;text-transform:uppercase;margin-bottom:2rem}
.pulse{width:6px;height:6px;background:#3b82f6;border-radius:50%;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.hero h1,.page-hero h1{font-size:clamp(2.5rem,5vw,4.2rem);font-weight:900;color:#fff;line-height:1.05;letter-spacing:-1px;margin-bottom:1.2rem}
.hero h1 .light,.page-hero h1 .light{font-weight:200}
.hero p,.page-hero p{font-size:1rem;font-weight:300;color:rgba(255,255,255,.8);line-height:1.7;max-width:550px;margin:0 auto 2rem}

/* ============================================
   BUTTONS & CTAs
   ============================================ */
.btn{padding:.85rem 2rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;border:none;border-radius:10px;cursor:pointer;text-decoration:none;display:inline-block;transition:.3s}
.btn-blue{background:#2563eb;color:#fff}.btn-blue:hover{background:#1d4ed8}
.btn-glass{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-glass:hover{background:rgba(255,255,255,.1)}
.btn-outline{background:transparent;color:#2563eb;border:1px solid rgba(37,99,235,.3)}.btn-outline:hover{background:rgba(37,99,235,.05)}
.btn-white{background:#fff;color:#1e3a8a}.btn-white:hover{background:#f0f4ff}
.ctas{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ============================================
   SHARED ELEMENTS
   ============================================ */
.eyebrow{font-size:.55rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:#2563eb;margin-bottom:.7rem}
.sec-title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:300;line-height:1.3}
.sec-title strong{font-weight:800}
.sec-head{text-align:center;margin-bottom:3rem}

/* ============================================
   OVERLAPPING STAT CARDS
   ============================================ */
.overlap-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1000px;margin:-4rem auto 0;padding:0 2rem;position:relative;z-index:20}
.o-stat{background:#fff;border-radius:18px;padding:1.8rem;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,.1);border:1px solid rgba(0,0,0,.04);transition:.3s}
.o-stat:hover{transform:translateY(-4px);box-shadow:0 18px 50px rgba(0,0,0,.15)}
.o-stat .num{font-size:2.2rem;font-weight:900;color:#2563eb;margin-bottom:.3rem}
.o-stat .label{font-size:.52rem;color:#696C71;letter-spacing:2px;text-transform:uppercase;font-weight:600}

/* ============================================
   SCROLLING LOGO BAR
   ============================================ */
.logo-bar{background:#ffffff;padding:2rem 0;overflow:hidden;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}
.marquee{display:flex;align-items:center;animation:scroll 30s linear infinite;width:max-content}
.marquee:hover{animation-play-state:paused}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Image logos — full color on white */
.m-logo{height:42px;width:auto;max-width:180px;object-fit:contain;padding:0 2.5rem;opacity:.75;transition:all .3s}
.m-logo:hover{opacity:1;transform:scale(1.05)}

/* Text fallback (when no images uploaded) */
.m-name{font-size:.82rem;font-weight:700;color:#383A35;opacity:.25;letter-spacing:4px;text-transform:uppercase;white-space:nowrap;padding:0 2.5rem}

.m-dot{width:5px;height:5px;background:#d4d4d8;border-radius:50%;flex-shrink:0}

/* ============================================
   BLUE STRIPE
   ============================================ */
.blue-stripe{background:#1e3a8a;padding:2.5rem 0}

/* ============================================
   SERVICE CARDS (HOME)
   ============================================ */
.services{padding:2.5rem 2rem 4rem;background:#f0f2f5}
.svc-stagger{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;max-width:1100px;margin:0 auto}
.svc-card{border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.04);transition:.4s}
.svc-card:nth-child(odd){transform:translateY(0)}.svc-card:nth-child(even){transform:translateY(20px)}
.svc-card:hover{transform:translateY(-5px)!important;box-shadow:0 18px 50px rgba(0,0,0,.12)}
.svc-img{height:180px;background-size:cover;background-position:center;position:relative}
.svc-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.25))}
.svc-badge{position:absolute;top:12px;left:12px;z-index:2;background:#2563eb;color:#fff;padding:.25rem .6rem;border-radius:8px;font-size:.5rem;font-weight:700;letter-spacing:1.5px}
.svc-badge.alt{background:#7c3aed}
.svc-body{padding:1.5rem}
.svc-body h3{font-size:1rem;font-weight:800;margin-bottom:.4rem}
.svc-body .it{font-family:Georgia,serif;font-style:italic;font-size:.75rem;color:#2563eb;margin-bottom:.5rem}
.svc-body p{font-size:.78rem;color:#696C71;line-height:1.6;font-weight:300;margin-bottom:1rem}
.svc-body a{color:#2563eb;font-size:.62rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;text-decoration:none}

/* ============================================
   SERVICE DETAIL (SERVICES PAGE)
   ============================================ */
.svc-intro-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1100px;margin:-4rem auto 0;padding:0 2rem;position:relative;z-index:20}
.svc-intro{background:#fff;border-radius:18px;padding:1.8rem;box-shadow:0 12px 40px rgba(0,0,0,.1);border:1px solid rgba(0,0,0,.04);transition:.4s;cursor:pointer;text-decoration:none;color:#383A35;display:block}
.svc-intro:hover{transform:translateY(-5px);box-shadow:0 18px 50px rgba(37,99,235,.12);border-color:rgba(37,99,235,.15)}
.svc-intro .num{font-size:1.8rem;font-weight:900;color:#2563eb;margin-bottom:.3rem}
.svc-intro h3{font-size:.88rem;font-weight:800;margin-bottom:.3rem}
.svc-intro .it{font-family:Georgia,serif;font-style:italic;font-size:.72rem;color:#2563eb}

.svc-detail{padding:5rem 2rem;max-width:1100px;margin:0 auto}
.svc-detail:first-of-type{padding-top:4rem}
.svc-detail-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.svc-detail:nth-child(even) .svc-detail-inner{direction:rtl}
.svc-detail:nth-child(even) .svc-detail-inner>*{direction:ltr}
.svc-detail-img{border-radius:20px;overflow:hidden;position:relative;aspect-ratio:4/3}
.svc-detail-img img{width:100%;height:100%;object-fit:cover}
.svc-num-badge{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;font-weight:800;font-size:.85rem;color:#fff;margin-bottom:1.2rem}
.bg-b{background:#2563eb}.bg-p{background:#7c3aed}
.svc-detail-text h2{font-size:1.6rem;font-weight:800;margin-bottom:.4rem;line-height:1.2}
.svc-detail-text .it{font-family:Georgia,serif;font-style:italic;font-size:.85rem;color:#2563eb;margin-bottom:1rem}
.svc-detail-text p{font-size:.92rem;color:#696C71;line-height:1.8;font-weight:300;margin-bottom:1rem}
.svc-detail-text ul{list-style:none;margin-bottom:1.5rem}
.svc-detail-text ul li{font-size:.82rem;color:#696C71;line-height:2;font-weight:400;padding-left:1.2rem;position:relative}
.svc-detail-text ul li::before{content:'✓';position:absolute;left:0;color:#2563eb;font-weight:700}
.svc-divider{max-width:1100px;margin:0 auto;border:none;border-top:1px solid #e2e8f0}

/* ── Contact Page Layout ── */
.contact-page-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 2rem;
    align-items: start;
}

.contact-left-intro { margin-bottom: 32px; }
.contact-left-intro h2 { margin: 8px 0 12px; }

.contact-svc-stack {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* Make the card image shorter when stacked vertically */
.contact-svc-stack .svc-img {
    height: 140px;
}

@media (max-width: 900px) {
    .contact-page-wrap {
        grid-template-columns: 1fr;
        padding: 40px 1.5rem;
    }
}
/* Make entire service card clickable */
.svc-card { position: relative; }

.svc-body a::after {
    content: '';
    position: absolute;
    inset: 0;
}

/* ============================================
   PROCESS SECTION
   ============================================ */
.process{max-width:1100px;margin:3rem auto;border-radius:22px;background:#383A35;padding:3.5rem;color:#fff;text-align:center}
.process .eyebrow{color:#60a5fa}
.process .sec-title{color:#fff;margin-bottom:2.5rem}
.p-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.p-card{background:rgba(255,255,255,.04);border-radius:14px;padding:2rem;border:1px solid rgba(255,255,255,.06);text-align:left}
.p-label{font-size:.52rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#60a5fa;margin-bottom:.9rem}
.p-card h3{font-family:Georgia,serif;font-style:italic;font-size:1.1rem;font-weight:400;margin-bottom:.5rem}
.p-card p{font-size:.8rem;color:rgba(255,255,255,.4);line-height:1.7;font-weight:300}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials-section{padding:3rem 2rem;max-width:1100px;margin:0 auto}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testi{padding:1.5rem;background:#fff;border-radius:16px;border:1px solid #e5e7eb;display:flex;flex-direction:column}
.testi .q{font-family:Georgia,serif;font-size:2.5rem;color:#2563eb;line-height:.6;margin-bottom:.8rem}
.testi blockquote{font-family:Georgia,serif;font-style:italic;font-size:.88rem;color:#383A35;line-height:1.7;flex:1;margin-bottom:1rem}
.testi-author{display:flex;align-items:center;gap:.8rem;margin-top:auto;padding-top:1rem;border-top:1px solid #e5e7eb}
.testi-avatar{width:36px;height:36px;border-radius:50%;background:#2563eb;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.7rem;flex-shrink:0}
.testi-info cite{font-style:normal;font-size:.65rem;font-weight:700;color:#383A35;display:block}
.testi-info .role{font-size:.55rem;color:#696C71}

/* ============================================
   CTA SECTION
   ============================================ */
.cta-overlap{background-size:cover;background-position:center;position:relative;padding:5rem 2rem;text-align:center}
.cta-overlap::before{content:'';position:absolute;inset:0;background:rgba(30,58,138,.92)}
.cta-overlap>*{position:relative;z-index:2}
.cta-overlap h2{font-size:2rem;font-weight:900;color:#fff;text-transform:uppercase;margin-bottom:.8rem}
.cta-overlap p{color:rgba(255,255,255,.65);margin-bottom:2rem;font-weight:300;font-size:1rem}

/* ============================================
   ABOUT PAGE
   ============================================ */
.founder{max-width:1100px;margin:0 auto;padding:5rem 2rem 3rem}
.founder-inner{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;align-items:center}
.founder-img{border-radius:22px;overflow:hidden;aspect-ratio:3/4}
.founder-img img{width:100%;height:100%;object-fit:cover}
.founder-text h2{font-size:2rem;font-weight:800;margin-bottom:.3rem}
.founder-text .title{font-family:Georgia,serif;font-style:italic;font-size:.95rem;color:#2563eb;margin-bottom:1.5rem}
.founder-text p{font-size:.92rem;color:#696C71;line-height:1.9;font-weight:300;margin-bottom:1.2rem}
.founder-text .highlight{background:#f8fafc;border-left:3px solid #2563eb;padding:1.2rem 1.5rem;border-radius:0 12px 12px 0;margin:1.5rem 0;font-style:italic;font-size:.88rem;color:#383A35;line-height:1.7}
.founder-contact{display:flex;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap}
.founder-contact a{display:flex;align-items:center;gap:.5rem;color:#2563eb;font-size:.75rem;font-weight:600;text-decoration:none}

.story{padding:3rem 2rem 4rem;background:#fff}
.story-inner{max-width:900px;margin:0 auto}
.timeline{position:relative;padding-left:3rem}
.timeline::before{content:'';position:absolute;left:12px;top:0;bottom:0;width:2px;background:#e2e8f0}
.tl-item{position:relative;margin-bottom:2.5rem}
.tl-dot{position:absolute;left:-3rem;top:.3rem;width:26px;height:26px;background:#2563eb;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 0 0 4px #fff}
.tl-dot::after{content:'';width:8px;height:8px;background:#fff;border-radius:50%}
.tl-year{font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#2563eb;margin-bottom:.4rem}
.tl-item h3{font-size:1rem;font-weight:700;margin-bottom:.3rem}
.tl-item p{font-size:.85rem;color:#696C71;line-height:1.7;font-weight:300}

.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.val-card{background:#fff;border-radius:18px;padding:2.5rem;border:1px solid #e5e7eb;transition:.3s;text-align:center}
.val-card:hover{border-color:rgba(37,99,235,.2);box-shadow:0 8px 30px rgba(37,99,235,.06)}
.val-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;font-size:1.4rem}
.val-card h3{font-size:1rem;font-weight:800;margin-bottom:.5rem}
.val-card p{font-size:.82rem;color:#696C71;line-height:1.7;font-weight:300}

.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:700px;margin:0 auto}
.team-card{background:#fff;border-radius:18px;padding:2rem;border:1px solid #e5e7eb;text-align:center}
.team-avatar{width:70px;height:70px;border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff}
.team-card h3{font-size:.95rem;font-weight:800;margin-bottom:.2rem}
.team-card .role{font-family:Georgia,serif;font-style:italic;font-size:.78rem;color:#2563eb;margin-bottom:.6rem}
.team-card p{font-size:.78rem;color:#696C71;line-height:1.6;font-weight:300}

/* ============================================
   PORTFOLIO PAGE
   ============================================ */

.case-featured{max-width:1100px;margin:0 auto;padding:4rem 2rem}
.case-featured-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:0;align-items:center;background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.04)}
.case-feat-img{min-height:400px;background-size:cover;background-position:center;position:relative}
.case-feat-badge{position:absolute;top:1.2rem;left:1.2rem;background:#2563eb;color:#fff;padding:.35rem .9rem;border-radius:8px;font-size:.5rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;z-index:2}
.case-feat-text{padding:3rem}
.case-feat-text h2{font-size:1.5rem;font-weight:800;margin-bottom:.5rem}
.case-feat-text .it{font-family:Georgia,serif;font-style:italic;font-size:.85rem;color:#2563eb;margin-bottom:1rem}
.case-feat-text p{font-size:.88rem;color:#696C71;line-height:1.8;font-weight:300;margin-bottom:1.2rem}
.case-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.case-stat{text-align:center;padding:.8rem;background:#f8fafc;border-radius:12px}
.case-stat .num{font-size:1.4rem;font-weight:900;color:#2563eb}
.case-stat .label{font-size:.45rem;color:#696C71;letter-spacing:1.5px;text-transform:uppercase;font-weight:600}

.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}
.case-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(0,0,0,.04);box-shadow:0 4px 16px rgba(0,0,0,.04);transition:.4s}
.case-card:hover{transform:translateY(-5px);box-shadow:0 16px 45px rgba(0,0,0,.1)}
.case-card-img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.case-tag{position:absolute;top:.8rem;left:.8rem;z-index:2;padding:.2rem .6rem;border-radius:6px;font-size:.45rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#fff}
.tag-prod{background:#2563eb}.tag-consult{background:#7c3aed}.tag-booth{background:#0891b2}.tag-strat{background:#dc2626}
.case-card-body{padding:1.5rem}
.case-card-body h3{font-size:.95rem;font-weight:800;margin-bottom:.3rem}
.case-card-body .desc{font-size:.78rem;color:#696C71;line-height:1.6;font-weight:300;margin-bottom:1rem}
.case-card-body .result{display:flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:700;color:#2563eb}

.mosaic-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:220px 220px;gap:8px;border-radius:20px;overflow:hidden;max-width:1100px;margin:0 auto}
.mosaic-grid .ph{background-size:cover;background-position:center;transition:.4s;position:relative}
.ph:hover{transform:scale(1.02)}
.ph::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.08);transition:.4s}
.ph:hover::after{background:transparent}
.ph-tall{grid-row:1/3}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-section{max-width:1100px;margin:-3rem auto 0;padding:0 2rem 4rem;position:relative;z-index:20;display:grid;grid-template-columns:1fr 1.2fr;gap:2rem;align-items:start}
.contact-info{background:#383A35;border-radius:22px;padding:3rem;color:#fff}
.contact-info .eyebrow{color:#60a5fa}
.contact-info h2{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem;color:#fff}
.info-row{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.8rem}
.info-icon{width:42px;height:42px;border-radius:12px;background:rgba(37,99,235,.15);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;color:#60a5fa}
.info-row h3{font-size:.85rem;font-weight:700;margin-bottom:.2rem}
.info-row p{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.6;font-weight:300}
.info-row a{color:#60a5fa;text-decoration:none}
.contact-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:1.5rem 0}
.social-links{display:flex;gap:1rem}
.social-link{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#60a5fa;font-size:.75rem;font-weight:700;text-decoration:none;transition:.3s}
.social-link:hover{background:rgba(37,99,235,.15);border-color:rgba(37,99,235,.3)}

.contact-form-card{background:#fff;border-radius:22px;padding:3rem;box-shadow:0 12px 40px rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.04)}
.contact-form-card h2{font-size:1.3rem;font-weight:800;margin-bottom:.5rem}
.contact-form-card .sub{font-size:.82rem;color:#696C71;line-height:1.6;font-weight:300;margin-bottom:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:.62rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#383A35;margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{font-family:'Montserrat',sans-serif;padding:.85rem 1rem;border:1px solid #e2e8f0;border-radius:12px;font-size:.85rem;color:#383A35;background:#f8fafc;transition:.3s;outline:none;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.08);background:#fff}
.form-group textarea{min-height:120px;resize:vertical}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23696C71' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.btn-submit{background:#2563eb;color:#fff;padding:1rem 2.5rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;border:none;border-radius:12px;cursor:pointer;transition:.3s;width:100%;margin-top:.5rem}
.btn-submit:hover{background:#1d4ed8}
.form-note{font-size:.65rem;color:#999;text-align:center;margin-top:1rem}

.quick-bar-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:1100px;margin:0 auto}
.quick-card{background:#fff;border-radius:18px;padding:2rem;text-align:center;border:1px solid #e5e7eb;transition:.3s}
.quick-card:hover{border-color:rgba(37,99,235,.2);box-shadow:0 8px 25px rgba(37,99,235,.06)}
.quick-icon{font-size:1.5rem;margin-bottom:.8rem}
.quick-card h3{font-size:.85rem;font-weight:800;margin-bottom:.3rem}
.quick-card p{font-size:.78rem;color:#696C71;font-weight:300;margin-bottom:.8rem;line-height:1.5}
.quick-card a{color:#2563eb;font-size:.65rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none}

.map-inner{border-radius:22px;overflow:hidden;height:300px;background-size:cover;background-position:center;position:relative;max-width:1100px;margin:0 auto}
.map-overlay{position:absolute;inset:0;background:rgba(30,58,138,.75);display:flex;align-items:center;justify-content:center;flex-direction:column;color:#fff;text-align:center;padding:2rem}
.map-overlay h3{font-size:1.2rem;font-weight:800;margin-bottom:.5rem}
.map-overlay p{font-size:.88rem;color:rgba(255,255,255,.7);font-weight:300;line-height:1.6}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:#383A35;padding:3rem 2rem 2rem;color:rgba(255,255,255,.45)}
.ft-grid{max-width:1100px;margin:0 auto 2rem;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem}
.ft-col h4{font-size:.58rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:#60a5fa;margin-bottom:1rem}
.ft-col a{color:rgba(255,255,255,.4);text-decoration:none;font-size:.8rem;line-height:2;display:block;transition:.3s}
.ft-col a:hover{color:#fff}
.ft-logo img{height:28px;opacity:.85;margin-bottom:.5rem}
.ft-bottom{max-width:1100px;margin:0 auto;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.06);text-align:center;font-size:.7rem}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:768px){
  .mobile-toggle{display:flex}
  .nav-r a:not(.nav-cta){display:none}
  .nav-r.open a{display:block}
  .overlap-stats,.svc-intro-row{grid-template-columns:1fr 1fr}
  .svc-stagger,.case-grid,.val-grid,.testimonials,.testi-grid,.p-grid,.team-grid,.quick-bar-inner{grid-template-columns:1fr}
  .svc-card:nth-child(even){transform:translateY(0)}
  .svc-detail-inner{grid-template-columns:1fr!important}
  .svc-detail:nth-child(even) .svc-detail-inner{direction:ltr}
  .founder-inner{grid-template-columns:1fr}
  .case-featured-inner{grid-template-columns:1fr}
  .case-feat-img{min-height:250px}
  .contact-section{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .mosaic-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}.ph-tall{grid-row:auto}
  .ft-grid{grid-template-columns:1fr}
  .hero,.page-hero,.cta-overlap{background-attachment:scroll}
  .timeline{padding-left:2.5rem}
}
@media(max-width:480px){
  .overlap-stats,.svc-intro-row{grid-template-columns:1fr}
}
.site-nav .logo img {
    height: 60px;
    width: auto;
}
.ft-logo img {
    height: 60px;
    width: auto;
}