/* Main Page */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --black:#000;
  --white:#fff;
  --off:#F4F4F2;
  --mid:#888;
  --font-d:'Archivo Black',sans-serif;
  --font-b:'Archivo',sans-serif;
}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{background:var(--white);color:var(--black);font-family:var(--font-b);font-size:16px;line-height:1.6;overflow-x:hidden;max-width:100vw;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;height:68px;background:var(--white);border-bottom:1px solid var(--black);}
.nav-logo{text-decoration:none;display:flex;align-items:center;filter:invert(1);}
.nav-logo img{height:52px;width:auto;display:block;mix-blend-mode:multiply;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .15s;}
.nav-links a:hover{color:var(--black);}
.nav-cta{font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--white);background:var(--black);padding:12px 26px;text-decoration:none;transition:opacity .15s;}
.nav-cta:hover{opacity:0.75;}

/* HAMBURGER — spans black on white nav */
.nav-toggle span { background: var(--black) !important; }
/* Mobile-only nav items hidden on desktop */
.mobile-only { display: none; }

/* HERO */
#hero{min-height:100vh;display:grid;grid-template-rows:1fr auto;padding-top:68px;border-bottom:1px solid var(--black);}
.hero-main{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.hero-logo-wrap{display:flex;flex-direction:column;justify-content:space-between;padding:60px 5vw 60px;background:var(--black);min-height:100%;}
.hero-logo-wrap img{width:100%;max-width:300px;height:auto;display:block;align-self:flex-start;margin-top:auto;}
.hero-logo-wrap .hero-top-title{font-family:var(--font-d);font-size:clamp(64px,9vw,120px);line-height:0.9;text-transform:uppercase;letter-spacing:-0.02em;color:var(--white);text-align: left;margin-top: auto;}
.hero-logo-wrap .hero-top-title .big{display:block;font-size:clamp(80px,11vw,150px);}
.hero-right{display:flex;flex-direction:column;justify-content:flex-end;padding:8vw 5vw;background:var(--black);color:var(--white);position:relative;overflow:hidden;}
.hero-sub{font-size:18px;font-weight:300;line-height:1.75;color:rgba(255,255,255,0.65);max-width:360px;margin-bottom:48px;}
.hero-sub strong{color:var(--white);font-weight:500;}
.hero-btns{display:flex;flex-direction:column;gap:12px;}
.btn-white{display:inline-block;font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--black);background:var(--white);padding:16px 32px;text-decoration:none;text-align:center;transition:opacity .15s;border:1px solid var(--white);}
.btn-white:hover{opacity:0.8;}
.btn-ghost-w{display:inline-block;font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);background:transparent;padding:16px 32px;text-decoration:none;text-align:center;border:1px solid rgba(255,255,255,0.3);transition:border-color .15s;}
.btn-ghost-w:hover{border-color:var(--white);}
.hero-bottom{display:grid;grid-template-columns:repeat(3,1fr);}
.hero-stat{padding:28px 5vw;border-right:1px solid var(--black);display:flex;align-items:center;justify-content:space-between;}
.hero-stat:last-child{border-right:none;}
.stat-num{font-family:var(--font-d);font-size:36px;letter-spacing:-0.02em;}
.stat-label{font-size:11px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--mid);}

/* TICKER */
#ticker{border-top:1px solid var(--black);border-bottom:1px solid var(--black);overflow:hidden;padding:0;background:var(--black);}
.ticker-track{display:flex;animation:tick 28s linear infinite;white-space:nowrap;}
.ticker-item{font-family:var(--font-d);font-size:12px;letter-spacing:0.25em;text-transform:uppercase;color:var(--white);padding:15px 48px;flex-shrink:0;}
.ticker-sep{color:rgba(255,255,255,0.25);padding:15px 0;flex-shrink:0;}
@keyframes tick{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* SERVICES */
#services{border-bottom:1px solid var(--black);}
.services-head{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.services-head-left{padding:80px 5vw;border-right:1px solid var(--black);}
.services-head-right{padding:80px 5vw;display:flex;flex-direction:column;justify-content:flex-end;gap:32px;}
.services-head-right p{font-size:17px;font-weight:300;color:var(--mid);line-height:1.75;max-width:400px;}
.section-label{font-size:11px;font-weight:500;letter-spacing:0.3em;text-transform:uppercase;color:var(--mid);margin-bottom:20px;}
.section-title{font-family:var(--font-d);font-size:clamp(52px,7vw,90px);line-height:0.92;text-transform:uppercase;letter-spacing:-0.02em;}
.service-row-link{display:grid;grid-template-columns:80px 1fr 1fr 80px;align-items:center;gap:0;border-bottom:1px solid var(--black);padding:0 5vw;transition:background .2s;text-decoration:none;color:inherit;cursor:pointer;}
.service-row-link:hover{background:var(--black);color:var(--white);}
.service-row-link:hover .svc-num,.service-row-link:hover .svc-desc{color:rgba(255,255,255,0.45);}
.service-row-link:hover .svc-arrow{opacity:1;}
.svc-num{font-size:11px;font-weight:500;letter-spacing:0.15em;color:var(--mid);padding:36px 0;}
.svc-name{font-family:var(--font-d);font-size:clamp(28px,3.5vw,48px);text-transform:uppercase;letter-spacing:-0.01em;padding:36px 40px;}
.svc-desc{font-size:14px;font-weight:300;color:var(--mid);line-height:1.7;padding:36px 40px 36px 0;}
.svc-arrow{font-size:24px;opacity:0;transition:opacity .2s;justify-self:end;}
/* SERVICES BOTTOM BANNER */
.services-banner{background:var(--black);padding:56px 5vw;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;}
.services-banner-text{font-family:var(--font-d);font-size:clamp(28px,4vw,48px);text-transform:uppercase;color:var(--white);line-height:0.95;letter-spacing:-0.01em;}
.services-banner-text span{color:rgba(255,255,255,0.35);}
.btn-white-outline{display:inline-block;font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);background:transparent;padding:14px 32px;text-decoration:none;border:1px solid rgba(255,255,255,0.4);transition:border-color .15s;}
.btn-white-outline:hover{border-color:#fff;}

/* WHY */
#why{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.why-left{padding:100px 5vw;border-right:1px solid var(--black);}
.why-title{margin-bottom:48px;}
.why-items{display:flex;flex-direction:column;}
.why-item{display:flex;align-items:flex-start;gap:20px;padding:24px 0;border-top:1px solid var(--black);flex-direction:column;}
.why-idx{font-size:28px;font-weight:700;color:var(--black);min-width:28px;margin-top:3px;letter-spacing:2px;}
.review-header{display:flex;align-items:center;gap:16px;width:100%;}
.review-profile{width:56px;height:56px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;color:#999;font-size:24px;flex-shrink:0;}
.review-info{flex:1;} 
.review-name{font-weight:600;font-size:15px;color:var(--black);}
.review-role{font-size:13px;color:var(--mid);margin-top:2px;}
.why-text{font-size:16px;font-weight:400;line-height:1.6;margin-top:12px;}
.why-item:last-child{border-bottom:1px solid var(--black);}
#why .why-right{background:var(--black);color:var(--white);display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;}
.metric-cell{padding:56px 5vw;border-right:1px solid rgba(255,255,255,0.1);border-bottom:1px solid rgba(255,255,255,0.1);display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;}
.metric-cell video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0.15;z-index:0;}
.metric-cell > div{position:relative;z-index:1;}
.metric-cell:nth-child(2){border-right:none;}
.metric-cell:nth-child(3){border-bottom:none;}
.metric-cell:nth-child(4){border-right:none;border-bottom:none;}
.m-num{font-family:var(--font-d);font-size:clamp(48px,6vw,80px);letter-spacing:-0.03em;line-height:1;color:var(--white);margin-bottom:8px;}
.m-label{font-size:11px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);}

/* CONTACT */
#contact{display:grid;grid-template-columns:1fr 1fr;}
.contact-left{padding:100px 5vw;border-right:1px solid var(--black);background:var(--off);}
.contact-right{padding:100px 5vw;}
.contact-title{margin-bottom:56px;}
.c-items{display:flex;flex-direction:column;}
.c-item{padding:24px 0;border-top:1px solid var(--black);display:flex;flex-direction:column;gap:4px;}
.c-item:last-child{border-bottom:1px solid var(--black);}
.c-label{font-size:10px;font-weight:500;letter-spacing:0.25em;text-transform:uppercase;color:var(--mid);}
.c-val{font-size:17px;font-weight:400;}
.form{display:flex;flex-direction:column;gap:0;}
.f-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.f-row.single{grid-template-columns:1fr;}
.f-group{display:flex;flex-direction:column;border-right:1px solid var(--black);}
.f-row.single .f-group{border-right:none;}
.f-row .f-group:last-child{border-right:none;}
.f-group label{font-size:10px;font-weight:500;letter-spacing:0.25em;text-transform:uppercase;color:var(--mid);padding:16px 20px 8px;}
.f-group input,.f-group select,.f-group textarea{background:transparent;border:none;outline:none;font-family:var(--font-b);font-size:16px;font-weight:400;color:var(--black);padding:0 20px 18px;width:100%;appearance:none;}
.f-group textarea{resize:none;min-height:140px;}
input::placeholder,textarea::placeholder{color:#bbb;}
.form-wrapper{border:1px solid var(--black);}
.form-submit{border-top:1px solid var(--black);}
.form-submit button{width:100%;font-family:var(--font-b);font-size:12px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);background:var(--black);border:none;padding:22px;cursor:pointer;transition:opacity .15s;}
.form-submit button:hover{opacity:0.75;}

/* FOOTER */
footer{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid var(--black);}
.f-col{padding:40px 5vw;border-right:1px solid var(--black);}
.f-col:last-child{border-right:none;}
.f-logo{font-family:var(--font-d);font-size:16px;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:12px;}
.f-copy{font-size:12px;color:var(--mid);line-height:1.6;}
.f-links{display:flex;flex-direction:column;gap:12px;}
.f-links a{font-size:12px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .15s;}
.f-links a:hover{color:var(--black);}
.f-tagline{font-family:var(--font-d);font-size:24px;line-height:1.1;text-transform:uppercase;letter-spacing:-0.01em;}

/* FOOTER LOGO */
.f-logo-img{margin-bottom:16px;}
.f-logo-img img{height:60px;width:auto;display:block;filter:invert(1);}


/* TURNSTILE CAPTCHA */
.captcha-row{padding:20px;border-top:1px solid var(--black);border-bottom:none;display:flex;align-items:center;justify-content:flex-start;grid-column:1/-1;}
.captcha-error{display:none;font-size:12px;color:#c00;letter-spacing:0.05em;padding:0 20px 16px;font-family:var(--font-b);}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s ease;}
.reveal.in{opacity:1;transform:none;}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}.d3{transition-delay:.32s;}



/* RESPONSIVE */
@media(max-width:900px){
  .hero-main,.hero-bottom,.services-head,#why,#contact,footer{grid-template-columns:1fr;}
  .hero-left,.services-head-left,.why-left{border-right:none;border-bottom:1px solid var(--black);}
  .hero-right{border-right:none;}
  .hero-stat{border-right:none;border-bottom:1px solid var(--black);}
  .hero-stat:last-child{border-bottom:none;}
  #why .why-right{grid-template-columns:1fr 1fr;}
  .metric-cell{border-bottom:1px solid rgba(255,255,255,0.1);}
  .contact-left{border-right:none;border-bottom:1px solid var(--black);}
  .f-col{border-right:none;border-bottom:1px solid var(--black);}
  .f-col:last-child{border-bottom:none;}
  nav .nav-links{display:none;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .svc-card:nth-child(3n){border-right:1px solid var(--black);}
  .svc-card:nth-child(2n){border-right:none;}
  .svc-num{padding:24px 0;}
}






/* ── CHAT WIDGET: OWNER + STATUS STYLES ──────────────────── */
/* Owner message bubble — dark gray, left-aligned like bot but distinct */
.msg.owner{background:#222;color:#fff;align-self:flex-start;border-left:3px solid #666;}
/* Small sender label above each bubble */
.msg-label{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:4px;}
.msg.user  .msg-label{color:rgba(255,255,255,0.5);}
.msg.bot   .msg-label{color:rgba(0,0,0,0.4);}
.msg.owner .msg-label{color:rgba(255,255,255,0.45);}
/* Make sure message text sits below the label correctly */
.msg-text{line-height:1.55;}
/* Centered status strip — "Connecting you with our team" */
.msg-status-badge{text-align:center;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:#999;padding:6px 0;width:100%;font-family:'Archivo',sans-serif;}


/* ═══════════════════════════════════════════════════════════ */
/* SERVICE PAGES — excavation-grading, demolition, etc.       */
/* ═══════════════════════════════════════════════════════════ */

/* ── HERO ─────────────────────────────────────────────────── */
.svc-hero{min-height:65vh;background:var(--black);display:flex;flex-direction:column;justify-content:flex-end;padding:140px 5vw 64px;}
.breadcrumb{font-size:11px;font-weight:500;letter-spacing:0.25em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:24px;}
.breadcrumb a{color:rgba(255,255,255,0.35);text-decoration:none;transition:color .15s;}
.breadcrumb a:hover{color:#fff;}
.breadcrumb span{margin:0 10px;}
.hero-title{font-family:var(--font-d);font-size:clamp(36px,9vw,120px);line-height:0.88;text-transform:uppercase;letter-spacing:-0.02em;color:var(--white);margin-bottom:32px;word-break:break-word;overflow-wrap:break-word;}
/* Scoped to .svc-hero to avoid conflict with main page .hero-sub */
.svc-hero .hero-sub{font-size:18px;font-weight:300;color:rgba(255,255,255,0.55);max-width:600px;line-height:1.75;border-left:2px solid rgba(255,255,255,0.2);padding-left:24px;margin-bottom:0;}

/* ── MEDIA STRIP ──────────────────────────────────────────── */
.media-strip{display:grid;grid-template-columns:1fr;height:45vh;width:100%;}
.media-box{overflow:hidden;position:relative;background:var(--off);border-right:1px solid var(--black);}
.media-box:last-child{border-right:none;}
.media-box img,.media-box video{width:100%;height:100%;object-fit:cover;display:block;}
.media-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.media-placeholder svg{width:32px;height:32px;stroke:var(--mid);fill:none;stroke-width:1.5;}
.media-placeholder p{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);}

/* ── TWO-COLUMN CONTENT ───────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.col-left{padding:80px 5vw;border-right:1px solid var(--black);}
.col-right{padding:80px 5vw;}
.tag{font-size:10px;font-weight:500;letter-spacing:0.3em;text-transform:uppercase;color:var(--mid);margin-bottom:20px;}
.col-title{font-family:var(--font-d);font-size:clamp(36px,4vw,54px);line-height:0.92;text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:32px;}
.body-text{font-size:16px;font-weight:300;color:#333;line-height:1.85;margin-bottom:24px;}
.includes-list{list-style:none;}
.includes-list li{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-top:1px solid var(--black);font-size:15px;line-height:1.5;}
.includes-list li:last-child{border-bottom:1px solid var(--black);}
.includes-list li::before{content:'→';font-family:var(--font-d);flex-shrink:0;}

/* ── WHY / FAQ (dark section) ─────────────────────────────── */
/* Scoped to .why-grid to avoid conflicts with main page #why  */
.dark-section{background:var(--black);color:var(--white);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);}
.why-grid .why-left{padding:80px 5vw;border-right:1px solid rgba(255,255,255,0.1);}
.why-grid .why-right{padding:80px 5vw;display:flex;flex-direction:column;background:transparent;}
.why-grid .why-title{font-family:var(--font-d);font-size:clamp(36px,4vw,54px);line-height:0.92;text-transform:uppercase;color:var(--white);margin-bottom:36px;}
.why-grid .why-items{list-style:none;}
.why-grid .why-items li{display:flex;gap:16px;padding:18px 0;border-top:1px solid rgba(255,255,255,0.1);font-size:15px;color:rgba(255,255,255,0.7);line-height:1.6;}
.why-grid .why-items li:last-child{border-bottom:1px solid rgba(255,255,255,0.1);}
.why-grid .why-items li::before{content:'✓';color:#fff;font-weight:700;flex-shrink:0;}
.faq-item{padding:28px 0;border-top:1px solid rgba(255,255,255,0.1);}
.faq-item:last-child{border-bottom:1px solid rgba(255,255,255,0.1);}
.faq-q{font-family:var(--font-d);font-size:16px;text-transform:uppercase;color:var(--white);margin-bottom:10px;}
.faq-a{font-size:15px;font-weight:300;color:rgba(255,255,255,0.55);line-height:1.75;}

/* ── CTA BAR ──────────────────────────────────────────────── */
.cta-bar{background:var(--black);padding:80px 5vw;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,0.08);}
.cta-title{font-family:var(--font-d);font-size:clamp(40px,6vw,80px);line-height:0.9;text-transform:uppercase;color:var(--white);}
/* Larger padding for service page CTA button vs main page btn-white */
.cta-bar .btn-white{padding:18px 44px;border:none;}
.cta-bar .btn-white:hover{opacity:0.85;}

/* ── OTHER SERVICES GRID ──────────────────────────────────── */
.other-services{padding:80px 5vw;border-bottom:1px solid var(--black);}
.other-tag{font-size:10px;font-weight:500;letter-spacing:0.3em;text-transform:uppercase;color:var(--mid);margin-bottom:40px;}
.other-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--black);}
.other-link{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-right:1px solid var(--black);border-bottom:1px solid var(--black);text-decoration:none;color:var(--black);transition:background .2s;}
.other-link:hover{background:var(--black);color:var(--white);}
.other-link:nth-child(3n){border-right:none;}
.other-name{font-family:var(--font-d);font-size:16px;text-transform:uppercase;letter-spacing:-0.01em;}
.other-arrow{font-size:18px;opacity:0.3;transition:opacity .2s,transform .2s;}
.other-link:hover .other-arrow{opacity:1;transform:translate(2px,-2px);}

/* ── SERVICE PAGE FOOTER LOGO ─────────────────────────────── */
.f-logo{display:flex;align-items:center;margin-bottom:12px;}
.f-logo img{height:40px;width:auto;filter:invert(1);}

/* ── PROCESS STEPS ────────────────────────────────────────── */
.process-steps{display:flex;flex-direction:column;}
.step{display:flex;gap:24px;align-items:flex-start;padding:24px 0;border-top:1px solid var(--black);}
.step:last-child{border-bottom:1px solid var(--black);}
.step-num{font-family:var(--font-d);font-size:13px;letter-spacing:0.15em;color:var(--mid);min-width:28px;padding-top:3px;}
.step-title{font-family:var(--font-d);font-size:17px;text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:8px;}
.step-desc{font-size:14px;font-weight:300;color:#555;line-height:1.7;}

/* ── SERVICE PAGES RESPONSIVE ─────────────────────────────── */
@media(max-width:900px){
  .two-col,.why-grid,.media-strip{grid-template-columns:1fr;}
  .col-left{border-right:none;border-bottom:1px solid var(--black);}
  .why-grid .why-left{border-right:none;border-bottom:1px solid var(--black);}
  .media-box{border-right:none;border-bottom:1px solid var(--black);height:220px;}
  .cta-bar{flex-direction:column;align-items:flex-start;}
  .other-grid{grid-template-columns:1fr 1fr;}
  .other-link:nth-child(3n){border-right:1px solid var(--black);}
  .other-link:nth-child(2n){border-right:none;}
}


/* ═══════════════════════════════════════════════════════════ */
/* CHAT WIDGET                                                 */
/* ═══════════════════════════════════════════════════════════ */
#chat-bubble{position:fixed;bottom:28px;right:28px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:16px;font-family:'Archivo',sans-serif;}
#chat-toggle{width:58px;height:58px;background:#000;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(0,0,0,0.25);transition:transform .2s,background .2s;flex-shrink:0;}
#chat-toggle:hover{transform:scale(1.08);}
#chat-toggle svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:1.8;transition:opacity .2s;}
#chat-toggle .icon-close{display:none;}
#chat-window{width:360px;background:#fff;border:1px solid #000;display:none;flex-direction:column;overflow:hidden;box-shadow:0 8px 48px rgba(0,0,0,0.18);}
#chat-window.open{display:flex;}
#chat-header{background:#000;color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #222;}
.chat-avatar{width:36px;height:36px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.chat-avatar svg{width:18px;height:18px;stroke:#000;fill:none;stroke-width:1.8;}
.chat-title{font-size:13px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;}
.chat-sub{font-size:11px;color:rgba(255,255,255,0.5);margin-top:1px;}
#chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px;max-height:340px;min-height:200px;}
.msg{max-width:82%;font-size:14px;line-height:1.55;padding:12px 15px;}
.msg.bot{background:#f4f4f2;color:#000;align-self:flex-start;border:1px solid #e8e8e8;}
.msg.user{background:#000;color:#fff;align-self:flex-end;}
.msg.owner{background:#222;color:#fff;align-self:flex-start;border-left:3px solid #666;}
.msg.typing{background:#f4f4f2;border:1px solid #e8e8e8;align-self:flex-start;padding:12px 18px;}
.msg-label{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:4px;}
.msg.user .msg-label{color:rgba(255,255,255,0.5);}
.msg.bot .msg-label{color:rgba(0,0,0,0.4);}
.msg.owner .msg-label{color:rgba(255,255,255,0.45);}
.msg-text{line-height:1.55;}
.msg-status-badge{text-align:center;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:#999;padding:6px 0;width:100%;font-family:'Archivo',sans-serif;}
.typing-dots{display:flex;gap:4px;align-items:center;}
.typing-dots span{width:6px;height:6px;background:#888;border-radius:50%;animation:blink 1.2s infinite;}
.typing-dots span:nth-child(2){animation-delay:.2s;}
.typing-dots span:nth-child(3){animation-delay:.4s;}
@keyframes blink{0%,80%,100%{opacity:0.2;}40%{opacity:1;}}
#chat-input-row{display:flex;border-top:1px solid #000;}
#chat-input{flex:1;border:none;outline:none;padding:14px 16px;font-family:'Archivo',sans-serif;font-size:14px;background:#fff;color:#000;}
#chat-input::placeholder{color:#bbb;}
#chat-send{background:#000;border:none;padding:0 18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;}
#chat-send:hover{opacity:0.7;}
#chat-send svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;}

/* ═══════════════════════════════════════════════
   MOBILE & TABLET RESPONSIVE STYLES
   ═══════════════════════════════════════════════ */

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  background: none;
  border: none;
  z-index: 1000;
}
.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: #fff;
  transition: all 0.3s ease;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 768px) {
  nav { padding: 16px 20px; position: relative; }
  .nav-toggle { display: flex; }
  .nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: var(--white);
    flex-direction: column;
    padding: 20px;
    gap: 16px;
    z-index: 999;
    border-top: 1px solid var(--black);
  }
  .nav-links.open { display: flex; }
  .nav-links li { list-style: none; }
  .nav-links a { font-size: 1rem; padding: 8px 0; display: block; color: var(--black); }
  .nav-cta { display: none; }
  .mobile-only { display: block; border-top: 1px solid #eee; padding-top: 4px; }
  .mobile-only a { font-size: 0.85rem !important; color: var(--mid) !important; padding: 6px 0 !important; }

  /* HERO */
  .hero-main { grid-template-columns: 1fr !important; }
  .hero-right { display: flex !important; min-height: 280px !important; padding: 32px 20px !important; }
  .hero-bottom { display: none !important; }
  .hero-logo-wrap { padding: 20px 20px 32px !important; min-height: auto !important; border-bottom: none !important; background: var(--black) !important; display: flex !important; flex-direction: column !important; justify-content: center !important; }
  .hero-logo-wrap .hero-top-title { font-size: clamp(2.55rem, 11.5vw, 3.83rem) !important; word-break: break-word !important; overflow-wrap: break-word !important; margin-bottom: 24px !important; }
  .hero-logo-wrap .hero-top-title .big { font-size: clamp(2.8rem, 12.75vw, 4.08rem) !important; }
  .hero-logo-wrap img { max-width: 130px !important; margin-bottom: 0 !important; }
  .hero-sub { font-size: 15px !important; max-width: 100% !important; }
  #hero { min-height: auto !important; padding-top: 0 !important; background: var(--black) !important; }
  #hero > .hero-main { margin-top: 68px !important; }

  /* SERVICES */
  .services-head { grid-template-columns: 1fr !important; }
  .services-head-left { padding: 40px 20px !important; border-right: none !important; border-bottom: 1px solid var(--black); }
  .services-head-right { padding: 40px 20px !important; }
  .service-row-link { grid-template-columns: 40px 1fr 80px !important; padding: 0 20px !important; }
  .svc-desc { display: none !important; }
  .svc-name { font-size: clamp(20px, 5vw, 32px) !important; padding: 24px 16px !important; }
  .svc-num { padding: 24px 0 !important; }
  .svc-arrow { opacity: 1 !important; }
  .services-banner { padding: 40px 20px !important; flex-direction: column !important; align-items: flex-start !important; }

  /* WHY / ABOUT */
  #why { grid-template-columns: 1fr !important; }
  .why-left { padding: 60px 20px !important; border-right: none !important; border-bottom: 1px solid var(--black); }
  .why-right { padding: 0 !important; }
  #why .why-right { grid-template-columns: 1fr 1fr !important; border: none !important; }
  .metric-cell { padding: 48px 20px !important; border: none !important; }
  .m-num { font-size: clamp(52px, 12vw, 80px) !important; }
  .m-label { font-size: 12px !important; }
  .metric-cell:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.1) !important; }
  .metric-cell:nth-child(1), .metric-cell:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.1) !important; }

  /* CONTACT */
  #contact { grid-template-columns: 1fr !important; }
  .contact-left { padding: 40px 20px !important; border-right: none !important; border-bottom: 1px solid var(--black); text-align: center !important; }
  .contact-right { padding: 40px 20px !important; }
  .c-items { align-items: center !important; }
  .c-item { text-align: center !important; align-items: center !important; }

  /* STATS */
  .stats-row, .numbers-row { flex-direction: column !important; gap: 24px !important; }

  /* GENERAL */
  .media-strip { grid-template-columns: 1fr !important; height: auto !important; }
  .media-box { height: 220px !important; }
  .two-col { flex-direction: column !important; }
  .col-left, .col-right { width: 100% !important; max-width: 100% !important; }
  input, textarea, select { font-size: 16px !important; }
  #chat-widget { width: calc(100vw - 32px) !important; right: 16px !important; bottom: 70px !important; max-height: 70vh !important; }
  footer { padding: 40px 20px !important; }
  .section-title { font-size: clamp(36px, 10vw, 60px) !important; }

  /* BREADCRUMB — hide on mobile */
  .breadcrumb { display: none !important; }

  /* SERVICE PAGE HERO — fix overflow */
  .svc-hero { padding: 90px 20px 40px !important; min-height: auto !important; }
  .svc-hero .hero-title {
    font-size: clamp(2.5rem, 12vw, 5rem) !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }

  /* STATS GRID */
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .stat-box { padding: 30px 16px !important; }

  /* TICKER — stop overflow */
  .ticker-wrap { overflow: hidden !important; }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .services-grid, .svc-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .hero-top-title { font-size: clamp(3rem, 6vw, 5rem) !important; }
  #hero, .svc-hero { padding: 120px 40px 80px !important; }
  nav { padding: 20px 40px !important; }
}