/* Garrett Media Main CSS */
:root{
  --bg: #ffffff;
  --text: #0b0e11;
  --muted: #5a6a7b;
  --card: #f7f9fc;
  --border: #e6eef7;
  --blue-50: #eef6ff;
  --blue-100: #d9ebff;
  --blue-300: #7ab6ff;
  --blue-500: #2878ff;
  --blue-600: #0f5fe3;
  --accent: var(--blue-500);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: "Montserrat", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height:1.6;
}

.container{max-width:1100px;margin:0 auto;padding:0 20px}

a{color:var(--accent);text-decoration:none}
a:hover{opacity:.9}

img{max-width:100%;display:block;border-radius:14px}

.section{padding:80px 0}
.section-title{
  font-size:clamp(28px, 5vw, 40px);
  margin:0 0 16px 0;
}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--border);
}

.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.site-nav{margin-left:auto;margin-right:10px}
.header-cta{margin-left:0}

.site-title{font-weight:800;font-size:22px;color:var(--text)}
.site-title .accent{color:var(--accent)}

.nav-toggle{display:none;background:none;border:0;font-size:28px}
.site-nav .menu{display:flex;gap:22px;list-style:none;margin:0;padding:0}
.site-nav .menu > li{position:relative}
.site-nav .menu > li > a{
  display:inline-block;padding:8px 12px;border-radius:10px;color:var(--text);
  transition: background .2s ease;
}
.site-nav .menu > li > a:hover{background:var(--blue-50)}

/* Dropdown (for Services children) */
.site-nav .menu .sub-menu{
  position:absolute;top:42px;left:0;background:#fff;border:1px solid var(--border);
  border-radius:12px;padding:8px 0;list-style:none;display:none;min-width:180px;box-shadow:0 10px 30px rgba(0,0,0,.08);
}
.site-nav .menu li:hover > .sub-menu{display:block}
.site-nav .menu .sub-menu li a{display:block;padding:8px 14px;color:var(--text)}
.site-nav .menu .sub-menu li a:hover{background:var(--blue-50)}

/* Mobile */
@media (max-width: 820px){
  .nav-toggle{display:block}
  .site-nav{position:fixed;inset:60px 0 0 0;background:#fff;transform:translateY(-120%);transition:.25s;box-shadow:0 12px 30px rgba(0,0,0,.08);}
  .site-nav.open{transform:translateY(0)}
  .site-nav .menu{flex-direction:column;padding:18px}
}

/* Buttons */
.btn{
  display:inline-block;border:1px solid var(--accent);padding:12px 18px;border-radius:12px;
  font-weight:600; transition: all .2s ease; text-align:center;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.15)}
.btn-outline{color:var(--accent);background:transparent}
.btn-outline:hover{background:var(--blue-50)}

/* Preloader */
.preloader{
  position:fixed;inset:0;background:#fff;display:flex;align-items:center;justify-content:center;
  z-index:9999; transition: opacity .4s ease, visibility .4s ease;
}
.preloader.hide{opacity:0;visibility:hidden}
.preloader .preloader-inner{font-size:32px;font-weight:800;letter-spacing:.5px}
.preloader .accent{background: linear-gradient(90deg, var(--blue-300), var(--blue-600)); -webkit-background-clip: text; -webkit-text-fill-color: transparent;}

/* Hero */
.hero{padding:100px 0 70px;background:linear-gradient(180deg, #fff, #f8fbff)}
.hero-title{
  font-weight:800;line-height:1.2;margin:0 0 8px 0;
  font-size:clamp(28px, 4.5vw, 52px);
}
#typed-output{
  background-image: linear-gradient( to top, var(--blue-100) 0 55%, transparent 55% 100% );
  padding: 0 .2em;
  border-radius: 4px;
}
.cursor{display:inline-block;margin-left:6px;animation:blink 1s infinite}
@keyframes blink { 50% { opacity:0 } }
.hero-sub{color:var(--muted);margin:6px 0 20px 0}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap}

/* Testimonials */
.testimonials{background:#fff}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.quote{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px}
@media (max-width: 900px){
  .testimonials-grid{grid-template-columns:1fr}
}

/* Who we are */
.who .lede{font-weight:600;color:var(--muted)}
.team-inline{display:flex;gap:18px;align-items:center;margin:22px 0}
.team-card{display:flex;gap:16px;background:var(--card);border:1px solid var(--border);padding:16px;border-radius:16px}
.team-photo img{width:120px;height:120px;object-fit:cover;border-radius:14px}

/* Services */
.service-tabs{display:flex;gap:10px;margin-bottom:14px}
.service-tabs .tab{padding:8px 12px;border-radius:12px;background:var(--blue-50);border:1px solid var(--blue-100)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.card-body{padding:14px}
.card h3{margin:0 0 8px 0}
@media (max-width: 900px){
  .cards{grid-template-columns:1fr}
}

/* Contact */
.contact .contact-form{margin-top:16px}
.field{display:flex;flex-direction:column;margin-bottom:12px}
.field label{font-size:14px;color:var(--muted);margin-bottom:6px}
.field input, .field textarea{
  border:1px solid var(--border);background:#fff;padding:12px;border-radius:12px;outline:0;
}
.field input:focus, .field textarea:focus{border-color:var(--blue-300);box-shadow:0 0 0 3px rgba(40,120,255,.08)}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 700px){ .grid{grid-template-columns:1fr} }

.contact-status{margin-top:10px;font-weight:600}
.contact-status.ok{color:green}
.contact-status.err{color:#c00}

.socials{display:flex;gap:12px;margin-top:16px}
.social{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--border);border-radius:12px;background:#fff}
.social:hover{background:var(--blue-50)}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:20px 0;background:#fff;color:var(--muted);text-align:center}

/* Page generic */
.page .narrow{max-width:800px;margin:0 auto}
.service-hero img{width:100%;height:auto;border-radius:16px}
.content p{margin:0 0 12px 0}
.cta{margin-top:20px}


/* --- Polished Testimonials --- */
.testimonials{position:relative;background:linear-gradient(180deg,#ffffff 0%, #f9fbff 100%)}
.testimonials:before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 180px at 20% 0%, rgba(40,120,255,0.08), transparent 60%),
    radial-gradient(600px 150px at 80% 0%, rgba(15,95,227,0.08), transparent 60%);
  pointer-events:none;
}
.testimonials-grid{gap:22px}
.quote{
  position:relative;
  background:linear-gradient(180deg,#fff, #f7faff);
  border:1px solid var(--border);
  box-shadow:0 8px 24px rgba(16,24,40,.06);
  border-radius:18px;
  padding:22px 20px 20px 22px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform;
}
.quote:before{
  content:"“";
  position:absolute; top:-10px; left:14px;
  font-size:54px; line-height:1; color:var(--blue-100);
  pointer-events:none;
}
.quote:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(16,24,40,.10);
  border-color: var(--blue-100);
}

/* --- Header CTA --- */
.header-cta{margin-left:12px; display:none}
@media (min-width: 900px){ .header-cta{display:inline-block} }

/* --- Light Accents & Animations --- */
.section{
  position:relative;
}
.section .accent-sheen{
  position:absolute; inset:auto 0 -120px 0; height:160px;
  background: radial-gradient(50% 120px at 50% 0, rgba(40,120,255,.10), transparent 70%);
  pointer-events:none;
}

/* Reveal on scroll */
.reveal{opacity:0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important; animation:none !important}
}


@media (max-width: 480px){
  .section{padding:64px 0}
  .quote{padding:18px;border-radius:16px}
  .hero-title{font-size:clamp(26px, 8vw, 42px)}
  .header-inner{gap:10px}
}


.card{transition:transform .25s ease, box-shadow .25s ease}
.card:hover, .card.hover{transform:translateY(-2px); box-shadow:0 12px 28px rgba(16,24,40,.08)}


/* --- Mobile Nav Fixes --- */
@media (max-width: 820px){
  .site-nav{top:60px; height:calc(100% - 60px); overflow-y:auto; padding:24px 16px}
  .site-nav .menu{flex-direction:column; gap:12px}
  .site-nav .menu li{border-bottom:1px solid var(--border); padding-bottom:10px}
  .site-nav .menu li:last-child{border-bottom:0}
  .header-cta{display:block; margin:18px 0 0 0; width:100%; text-align:center}
}


/* Anchor offset for sticky header */
.section{scroll-margin-top:84px}

/* Mobile menu fix: ensure it overlays content properly */
@media (max-width: 820px){
  .site-header{z-index:1001}
  .site-nav{z-index:1002; top:64px}
  .site-nav .menu > li > a{padding:14px 10px; font-size:18px}
  .brand .site-title{font-size:20px}
  .hero{padding-top:84px}
}

/* Improve hamburger alignment */
.header-inner{gap:12px}

/* Make mobile menu icon more tappable */
.nav-toggle{padding:8px 10px}


/* --- Mobile Header & Menu Fix --- */
@media (max-width: 820px){
  .site-header{z-index:1001}
  .header-inner{padding:12px 16px}
  .nav-toggle{margin-left:auto;font-size:28px;color:var(--accent)}
  .site-nav{
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:#fff; transform:translateY(-100%);
    transition:transform .3s ease;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    gap:20px; font-size:22px;
  }
  .site-nav.open{transform:translateY(0)}
  .site-nav .menu{flex-direction:column; gap:18px; align-items:center}
  .site-nav .menu > li > a{font-size:22px; padding:10px 0}
  .header-cta{display:block; margin-top:30px; font-size:20px; padding:14px 22px}
}


/* === Robust Mobile Header/Menu === */
@media (max-width: 820px){
  .site-header{position:sticky; top:0; z-index:1003; background:rgba(255,255,255,.98);}
  .header-inner{padding:10px 0}
  .nav-toggle{font-size:30px; line-height:1; padding:8px 10px; border-radius:10px}
  .site-nav{position:fixed; inset:64px 0 0 0; transform:translateY(-100%); transition:transform .25s ease; background:#fff; box-shadow:0 20px 40px rgba(0,0,0,.12);}
  .site-nav.open{transform:translateY(0)}
  .site-nav .menu{flex-direction:column; padding:18px 20px; gap:8px}
  .site-nav .menu > li > a{padding:12px 10px; font-size:18px; border-radius:10px}
  .header-cta{display:none}
  body.nav-open{overflow:hidden}
  body.nav-open::before{content:""; position:fixed; inset:64px 0 0 0; background:rgba(0,0,0,.25); z-index:1002}
  .hero{padding-top:94px}
}


.nav-toggle{color:var(--accent)}


/* --- Full-screen Mobile Nav Overlay --- */
@media (max-width: 820px){
  .site-nav{
    position:fixed;
    inset:0;
    background:#fff;
    transform:translateY(-100%);
    transition:transform .3s ease;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    z-index:1000;
  }
  .site-nav.open{transform:translateY(0)}
  .site-nav .menu{
    flex-direction:column;
    gap:24px;
    font-size:22px;
  }
  body.menu-open{overflow:hidden}
  .nav-toggle{
    z-index:1101;
    font-size:30px;
    padding:10px;
  }
}


/* === v1.5 Mobile full-screen menu overlay === */
@media (max-width: 820px){
  .site-nav{
    position:fixed;
    inset:0;
    background:#ffffff;
    transform:translateY(-100%);
    transition:transform .28s ease;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:40px 20px;
    box-shadow:none;
  }
  .site-nav.open{ transform:translateY(0) }
  .site-nav .menu{
    flex-direction:column;
    gap:24px;
    font-size:22px;
    padding:0;
  }
  .site-nav .menu > li > a{
    padding:10px 14px;
    border-radius:12px;
    font-weight:600;
  }
  body.menu-open{ overflow:hidden }
  .nav-toggle{ z-index:1100; font-size:30px; padding:10px }
}


/* v1.6 header brand padding */
.brand{padding-left:16px}

/* Ensure nav menu is visible in overlay */
@media (max-width: 820px){
  .site-nav{overflow-y:auto}
  .site-nav .menu{display:flex !important}
}


/* === v1.5.1 fixes === */
@media (max-width: 820px){
  .container{padding:0 24px}
  .site-nav{z-index:1200}
  .site-nav.open::before{
    content:"";
    position:fixed; inset:0;
    background:rgba(0,0,0,.4);
    z-index:-1;
  }
  .site-header{padding:6px 0}
  .brand .site-title{padding-left:2px}
}
/* ensure UL has no default margins in overlay */
.site-nav .menu{margin:0}


/* v1.5.2 ensure nav is fully on top and visible */
@media (max-width: 820px){
  .site-nav{ z-index: 3000; height:100vh; }
  .site-nav .menu{ color: var(--text); }
  .brand{ padding-left: 6px; }
}

/* Backdrop for mobile menu */
.nav-backdrop{
  position:fixed; inset:0; background: rgba(9,11,15,.45);
  opacity:0; visibility:hidden; transition: opacity .25s ease, visibility .25s ease;
  z-index: 2500;
}
.nav-backdrop.show{ opacity:1; visibility:visible }


/* v1.5.3: Force mobile menu visibility model (opacity/visibility) */
@media (max-width: 820px){
  header.site-header + .site-nav, .site-header .site-nav { /* increase specificity just in case */ }
  .site-nav{
    position:fixed !important;
    inset:0 !important;
    background:#ffffff !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    padding:40px 20px !important;
    opacity:0; visibility:hidden; pointer-events:none;
    z-index:4000 !important;
    transform:none !important; /* neutralize older translate rules */
  }
  .site-nav.open{
    opacity:1; visibility:visible; pointer-events:auto;
  }
  .site-nav .menu{
    flex-direction:column !important;
    gap:24px !important;
    font-size:22px !important;
    padding:0 !important; margin:0 !important;
  }
}


/* === v1.6 Dedicated mobile drawer === */
.mobile-backdrop{
  position:fixed; inset:0; background:rgba(9,11,15,.5); opacity:0; visibility:hidden; transition:.25s;
  z-index: 5000;
}
.mobile-drawer{
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:.25s; z-index: 5001;
}
.mobile-drawer .mobile-drawer-inner{
  background:#fff; border-radius:16px; width:min(92vw, 520px); max-height:86vh; padding:22px;
  box-shadow:0 24px 60px rgba(16,24,40,.2); overflow:auto;
}
.mobile-drawer .mobile-close{
  position:absolute; top:10px; right:16px; font-size:30px; line-height:1; background:transparent; border:0; cursor:pointer;
}
.mobile-nav .mobile-menu{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px }
.mobile-nav .mobile-menu a{ display:block; padding:12px 14px; border-radius:12px; font-weight:600; color:var(--text) }
.mobile-nav .mobile-menu a:hover{ background:var(--blue-50) }
.mobile-cta{ display:block; margin-top:14px }

@media (max-width: 820px){
  body.menu-open .mobile-backdrop{ opacity:1; visibility:visible }
  body.menu-open .mobile-drawer{ opacity:1; visibility:visible }

  /* Keep desktop nav hidden inside header when drawer is used (only show hamburger) */
  .site-nav{ display:none }
  .nav-toggle{ display:block }
}

.gm-no-preloader #preloader{display:none !important}


/* ===== v1.7.0 UI polish ===== */

/* Accent gradients */
:root{
  --accent-grad: linear-gradient(90deg, var(--blue-500), var(--blue-600));
}

/* Buttons: fuller, with subtle depth + shine */
.btn{
  position:relative;
  padding:13px 20px;
  border-radius:14px;
  transition:transform .16s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  will-change: transform;
}
.btn:active{ transform: translateY(1px) scale(.99) }
.btn:focus-visible{ outline: none; box-shadow: 0 0 0 3px rgba(40,120,255,.18) }

.btn-primary{
  background: var(--accent-grad);
  border-color: transparent;
  box-shadow: 0 8px 20px rgba(40,120,255,.25);
}
.btn-primary:hover{ filter: brightness(1.06); box-shadow: 0 10px 26px rgba(40,120,255,.30) }
.btn-primary::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(120deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.35) 40%, rgba(255,255,255,0) 70%);
  transform: translateX(-120%);
  transition: transform .6s ease;
  border-radius: inherit; pointer-events:none;
}
.btn-primary:hover::after{ transform: translateX(120%) }

.btn-outline{
  border-color: var(--blue-300);
  box-shadow: 0 2px 10px rgba(16,24,40,.06);
}
.btn-outline:hover{ background:#fff; box-shadow: 0 6px 18px rgba(16,24,40,.10) }

/* Ripple effect */
.btn{ overflow:hidden }
.btn .ripple{
  position:absolute; border-radius:50%; opacity:.35; transform: scale(0);
  background: currentColor; filter: saturate(0%) brightness(160%);
  animation: gm-ripple .6s ease-out forwards;
  pointer-events:none;
}
@keyframes gm-ripple{ to { transform: scale(1); opacity:0 } }

/* Social icons: gradient ring + hover float */
.social{
  width:46px; height:46px; border-radius:50%;
  padding:2px; border: none; background: conic-gradient(from 0deg, var(--blue-300), var(--blue-600), var(--blue-300));
}
.social svg{ background:#fff; border-radius:50%; width:100%; height:100%; padding:10px }
.social:hover{ transform: translateY(-2px); box-shadow: 0 10px 22px rgba(16,24,40,.12) }

/* Inputs: clearer focus + subtle inner shadow */
.field input, .field textarea{
  background: #fff; box-shadow: inset 0 1px 2px rgba(16,24,40,.04);
}
.field input::placeholder, .field textarea::placeholder{ color:#9aa9bb }
.field input:focus, .field textarea:focus{
  border-color: var(--blue-300);
  box-shadow: 0 0 0 4px rgba(40,120,255,.10);
}

/* Contact CTA sizing */
.contact .btn{ padding:14px 22px; font-weight:700 }
@media (max-width: 560px){
  .contact .btn{ width:100% }
}

/* Hero & section polish */
.hero{
  position:relative;
}
.hero:after{
  content:""; position:absolute; left:50%; transform:translateX(-50%); bottom:-40px;
  width:min(1100px, 88vw); height:120px;
  background: radial-gradient(50% 60% at 50% 0, rgba(40,120,255,.18), rgba(40,120,255,0));
  filter: blur(12px); pointer-events:none;
}

/* Testimonial gradient border via outline shadow */
.quote{
  box-shadow:
    0 1px 0 rgba(16,24,40,.02),
    0 8px 24px rgba(16,24,40,.06),
    0 0 0 1px var(--border) inset;
}

/* Micro hover for cards already present; add slight scale */
.card:hover, .card.hover{ transform: translateY(-3px) scale(1.01) }

/* v1.7.1 Hero typing area lock fallback */
.hero-title{min-height:clamp(40px,8vw,120px)}


/* v1.7.2: slower preloader fade */
.preloader{ transition: opacity 1.2s ease, visibility 1.2s ease }

/* v1.7.2: caret no-layout-shift */
.hero-title{ position: relative }
.cursor{ display:none !important }
#typed-output::after{
  content:"|"; margin-left:6px; animation:blink 1s infinite; opacity:.8;
}

/* v1.7.2: fallback reserved space for 3 lines on small screens */
@media (max-width: 680px){
  .hero-title{ min-height: 3.2em }
}


/* === v1.7.7 mobile polish: who-we-are headshot, publication buttons, scrollers === */
@media (max-width:700px){
  .section.who .team-card{ display:block !important; text-align:center; }
  .section.who .team-photo{ display:flex !important; justify-content:center !important; align-items:flex-start !important;
    margin:8px auto 12px !important; height:auto !important; min-height:0 !important; padding:0 !important; overflow:visible !important; }
  .section.who .team-photo img, img.about-avatar{
    width:min(360px,88vw) !important; aspect-ratio:3/4 !important; height:auto !important;
    object-fit:cover !important; object-position:50% 14% !important; border-radius:20px !important; display:block !important;
  }
}

/* Center publications buttons and keep long labels neat */
.page-template-service-page .wp-block-buttons,
.page-slug-writing .wp-block-buttons{
  justify-content:center !important; flex-wrap:wrap; gap:12px;
}
.page-template-service-page .wp-block-button .wp-block-button__link,
.page-slug-writing .wp-block-button .wp-block-button__link{
  border-radius:999px; padding:.7rem 1.15rem; line-height:1.2;
}
@media (max-width:480px){
  .page-template-service-page .wp-block-button .wp-block-button__link,
  .page-slug-writing .wp-block-button .wp-block-button__link{
    max-width:92vw; white-space:normal; text-align:center;
  }
}

/* Friendlier mobile crops for [gm_scroll] image rows */
@media (max-width:700px){
  .gm-scroll .gm-item{ aspect-ratio:3/4 !important; }
  .gm-scroll .gm-item img{ object-fit:cover; object-position:50% 18%; }
}

/* Video carousel soft edges on mobile */
.gmvc .gmvc-slide{ box-shadow: 0 6px 24px rgba(16,24,40,.08); }


