/* ===================================================================
   TRIMINOG SOLUTION — Corporate Luxury Theme
   Palette derived from logo: Signal Red / Near-Black / Off-White
   =================================================================== */

:root{
  --red:           #E30613;
  --red-dark:      #B5040F;
  --red-light:     #FF4F58;
  --black:         #0D0D0D;
  --charcoal:      #1A1A1A;
  --charcoal-2:    #232323;
  --off-white:     #F7F6F4;
  --white:         #FFFFFF;
  --grey-500:      #8A8A8A;
  --grey-300:      #C9C7C3;
  --grey-100:      #EFEEEC;

  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'Inter', sans-serif;

  --container: 1240px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 24px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  background:var(--off-white);
  color:var(--charcoal);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
svg{ display:block; }
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }

::selection{ background:var(--red); color:var(--white); }

:focus-visible{
  outline:2px solid var(--red);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- Typography helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display);
  font-size:13px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--red);
  margin-bottom:14px;
}
.eyebrow-dot{ width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 0 4px rgba(227,6,19,.15); }
.eyebrow-light{ color:var(--red-light); }

.section-title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(28px, 3.4vw, 44px);
  line-height:1.15;
  letter-spacing:-0.01em;
  color:var(--black);
  max-width:640px;
}
.section-title-light{ color:var(--white); }
.text-red{ color:var(--red); }

.section-text{
  font-size:16px;
  color:#4d4d4d;
  max-width:520px;
  margin-top:16px;
}
.section-text-light{ color:#C9C7C3; }

.section-head{ margin-bottom:56px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display);
  font-weight:600; font-size:14px; letter-spacing:.02em;
  padding:13px 26px;
  border-radius:999px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  white-space:nowrap;
}
.btn-lg{ padding:16px 32px; font-size:15px; }
.btn-primary{
  background:var(--red); color:var(--white);
  box-shadow:0 8px 24px -8px rgba(227,6,19,.55);
}
.btn-primary:hover{ background:var(--red-dark); transform:translateY(-2px); box-shadow:0 12px 28px -8px rgba(227,6,19,.65); }

.btn-outline{
  background:transparent; color:var(--white);
  border:1.5px solid rgba(255,255,255,.35);
}
.btn-outline:hover{ border-color:var(--white); background:rgba(255,255,255,.08); transform:translateY(-2px); }

.btn-outline-dark{
  background:transparent; color:var(--black);
  border:1.5px solid var(--black);
  width:100%;
}
.btn-outline-dark:hover{ background:var(--black); color:var(--white); }

.btn-light{ background:var(--white); color:var(--red); }
.btn-light:hover{ background:var(--off-white); transform:translateY(-2px); }

/* ===================================================================
   PRELOADER
   =================================================================== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  background:var(--black);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s var(--ease), visibility .6s var(--ease);
}
.preloader.done{ opacity:0; visibility:hidden; }
.preloader-mark{
  font-family:var(--font-display); font-weight:700; font-size:54px;
  display:flex; gap:2px;
}
.pl-t{ color:var(--red); animation:pulseLetter 1.1s ease-in-out infinite; }
.pl-w{ color:var(--white); animation:pulseLetter 1.1s ease-in-out infinite .25s; }
@keyframes pulseLetter{ 0%,100%{ opacity:.35; transform:translateY(0);} 50%{ opacity:1; transform:translateY(-6px);} }

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:18px 0;
  transition:background .35s var(--ease), padding .35s var(--ease), box-shadow .35s var(--ease);
}
.site-header.scrolled{
  background:rgba(13,13,13,.92);
  backdrop-filter:blur(14px);
  padding:12px 0;
  box-shadow:0 4px 30px rgba(0,0,0,.25);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}

.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand-mark{
  width:42px; height:42px; object-fit:contain;
  background:var(--white); border-radius:10px; padding:5px;
}
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:var(--font-display); font-weight:700; font-size:17px; color:var(--white); letter-spacing:.03em; }
.brand-sub{ font-family:var(--font-display); font-weight:500; font-size:10px; color:var(--red); letter-spacing:.28em; margin-top:3px; }

.main-nav{ display:flex; align-items:center; gap:32px; }
.main-nav a{
  font-family:var(--font-display); font-size:14px; font-weight:500;
  color:#D9D7D3; position:relative; padding:4px 0;
  transition:color .25s;
}
.main-nav a::after{
  content:''; position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--red); transition:width .25s var(--ease);
}
.main-nav a:hover{ color:var(--white); }
.main-nav a:hover::after{ width:100%; }

.header-cta{ display:flex; align-items:center; gap:16px; flex-shrink:0; }
.phone-pill{
  display:flex; align-items:center; gap:8px;
  color:var(--white); font-family:var(--font-display); font-size:13px; font-weight:500;
}
.phone-pill svg{ color:var(--red); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; width:28px; }
.nav-toggle span{ height:2px; background:var(--white); border-radius:2px; transition:transform .3s var(--ease), opacity .3s var(--ease); }

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  position:relative;
  background:var(--black);
  padding:160px 0 0;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-diagonal{
  position:absolute; top:-10%; right:-15%; width:75%; height:130%;
  background:linear-gradient(135deg, var(--red) 0%, var(--red-dark) 55%, transparent 100%);
  clip-path:polygon(38% 0, 100% 0, 100% 100%, 0% 100%);
  opacity:.94;
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), transparent 80%);
}

.hero-inner{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.15fr .85fr; gap:40px;
  align-items:center;
  padding-bottom:110px;
}
.hero-copy .eyebrow{ color:var(--red-light); }
.hero-title{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(36px, 5vw, 60px); line-height:1.08; letter-spacing:-0.01em;
  color:var(--white);
  max-width:620px;
}
.hero-title .text-red{ color:var(--red-light); }
.hero-subtitle{
  margin-top:22px; font-size:17px; color:#C9C7C3; max-width:520px;
}
.hero-actions{ display:flex; gap:16px; margin-top:34px; flex-wrap:wrap; }

.hero-stats{
  display:flex; gap:40px; margin-top:56px; padding-top:32px;
  border-top:1px solid rgba(255,255,255,.12);
  flex-wrap:wrap;
}
.stat{ display:flex; flex-direction:column; }
.stat-num, .stat-plus{
  font-family:var(--font-display); font-weight:700; font-size:32px; color:var(--white); display:inline;
}
.stat-plus{ color:var(--red-light); }
.stat-label{ font-size:13px; color:var(--grey-500); margin-top:6px; max-width:140px; }

.hero-visual{ position:relative; display:flex; justify-content:center; }
.hero-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(16px);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  width:100%; max-width:340px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6);
  animation:floatCard 6s ease-in-out infinite;
}
@keyframes floatCard{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-14px);} }
.hero-card-icon{ width:64px; height:auto; object-fit:contain; margin-bottom:22px; border-radius:8px; background:var(--white); padding:6px; }
.hero-card-row{ margin-bottom:16px; }
.hero-card-row span{ font-size:12px; color:var(--grey-300); display:block; margin-bottom:6px; font-family:var(--font-display); }
.bar{ height:6px; background:rgba(255,255,255,.1); border-radius:4px; overflow:hidden; }
.bar span{
  display:block; height:100%; background:linear-gradient(90deg, var(--red) , var(--red-light));
  border-radius:4px; width:0;
  transition:width 1.4s var(--ease);
}
.hero-card.in-view .bar span{ width:var(--w, 90%); }
.hero-card-tag{
  margin-top:22px; text-align:center; font-family:var(--font-display); font-size:12px; font-weight:600;
  letter-spacing:.06em; color:var(--white); background:var(--red); padding:10px; border-radius:999px;
}
.hero-float-badge{
  position:absolute; bottom:-22px; left:-12px;
  background:var(--white); color:var(--black);
  border-radius:var(--radius-md);
  padding:14px 18px; display:flex; align-items:center; gap:10px;
  box-shadow:0 20px 40px -10px rgba(0,0,0,.5);
}
.hero-float-badge strong{ font-family:var(--font-display); font-size:26px; color:var(--red); }
.hero-float-badge span{ font-size:11px; line-height:1.3; font-weight:600; color:var(--charcoal); }

.hero-marquee{
  position:relative; z-index:1;
  border-top:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  overflow:hidden; padding:18px 0;
}
.marquee-track{
  display:flex; gap:28px; white-space:nowrap;
  font-family:var(--font-display); font-size:13px; font-weight:600;
  letter-spacing:.14em; color:var(--grey-500);
  animation:scrollMarquee 32s linear infinite;
  width:max-content;
}
.marquee-track span:nth-child(odd){ color:var(--red-light); }
@keyframes scrollMarquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ===================================================================
   ABOUT
   =================================================================== */
.about{ padding:120px 0; background:var(--off-white); position:relative; }
.about-inner{ display:grid; grid-template-columns:.9fr 1.1fr; gap:64px; align-items:center; }

.about-frame{
  position:relative;
  background:var(--charcoal);
  border-radius:var(--radius-lg);
  padding:52px 36px;
  overflow:hidden;
}
.about-frame-glow{
  position:absolute; top:-30%; right:-30%; width:70%; height:70%;
  background:radial-gradient(circle, rgba(227,6,19,.35), transparent 70%);
}
.about-icon{
  width:130px; height:auto; margin:0 auto 36px; display:block;
  background:var(--white); border-radius:14px; padding:14px;
  position:relative; z-index:1;
}
.about-checklist{ position:relative; z-index:1; display:flex; flex-direction:column; gap:18px; }
.about-checklist li{
  display:flex; align-items:flex-start; gap:12px;
  color:var(--grey-300); font-size:14.5px; font-weight:500;
}
.about-checklist .check{
  flex-shrink:0; width:22px; height:22px; border-radius:50%;
  background:var(--red); color:var(--white);
  display:flex; align-items:center; justify-content:center;
  font-size:12px;
}

.about-mini-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:32px; }
.about-mini{
  background:var(--white); border-left:3px solid var(--red);
  border-radius:var(--radius-sm); padding:20px;
  box-shadow:0 10px 30px -16px rgba(0,0,0,.12);
}
.about-mini h3{ font-family:var(--font-display); font-size:15px; margin-bottom:8px; }
.about-mini p{ font-size:13.5px; color:#5b5b5b; }

/* ===================================================================
   SERVICES
   =================================================================== */
.services{ padding:120px 0; background:var(--black); position:relative; }
.services-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.service-card{
  background:var(--charcoal);
  padding:38px 30px;
  transition:background .3s var(--ease), transform .3s var(--ease);
  position:relative;
}
.service-card:hover{ background:var(--charcoal-2); }
.service-card:hover .service-icon{ color:var(--red); transform:translateY(-4px); }
.service-icon{
  width:48px; height:48px; color:var(--red-light);
  margin-bottom:20px; transition:transform .3s var(--ease), color .3s var(--ease);
}
.service-icon svg{ width:100%; height:100%; }
.service-card h3{
  font-family:var(--font-display); font-size:17px; font-weight:600;
  color:var(--white); margin-bottom:10px; line-height:1.3;
}
.service-card p{ font-size:13.5px; color:var(--grey-500); line-height:1.6; }

/* ===================================================================
   PROCESS
   =================================================================== */
.process{ padding:120px 0; background:var(--off-white); }
.process-track{
  position:relative;
  display:grid; grid-template-columns:repeat(5, 1fr); gap:24px;
}
.process-line{
  position:absolute; top:24px; left:0; right:0; height:2px;
  background:repeating-linear-gradient(90deg, var(--grey-300) 0 8px, transparent 8px 16px);
  z-index:0;
}
.process-step{
  position:relative; z-index:1; background:var(--off-white);
  padding-top:8px;
}
.process-num{
  font-family:var(--font-display); font-weight:700; font-size:16px;
  color:var(--white); background:var(--red);
  width:48px; height:48px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:22px;
  box-shadow:0 10px 24px -8px rgba(227,6,19,.5);
}
.process-step h3{ font-family:var(--font-display); font-size:16.5px; margin-bottom:10px; }
.process-step p{ font-size:13.5px; color:#5b5b5b; line-height:1.6; }

/* ===================================================================
   PORTFOLIO
   =================================================================== */
.portfolio{ padding:120px 0; background:var(--charcoal); }
.portfolio-filter{
  display:flex; gap:10px; margin-bottom:44px; flex-wrap:wrap;
}
.filter-btn{
  font-family:var(--font-display); font-size:13px; font-weight:600;
  color:var(--grey-300); padding:10px 20px; border-radius:999px;
  border:1px solid rgba(255,255,255,.15);
  transition:all .25s var(--ease);
}
.filter-btn:hover{ border-color:var(--red); color:var(--white); }
.filter-btn.active{ background:var(--red); color:var(--white); border-color:var(--red); }

.portfolio-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
}
.portfolio-card{
  border-radius:var(--radius-md); overflow:hidden;
  background:var(--charcoal-2);
  border:1px solid rgba(255,255,255,.08);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.portfolio-card.hide{ display:none; }
.portfolio-card:hover{ transform:translateY(-8px); box-shadow:0 30px 50px -20px rgba(0,0,0,.5); }
.portfolio-visual{
  height:200px; position:relative; overflow:hidden;
}
.portfolio-visual::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, transparent 40%, rgba(0,0,0,.5));
}
.pv-1{ background:linear-gradient(135deg, #E30613 0%, #4a0307 100%); }
.pv-2{ background:linear-gradient(135deg, #2b2b2b 0%, #0d0d0d 100%); }
.pv-3{ background:linear-gradient(135deg, #B5040F 0%, #1a1a1a 100%); }
.pv-4{ background:linear-gradient(135deg, #3a3a3a 0%, #E30613 120%); }
.pv-5{ background:linear-gradient(135deg, #1a1a1a 0%, #B5040F 140%); }
.pv-6{ background:linear-gradient(135deg, #E30613 0%, #2b2b2b 100%); }
.portfolio-visual::before{
  content:'TW'; position:absolute; bottom:14px; right:18px;
  font-family:var(--font-display); font-weight:700; font-size:13px;
  color:rgba(255,255,255,.5); letter-spacing:.1em;
}
.portfolio-info{ padding:24px; }
.portfolio-tag{
  font-family:var(--font-display); font-size:11px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--red-light);
}
.portfolio-info h3{ font-family:var(--font-display); font-size:18px; color:var(--white); margin:10px 0 8px; }
.portfolio-info p{ font-size:13.5px; color:var(--grey-500); line-height:1.6; }

/* ===================================================================
   OFFER
   =================================================================== */
.offer{
  padding:90px 0; background:linear-gradient(120deg, var(--red-dark), var(--red) 60%, var(--red-light));
  position:relative; overflow:hidden;
}
.offer::before{
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size:36px 36px;
}
.offer-inner{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.4fr .6fr; gap:40px; align-items:center;
}
.offer .eyebrow{ color:rgba(255,255,255,.85); }
.offer .eyebrow-dot{ background:var(--white); box-shadow:0 0 0 4px rgba(255,255,255,.25); }
.offer-title{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(28px, 3.6vw, 42px); color:var(--white); line-height:1.2;
}
.offer-percent{ display:inline-block; background:var(--black); color:var(--white); padding:2px 14px; border-radius:8px; }
.offer-text{ color:rgba(255,255,255,.9); margin:18px 0 28px; max-width:480px; }

.offer-countdown{ display:flex; gap:14px; margin-bottom:30px; }
.cd-box{
  background:rgba(0,0,0,.25); border-radius:var(--radius-sm);
  padding:14px 18px; text-align:center; min-width:70px;
}
.cd-box span{ display:block; font-family:var(--font-display); font-weight:700; font-size:26px; color:var(--white); }
.cd-box label{ font-size:11px; color:rgba(255,255,255,.75); text-transform:uppercase; letter-spacing:.08em; }

.offer-badge{ display:flex; justify-content:center; }
.offer-badge-circle{
  width:200px; height:200px; border-radius:50%;
  background:var(--black);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  border:6px solid rgba(255,255,255,.25);
  animation:spinSlow 16s linear infinite;
}
.offer-badge-num{ font-family:var(--font-display); font-weight:700; font-size:40px; color:var(--white); }
.offer-badge-label{ font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--red-light); letter-spacing:.1em; }
@keyframes spinSlow{ from{ transform:rotate(0); } to{ transform:rotate(360deg); } }

/* ===================================================================
   PACKAGES
   =================================================================== */
.packages{ padding:120px 0; background:var(--off-white); }
.packages-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:28px;
  align-items:stretch;
}
.package-card{
  background:var(--white);
  border:1px solid var(--grey-100);
  border-radius:var(--radius-lg);
  padding:40px 32px;
  display:flex; flex-direction:column;
  box-shadow:0 20px 40px -28px rgba(0,0,0,.15);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  position:relative;
}
.package-card:hover{ transform:translateY(-6px); box-shadow:0 30px 50px -24px rgba(0,0,0,.2); }
.package-featured{
  background:var(--charcoal); border-color:var(--charcoal); color:var(--white);
  transform:scale(1.03);
}
.package-featured:hover{ transform:scale(1.03) translateY(-6px); }
.package-ribbon{
  position:absolute; top:-13px; left:32px;
  background:var(--red); color:var(--white);
  font-family:var(--font-display); font-size:11px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  padding:6px 14px; border-radius:999px;
}
.package-card h3{ font-family:var(--font-display); font-size:22px; margin-bottom:10px; }
.package-featured h3{ color:var(--white); }
.package-desc{ font-size:14px; color:#6b6b6b; min-height:42px; }
.package-featured .package-desc{ color:var(--grey-300); }
.package-price{
  font-family:var(--font-display); font-weight:700; font-size:40px;
  margin:24px 0 28px; color:var(--black);
}
.package-featured .package-price{ color:var(--white); }
.package-price .cur{ font-size:16px; font-weight:600; margin-right:4px; color:var(--red); vertical-align:middle; }
.package-price .per{ font-size:13px; font-weight:500; color:var(--grey-500); margin-left:4px; }
.package-list{ display:flex; flex-direction:column; gap:13px; margin-bottom:32px; flex-grow:1; }
.package-list li{
  font-size:14px; padding-left:26px; position:relative; color:#444;
}
.package-featured .package-list li{ color:var(--grey-300); }
.package-list li::before{
  content:'✓'; position:absolute; left:0; top:0;
  color:var(--red); font-weight:700;
}

/* ===================================================================
   FAQ
   =================================================================== */
.faq{ padding:120px 0; background:var(--white); }
.faq-inner{ display:grid; grid-template-columns:.8fr 1.2fr; gap:60px; }
.faq-side .btn{ margin-top:8px; }

.faq-item{
  border-bottom:1px solid var(--grey-100);
}
.faq-question{
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:22px 4px; text-align:left;
  font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--black);
}
.faq-icon{
  flex-shrink:0; width:28px; height:28px; border-radius:50%;
  border:1.5px solid var(--grey-300); color:var(--charcoal);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; transition:all .3s var(--ease);
}
.faq-item.active .faq-icon{ background:var(--red); border-color:var(--red); color:var(--white); transform:rotate(45deg); }
.faq-answer{
  max-height:0; overflow:hidden; transition:max-height .35s var(--ease);
}
.faq-answer p{ padding:0 4px 22px; font-size:14.5px; color:#5b5b5b; max-width:560px; }
.faq-item.active .faq-answer{ max-height:200px; }

/* ===================================================================
   CTA STRIP
   =================================================================== */
.cta-strip{ background:var(--black); padding:80px 0; }
.cta-strip-inner{
  display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
}
.cta-strip h2{
  font-family:var(--font-display); font-weight:600; font-size:clamp(24px, 3vw, 34px); color:var(--white); max-width:480px;
}
.cta-strip p{ color:var(--grey-500); margin-top:10px; max-width:420px; }
.cta-strip-actions{ display:flex; gap:16px; flex-wrap:wrap; }

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{ background:var(--charcoal); padding-top:80px; }
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px;
  padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand p{ margin:18px 0 22px; font-size:14px; color:var(--grey-500); max-width:280px; }
.footer-social{ display:flex; gap:12px; }
.footer-social a{
  width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(255,255,255,.15); color:var(--grey-300);
  display:flex; align-items:center; justify-content:center;
  transition:all .25s var(--ease);
}
.footer-social a:hover{ background:var(--red); border-color:var(--red); color:var(--white); }

.footer-col h4{
  font-family:var(--font-display); font-size:14px; color:var(--white);
  letter-spacing:.04em; margin-bottom:20px;
}
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col li, .footer-col a{ font-size:14px; color:var(--grey-500); }
.footer-col a:hover{ color:var(--red-light); }
.footer-contact h4:not(:first-child){ margin-top:24px; }

.footer-bottom{ padding:26px 0; }
.footer-bottom-inner{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.footer-bottom p{ font-size:13px; color:var(--grey-500); }

/* ===================================================================
   BACK TO TOP
   =================================================================== */
.back-to-top{
  position:fixed; bottom:28px; right:28px; z-index:900;
  width:46px; height:46px; border-radius:50%;
  background:var(--red); color:var(--white);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 12px 24px -8px rgba(227,6,19,.6);
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:all .3s var(--ease);
}
.back-to-top.visible{ opacity:1; visibility:visible; transform:translateY(0); }
.back-to-top:hover{ background:var(--red-dark); }

/* ===================================================================
   SCROLL REVEAL (JS-toggled)
   =================================================================== */
[data-reveal]{
  opacity:0; transform:translateY(28px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
[data-reveal].is-visible{ opacity:1; transform:translateY(0); }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width: 1080px){
  .services-grid{ grid-template-columns:repeat(2, 1fr); }
  .process-track{ grid-template-columns:repeat(3, 1fr); row-gap:48px; }
  .process-line{ display:none; }
  .portfolio-grid{ grid-template-columns:repeat(2, 1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width: 900px){
  .main-nav{ display:none; }
  .header-cta .phone-pill{ display:none; }
  .nav-toggle{ display:flex; }

  .hero{ padding-top:120px; }
  .hero-inner{ grid-template-columns:1fr; }
  .hero-visual{ margin-top:40px; }
  .hero-stats{ gap:28px; }

  .about-inner{ grid-template-columns:1fr; }
  .about-mini-grid{ grid-template-columns:1fr; }

  .offer-inner{ grid-template-columns:1fr; text-align:center; }
  .offer .eyebrow, .offer-text{ margin-left:auto; margin-right:auto; }
  .offer-countdown{ justify-content:center; }
  .offer-badge{ order:-1; }

  .faq-inner{ grid-template-columns:1fr; }
  .packages-grid{ grid-template-columns:1fr; }
  .package-featured{ transform:none; order:-1; }
  .package-featured:hover{ transform:translateY(-6px); }

  .cta-strip-inner{ flex-direction:column; align-items:flex-start; }
}

@media (max-width: 640px){
  .services-grid{ grid-template-columns:1fr; }
  .process-track{ grid-template-columns:1fr; }
  .portfolio-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:36px; }
  .hero-title{ font-size:34px; }
  .hero-stats{ flex-direction:column; gap:18px; }
  .offer-countdown{ flex-wrap:wrap; }

  /* Mobile nav drawer */
  .main-nav{
    display:flex; flex-direction:column;
    position:fixed; top:0; right:0; height:100vh; width:74%;
    background:var(--black); padding:100px 32px 32px;
    transform:translateX(100%); transition:transform .4s var(--ease);
    gap:24px; z-index:999;
  }
  .main-nav.open{ transform:translateX(0); }
  .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); }
}
