/* Taysa Group — Cloudflare Pages static site */
:root {
  --navy: #1C3255;
  --navy-900: #102541;
  --navy-950: #07172b;
  --cyan: #20A3C1;
  --cyan-soft: #dff5f9;
  --orange: #E35731;
  --slate: #596D7D;
  --slate-2: #7e8b9a;
  --paper: #f4f1ea;
  --white: #ffffff;
  --ink: #101820;
  --border: rgba(28, 50, 85, 0.16);
  --shadow: rgba(7, 23, 43, 0.16) 0 24px 80px -36px;
  --font-sans: 'Source Sans 3', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-serif: 'Newsreader', Georgia, serif;
  --container: min(1160px, calc(100vw - 48px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--white);
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--cyan-soft); color: var(--navy-950); }

.skip-link { position: absolute; left: 16px; top: -80px; background: var(--white); color: var(--navy); padding: 10px 14px; z-index: 100; }
.skip-link:focus { top: 16px; }

.container { width: var(--container); margin: 0 auto; }
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  height: 76px;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 max(24px, calc((100vw - 1160px) / 2));
  background: rgba(255,255,255,.88);
  border-bottom: 1px solid rgba(28,50,85,.10);
  backdrop-filter: blur(18px) saturate(160%);
  transition: background .2s ease, box-shadow .2s ease;
}
.site-header.is-scrolled { box-shadow: rgba(7,23,43,.08) 0 14px 42px; }
.brand img { width: 190px; height: auto; }
.nav { display: flex; align-items: center; gap: 30px; font-size: 15px; font-weight: 500; color: var(--navy); }
.nav a { opacity: .86; }
.nav a:hover { opacity: 1; color: var(--cyan); }
.nav-cta { padding: 10px 16px; border: 1px solid var(--border); background: var(--white); }
.nav-toggle { display:none; border:0; background:transparent; width:44px; height:44px; }
.nav-toggle span { display:block; height:2px; width:24px; background:var(--navy); margin:7px auto; }

section { position: relative; }
.section-dark { background: var(--navy-950); color: var(--white); }
.section-light { background: var(--white); }
.section-paper { background: var(--paper); }
.hero { min-height: 100svh; overflow: hidden; display: grid; align-items: center; padding: 128px 0 90px; }
.hero-media, .hero-overlay { position:absolute; inset:0; }
.hero-media img { width:100%; height:100%; object-fit:cover; opacity:.62; filter:saturate(.85) contrast(1.05); }
.hero-overlay { background: linear-gradient(90deg, rgba(7,23,43,.96) 0%, rgba(7,23,43,.78) 42%, rgba(7,23,43,.34) 100%); }
.hero-grid { position:relative; display:grid; grid-template-columns: minmax(0, 720px) 310px; gap: 72px; align-items:end; }
.eyebrow { margin:0 0 18px; font-size:13px; letter-spacing:.17em; text-transform:uppercase; font-weight:700; color: var(--cyan); }
.eyebrow.dark { color: var(--navy); }
h1, h2, h3, p { margin-top:0; }
h1 { font-size: clamp(52px, 8vw, 104px); line-height:.92; letter-spacing:-.055em; font-weight:300; max-width:820px; margin-bottom:30px; }
h2 { font-size: clamp(38px, 5.2vw, 72px); line-height:.97; letter-spacing:-.046em; font-weight:300; color: var(--navy-950); margin-bottom:0; }
.section-dark h2, .section-dark h1 { color: var(--white); }
h3 { font-size: 25px; line-height:1.05; letter-spacing:-.02em; font-weight:500; color: var(--navy-950); }
p { font-size: 18px; line-height:1.58; color: var(--slate); }
.section-dark p { color: rgba(255,255,255,.76); }
.hero-lede { max-width:650px; font-size:22px; line-height:1.42; color:rgba(255,255,255,.80); }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:36px; }
.button { display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:13px 20px; border:1px solid transparent; font-size:16px; font-weight:600; transition: transform .2s ease, background .2s ease, border-color .2s ease; }
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--cyan); color: var(--navy-950); }
.button-primary:hover { background: #5bc4d8; }
.button-secondary { border-color:rgba(255,255,255,.34); color: var(--white); }
.button-secondary:hover { border-color: var(--cyan); color: var(--cyan); }
.hero-card { border-left: 1px solid rgba(255,255,255,.24); padding: 24px 0 6px 26px; }
.hero-card .rule { display:block; width:44px; height:4px; background:var(--orange); margin-bottom:24px; }
.kicker { color:var(--white)!important; font-weight:700; font-size:16px; margin-bottom:8px; }
.hero-card p:last-child { font-family: var(--font-serif); font-size:22px; line-height:1.34; color:rgba(255,255,255,.84); }

.intro { padding: 120px 0; }
.intro-grid { display:grid; grid-template-columns: .95fr 1fr; gap:80px; align-items:start; }
.intro-copy p { font-size:23px; line-height:1.42; color: var(--navy); }
.intro-copy p + p { color: var(--slate); }

.approach { padding: 120px 0 130px; }
.section-heading { max-width: 760px; margin-bottom: 58px; }
.approach-grid { display:grid; grid-template-columns: 1.25fr 1fr 1fr; gap:1px; background:var(--border); border:1px solid var(--border); }
.approach-card { background: var(--white); padding: 38px 34px; min-height: 290px; }
.approach-card.featured { background: var(--navy); }
.approach-card span { font-family: ui-monospace, monospace; color: var(--cyan); font-size:14px; font-weight:700; }
.approach-card h3 { margin: 56px 0 14px; }
.approach-card.featured h3, .approach-card.featured p { color: var(--white); }
.approach-card p { font-size:17px; }

.work { padding: 130px 0; }
.work-grid { display:grid; grid-template-columns: .95fr 1fr; gap:80px; align-items:center; }
.image-panel { position:relative; min-height:560px; background:var(--navy); box-shadow:var(--shadow); }
.image-panel:before { content:""; position:absolute; inset:24px -24px -24px 24px; border:1px solid var(--cyan); z-index:0; }
.image-panel img { position:relative; z-index:1; width:100%; height:560px; object-fit:cover; }
.work-copy h2 { margin-bottom: 36px; }
.service-list { display:grid; gap: 24px; }
.service-list div { border-top:1px solid var(--border); padding-top:22px; }
.service-list h3 { font-size:22px; margin-bottom:8px; }
.service-list p { font-size:17px; margin-bottom:0; }

.proof.compact { padding: 74px 0; }
.proof-grid { display:grid; grid-template-columns: .9fr 1.4fr; gap:70px; align-items:start; }
.proof-line { font-family:var(--font-serif); font-size:33px!important; line-height:1.15!important; color:var(--white)!important; }
.proof-points { display:grid; grid-template-columns: repeat(3, 1fr); gap:1px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.16); }
.proof-points div { background:rgba(255,255,255,.045); padding:25px; }
.proof-points strong { display:block; font-size:29px; color:var(--cyan); font-weight:500; letter-spacing:-.03em; }
.proof-points span { display:block; margin-top:8px; color:rgba(255,255,255,.72); line-height:1.35; }

.advisor { padding: 130px 0; }
.advisor-grid { display:grid; grid-template-columns: 1fr .8fr; gap:88px; align-items:center; }
.advisor-copy h2 { margin-bottom:28px; }
.advisor-copy p { font-size:20px; line-height:1.5; }
.advisor-media img { height:640px; width:100%; object-fit:cover; box-shadow:var(--shadow); }

.quote { padding: 115px 0; }
.quote-box { max-width: 920px; }
blockquote { margin:0; font-family:var(--font-serif); font-size: clamp(34px, 5vw, 68px); line-height:1.04; letter-spacing:-.04em; color:var(--navy-950); }

.contact { padding: 120px 0; }
.contact-grid { display:grid; grid-template-columns: .9fr 1fr; gap:86px; align-items:start; }
.contact h2 { margin-bottom:24px; }
.contact-lede { font-size:20px; }
.contact-form { display:grid; grid-template-columns:1fr 1fr; gap:18px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); padding:28px; }
.contact-form label { display:grid; gap:8px; color:rgba(255,255,255,.78); font-size:14px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.contact-form .full { grid-column:1 / -1; }
input, textarea { width:100%; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.92); color:var(--navy-950); padding:14px; font: inherit; border-radius:0; }
textarea { resize:vertical; }
.contact-form button { grid-column:1 / span 1; border:0; cursor:pointer; }
.form-note { grid-column:1 / -1; font-size:14px!important; margin:0; }
.footer { padding:38px 0; border-top:1px solid var(--border); background:var(--white); }
.footer-grid { display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center; }
.footer p { margin:0; font-size:15px; }
.footer a { color:var(--navy); font-weight:700; }

@media (max-width: 920px) {
  .site-header { height:68px; padding: 0 20px; }
  .brand img { width:160px; }
  .nav-toggle { display:block; }
  .nav { position:absolute; inset:68px 0 auto 0; padding:22px 24px 28px; background:rgba(255,255,255,.97); border-bottom:1px solid var(--border); display:none; flex-direction:column; align-items:flex-start; gap:18px; }
  .nav.is-open { display:flex; }
  .hero-grid, .intro-grid, .work-grid, .proof-grid, .advisor-grid, .contact-grid { grid-template-columns:1fr; gap:42px; }
  .hero { min-height: auto; padding-top: 120px; }
  .hero-card { max-width: 480px; }
  .intro, .approach, .work, .advisor, .quote, .contact { padding:82px 0; }
  .approach-grid { grid-template-columns:1fr; }
  .proof-points { grid-template-columns:1fr; }
  .image-panel, .image-panel img, .advisor-media img { min-height:0; height:auto; }
  .image-panel:before { display:none; }
  .footer-grid { grid-template-columns:1fr; }
}

@media (max-width: 560px) {
  :root { --container: min(100vw - 32px, 1160px); }
  h1 { font-size: 49px; }
  .hero-lede, .intro-copy p { font-size:19px; }
  .hero-actions, .contact-form { display:grid; grid-template-columns:1fr; }
  .contact-form button { grid-column:1; }
  .approach-card { padding:30px 24px; }
  .hero-overlay { background: linear-gradient(90deg, rgba(7,23,43,.96), rgba(7,23,43,.72)); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior:auto!important; transition:none!important; }
}
