/* OnceMore Digital - shared styles
   Design tokens: blue #4d65af, background #222222 (midnight ash), Satoshi. */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --blue:#4d65af;
  --blue-dark:#3a4e8f;
  --blue-light:#7a90c7;
  --dark:#222222;
  --dark-2:#2c2c2c;
  --off-white:#f4f4f2;
  --muted:#888;
  --border:rgba(77,101,175,0.2);
  --maxw:1100px;
}

html{height:100%;scroll-behavior:smooth;font-size:112.5%}

body{
  min-height:100vh;
  background:var(--dark);
  color:var(--off-white);
  font-family:'Satoshi','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
  position:relative;
  -webkit-font-smoothing:antialiased;
}

body::before{
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(77,101,175,0.12) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 90%,rgba(77,101,175,0.06) 0%,transparent 50%);
  pointer-events:none;
  z-index:0;
}

.wrap{position:relative;z-index:1}
.container{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}

a{color:var(--blue-light);text-decoration:none}
a:hover{color:var(--off-white)}

@keyframes rise{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(34,34,34,0.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:-.01em;color:var(--off-white)}
.brand-logo{height:62px;width:auto;display:block}
.footer-logo{height:46px}
.brand span{font-size:1.05rem}
.nav-links{display:flex;align-items:center;gap:1.75rem;list-style:none}
.nav-links a{
  font-size:14px;font-weight:400;letter-spacing:.02em;color:var(--off-white);
  padding:6px 0;border-bottom:1px solid transparent;transition:border-color .2s,color .2s;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{border-color:var(--blue);color:var(--blue-light)}
.nav-cta{
  background:var(--blue);color:#fff !important;font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;padding:9px 16px;border-radius:2px;
  border:none !important;transition:background .2s;
}
.nav-cta:hover{background:var(--blue-dark);color:#fff !important}
.nav-toggle{display:none;background:none;border:1px solid var(--border);color:var(--off-white);
  width:42px;height:42px;border-radius:2px;cursor:pointer;font-size:18px}

/* services dropdown */
.nav-item.has-dropdown{position:relative}
.has-dropdown > a{display:inline-flex;align-items:center}
.has-dropdown > a::after{content:'';width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:7px;margin-top:-3px;transition:transform .2s}
.has-dropdown:hover > a::after,.has-dropdown:focus-within > a::after{transform:rotate(225deg);margin-top:2px}
.dropdown{
  position:absolute;top:100%;left:0;margin-top:10px;min-width:215px;list-style:none;
  background:var(--dark-2);border:1px solid var(--border);border-radius:5px;padding:.5rem;
  box-shadow:0 16px 40px rgba(0,0,0,0.45);display:none;z-index:60;
}
.dropdown::before{content:'';position:absolute;top:-12px;left:0;right:0;height:12px}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{display:block}
.dropdown li{width:100%}
.dropdown a{display:block;padding:.6rem .8rem;border-radius:4px;border-bottom:none;font-size:14px;color:var(--off-white)}
.dropdown a:hover{background:rgba(77,101,175,.16);color:var(--blue-light);border-color:transparent}

/* ---------- generic section ---------- */
.section{padding:5rem 0}
.section-sm{padding:3.5rem 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--blue-light);margin-bottom:1.1rem;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--blue-light);opacity:.5}
h1,h2,h3{font-weight:700;line-height:1.15;letter-spacing:-.02em;color:var(--off-white)}
h1{font-size:clamp(2.1rem,6vw,3.6rem);margin-bottom:1.1rem}
h1 em,h2 em{color:var(--blue-light);font-weight:400;font-style:italic}
h2{font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:1rem}
h3{font-size:1.2rem;margin-bottom:.5rem}
p{color:var(--muted);font-weight:400}
.lead{font-size:clamp(1rem,2.2vw,1.15rem);max-width:60ch;color:#aaa}
.section > .container > p{max-width:65ch}

/* ---------- hero ---------- */
.hero{padding:4.5rem 0 4.5rem;text-align:left;animation:rise .9s cubic-bezier(.22,1,.36,1) both}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.hero-copy .lead{margin:0 0 1.75rem}
.hero-copy .services-tags{justify-content:flex-start;margin-bottom:1.75rem}
.hero-copy .btn-row{justify-content:flex-start;margin-top:0}
.hero-media .hero-illustration{margin:0;max-width:100%}
.hero .lead{margin:0 auto 2rem}
@media(max-width:860px){
  .hero{text-align:center}
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-copy .lead{margin:0 auto 1.75rem}
  .hero-copy .services-tags{justify-content:center}
  .hero-copy .btn-row{justify-content:center}
  .hero-media{order:2}
  .hero-media .hero-illustration{margin:0 auto;max-width:460px}
}
.divider{width:36px;height:2px;background:var(--blue);margin:0 auto 2.25rem}
.divider.left{margin:1.25rem 0 2rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:0 2.5rem;height:52px;border-radius:2px;cursor:pointer;transition:.2s;
  border:1px solid var(--blue);
}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--blue-light)}
.btn-ghost:hover{background:rgba(77,101,175,.1);color:var(--off-white)}
.btn-row{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}

/* ---------- service tags ---------- */
.services-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:2.25rem}
.service-tag{
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue-light);border:1px solid var(--border);padding:5px 12px;border-radius:2px;
  background:rgba(77,101,175,.06);
}

/* ---------- cards grid ---------- */
.grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{
  border:1px solid var(--border);border-radius:3px;padding:1.75rem;
  background:rgba(77,101,175,.04);transition:border-color .2s,transform .2s;display:block;
}
.card:hover{border-color:rgba(77,101,175,.5);transform:translateY(-3px)}
.card .num{font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--blue);display:block;margin-bottom:.75rem}
.card h3{color:var(--off-white)}
.card p{font-size:.95rem;margin-top:.4rem}
.card .more{display:inline-block;margin-top:1rem;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-light)}

/* ---------- feature list ---------- */
.feature-list{list-style:none;display:grid;gap:.9rem;margin:1.5rem 0;max-width:60ch}
.feature-list li{position:relative;padding-left:1.6rem;color:#aaa;font-weight:400}
.feature-list li::before{content:'';position:absolute;left:0;top:.65em;width:8px;height:8px;border:1px solid var(--blue);background:rgba(77,101,175,.3)}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
@media(max-width:760px){.split{grid-template-columns:1fr;gap:2rem}}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--border);padding:1.1rem 0}
.faq summary{cursor:pointer;font-weight:400;color:var(--off-white);font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--blue-light);font-weight:400}
.faq details[open] summary::after{content:'\2212'}
.faq p{margin-top:.75rem;font-size:.98rem}

/* ---------- cta band ---------- */
.cta-band{text-align:center;border:1px solid var(--border);border-radius:4px;
  padding:3rem 1.5rem;background:rgba(77,101,175,.05);margin:0 auto;max-width:var(--maxw)}
.cta-band h2{margin-bottom:.75rem}
.cta-band p{margin:0 auto 1.5rem;max-width:48ch}

/* ---------- breadcrumb ---------- */
  .crumbs{font-size:13px;color:var(--muted);padding-top:1.75rem}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--blue-light)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:1rem}
.field label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-light);margin-bottom:.4rem}
.field input,.field textarea{
  width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--off-white);font-family:inherit;font-size:14px;font-weight:400;
  padding:.8rem 1rem;border-radius:2px;outline:none;transition:border-color .2s;
}
.field input:focus,.field textarea:focus{border-color:rgba(77,101,175,.5)}
.field textarea{min-height:130px;resize:vertical}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--border);margin-top:4rem;padding:3rem 0 2.5rem;position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
@media(max-width:680px){.footer-grid{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}
.footer-grid h4{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--blue-light);margin-bottom:1rem;font-weight:700}
.footer-grid ul{list-style:none;display:grid;gap:.6rem}
  .footer-grid a{font-size:.98rem;color:var(--muted)}
.footer-grid a:hover{color:var(--blue-light)}
.footer-brand p{font-size:.92rem;max-width:34ch;margin-top:.75rem}
.footer-address{font-style:normal;font-size:.9rem;color:var(--muted);line-height:1.6;margin-top:1rem;max-width:34ch}
.footer-ssm{font-size:.82rem;color:var(--muted);margin-top:.6rem;opacity:.85}
.office-address{font-style:normal;color:#aaa;line-height:1.7;margin-top:.35rem}
  .footer-bottom{font-size:13px;color:var(--muted);text-align:center;padding-top:1.75rem;border-top:1px solid var(--border)}

/* ---------- mobile nav ---------- */
@media(max-width:760px){
  .brand-logo{height:46px}
  .footer-logo{height:40px}
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:88px;left:0;right:0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--dark-2);border-bottom:1px solid var(--border);padding:.5rem 1.5rem 1.25rem;
    display:none;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;width:100%;padding:.85rem 0;border-bottom:1px solid var(--border)}
  .nav-links .nav-cta{margin-top:.75rem;width:100%;text-align:center}
  .has-dropdown > a::after{display:none}
  .dropdown{position:static;display:block;margin:0 0 .25rem;padding:0 0 0 1rem;border:none;
    background:transparent;box-shadow:none;min-width:0}
  .dropdown::before{display:none}
  .dropdown a{padding:.7rem 0;font-size:13px;color:var(--blue-light)}
}


/* ---------- icons & illustration ---------- */
.card .icon{display:block;width:36px;height:36px;color:var(--blue-light);margin-bottom:1.1rem}
.card .icon svg{width:100%;height:100%}
.card:hover .icon{color:var(--off-white)}
.svc-icon{width:60px;height:60px;color:var(--blue-light);margin-bottom:1.25rem}
.svc-icon svg{width:100%;height:100%}
.hero-illustration{display:block;width:100%;max-width:560px;height:auto;margin:3rem auto 0;filter:drop-shadow(0 18px 40px rgba(0,0,0,0.45))}

/* ---------- client logos marquee ---------- */
.clients-head{text-align:center;margin-bottom:.5rem}
.logos{position:relative;overflow-x:auto;overflow-y:hidden;margin-top:1.75rem;cursor:grab;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logos::-webkit-scrollbar{display:none}
.logos.dragging{cursor:grabbing}
.logos.dragging .logo-chip{pointer-events:none}
.logos-track{display:flex;align-items:center;gap:1.1rem;width:max-content}
.logo-chip{flex:0 0 auto;width:172px;height:90px;background:#fff;border-radius:9px;
  display:flex;align-items:center;justify-content:center;padding:16px 22px;
  box-shadow:0 8px 22px rgba(0,0,0,0.25);opacity:.5;transition:opacity .25s;
  user-select:none;-webkit-user-select:none}
.logo-chip:hover{opacity:1}
.logo-chip img{max-width:100%;max-height:100%;object-fit:contain;display:block;
  pointer-events:none;-webkit-user-drag:none}
@media(max-width:600px){.logo-chip{width:142px;height:78px;padding:12px 16px}}

/* ---------- long-form prose + link lists ---------- */
.prose{max-width:70ch}
.prose p{color:#b8b8b8;margin-bottom:1rem;font-weight:400}
.prose h2{font-size:1.4rem;margin:2rem 0 .7rem;scroll-margin-top:104px}
.prose a{color:var(--blue-light);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--off-white)}
.link-list{list-style:none;display:grid;gap:.75rem;max-width:62ch;margin-top:1rem}
.link-list li{border-bottom:1px solid var(--border);padding-bottom:.75rem}
.link-list a{color:var(--blue-light);font-size:1.05rem}
.link-list a:hover{color:var(--off-white)}

/* ---------- AEO guide components ---------- */
.updated{font-size:.82rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin:.25rem 0 1.25rem}
.answer-box{border:1px solid var(--border);border-left:3px solid var(--blue);border-radius:6px;
  background:rgba(77,101,175,.07);padding:1.25rem 1.5rem;max-width:72ch;margin-bottom:1.75rem}
.answer-label{display:block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-light);margin-bottom:.4rem}
.answer-box p{color:#d2d2d0;margin:0;font-size:1.05rem;line-height:1.7}
.toc{border:1px solid var(--border);border-radius:6px;padding:1.1rem 1.4rem;max-width:46ch;margin-bottom:2rem;background:rgba(255,255,255,.02)}
.toc-title{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-light);margin-bottom:.6rem}
.toc ul{list-style:none;display:grid;gap:.45rem}
.toc a{color:#b8b8b8;font-size:.95rem}
.toc a:hover{color:var(--blue-light)}
.guide-figure{margin:2rem 0 .5rem;text-align:center}
.guide-illustration{display:block;width:100%;max-width:560px;height:auto;margin:0 auto}
.tldr{border:1px solid var(--border);border-radius:6px;padding:1.4rem 1.6rem;max-width:72ch;margin:2.25rem 0 0;background:rgba(77,101,175,.05)}
.tldr h2{font-size:1.1rem;margin-bottom:.75rem}
.tldr ul{margin:0;padding-left:1.1rem;display:grid;gap:.45rem}
.tldr li{color:#c4c4c4}
.author-bio{display:flex;gap:1rem;align-items:flex-start;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);max-width:72ch}
.author-bio p{color:#a9a9a9;font-size:.95rem;margin:0}
.author-bio strong{color:var(--off-white);font-weight:700}
.author-dot{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--blue);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--blue-light);letter-spacing:.04em}

/* feature-list gets a check icon instead of a plain square */
.feature-list li::before{content:'';position:absolute;left:0;top:.35em;width:15px;height:15px;background:none;border:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237a90c7' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat}

/* accessibility */
:focus-visible{outline:2px solid var(--blue-light);outline-offset:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}
