
:root{
  --green:#123f3b;
  --green-dark:#082421;
  --green-soft:#194f49;
  --cream:#f6f0e7;
  --white:#ffffff;
  --gold:#c8a45d;
  --charcoal:#111716;
  --muted:#b9c7c1;
  --line:rgba(255,255,255,.14);
  --shadow:0 25px 80px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--green-dark);
  color:var(--white);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;
  background:rgba(8,36,33,.72);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand img{height:54px;width:auto;display:block}
.nav{display:flex;gap:18px;align-items:center;font-size:14px}
.nav a{opacity:.86;transition:.25s}
.nav a:hover,.nav a.active{opacity:1;color:var(--gold)}
.nav-cta{
  border:1px solid var(--gold);
  border-radius:999px;
  padding:11px 16px;
  color:var(--gold)!important;
}
.menu-toggle{display:none;background:transparent;color:white;border:1px solid var(--line);border-radius:999px;padding:9px 13px}
.section-dark{background:radial-gradient(circle at top left, #1a544e 0%, var(--green-dark) 45%, #061b19 100%);color:white}
.section-light{background:var(--cream);color:var(--charcoal)}
.hero,.page-hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1.2fr .65fr;
  align-items:center;
  gap:5vw;
  padding:145px 5vw 80px;
  position:relative;
  overflow:hidden;
}
.page-hero{min-height:72vh;grid-template-columns:1fr;padding-bottom:70px}
.hero-content{max-width:920px;position:relative;z-index:2}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--gold);
  font-weight:800;
  font-size:12px;
  margin:0 0 18px;
}
h1,h2,h3{margin:0;letter-spacing:-.055em;line-height:.93}
h1{font-size:clamp(46px,9vw,126px)}
h2{font-size:clamp(36px,6vw,78px)}
h3{font-size:28px}
.hero-lead,.section-heading p,.split p,.hero-panel p,.service-card p,.sector p,.offer p,.footer p{
  font-size:clamp(17px,1.45vw,22px);
  line-height:1.55;
  opacity:.88;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.button{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:54px;padding:0 24px;border-radius:999px;
  font-weight:900;transition:.25s;border:1px solid transparent;
}
.primary{background:var(--gold);color:#102522}
.secondary{border-color:rgba(255,255,255,.26);color:white}
.section-light .secondary{border-color:rgba(0,0,0,.15);color:var(--charcoal)}
.button:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.hero-panel{
  position:relative;z-index:2;
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow);
}
.hero-panel strong{font-size:72px;color:var(--gold)}
.status-dot{width:13px;height:13px;background:#62ffbd;border-radius:50%;box-shadow:0 0 30px #62ffbd;margin-bottom:20px}
.panel-kicker{text-transform:uppercase;letter-spacing:.16em;color:var(--muted);font-size:12px!important}
.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:22px}
.mini-grid span{border:1px solid var(--line);padding:12px;border-radius:16px;text-align:center;color:var(--muted)}
.luxury-orb{position:absolute;border-radius:50%;filter:blur(15px);opacity:.6;animation:float 7s ease-in-out infinite}
.orb-one{width:380px;height:380px;background:rgba(200,164,93,.12);right:8%;top:18%}
.orb-two{width:260px;height:260px;background:rgba(255,255,255,.08);left:-60px;bottom:10%}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}
.scroll-cue{position:absolute;bottom:32px;left:5vw;color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.ticker{overflow:hidden;background:var(--gold);color:#102522;padding:14px 0;font-weight:1000;text-transform:uppercase;letter-spacing:.16em}
.ticker-track{display:flex;gap:36px;white-space:nowrap;animation:ticker 28s linear infinite}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;padding:1px;background:#d6cab8}
.stat-card{background:var(--cream);padding:44px 5vw;text-align:center}
.stat-card strong{font-size:54px;color:var(--green)}
.stat-card p{margin:8px 0 0;color:#45524e;font-weight:800}
.section{padding:110px 5vw}
.section-heading{max-width:900px;margin-bottom:45px}
.service-grid,.sector-grid,.offer-grid,.area-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.service-card,.sector,.offer{
  min-height:270px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  border-radius:30px;
  padding:30px;
  transition:.3s;
  position:relative;
  overflow:hidden;
}
.service-card:before,.sector:before,.offer:before{
  content:"";position:absolute;inset:auto -30% -60% -30%;height:70%;
  background:radial-gradient(circle,rgba(200,164,93,.25),transparent 64%);
  transition:.3s;
}
.service-card:hover,.sector:hover,.offer:hover{transform:translateY(-8px);border-color:rgba(200,164,93,.55);box-shadow:var(--shadow)}
.service-card span{color:var(--gold);font-weight:1000}
.accent{background:linear-gradient(145deg,var(--gold),#ead293);color:#102522}
.accent p,.accent span{color:#102522}
.split{display:grid;grid-template-columns:.85fr 1fr;gap:6vw;padding:110px 5vw}
.check-list{list-style:none;padding:0;margin:25px 0 0;display:grid;gap:13px}
.check-list li{padding-left:32px;position:relative;font-size:18px;line-height:1.4}
.check-list li:before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:1000}
.check-list.light li{color:white}
.area-band{background:linear-gradient(135deg,var(--green),var(--green-dark));color:white}
.area-grid a{
  border:1px solid var(--line);border-radius:22px;
  padding:28px;font-size:22px;font-weight:1000;
  background:rgba(255,255,255,.05);
  transition:.25s;
}
.area-grid a:hover{background:var(--gold);color:#102522;transform:translateY(-4px)}
.offers .offer{background:white;border-color:#e4d8c7;color:var(--charcoal)}
.mascot-card .shark{font-size:70px;position:absolute;right:24px;bottom:18px;animation:bob 2.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:rotate(-6deg) translateY(0)}50%{transform:rotate(6deg) translateY(-10px)}}
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.feature{display:flex;gap:14px;align-items:center;background:white;border:1px solid #e5d8c6;padding:20px;border-radius:18px;font-weight:800}
.feature span{color:var(--green);font-weight:1000}
.contact-section{display:grid;grid-template-columns:1.2fr .8fr;gap:28px}
.contact-form,.contact-card{background:white;border-radius:30px;padding:30px;border:1px solid #e5d8c6;box-shadow:0 16px 50px rgba(0,0,0,.08)}
.contact-form{display:grid;gap:16px}
label{font-weight:900;display:grid;gap:8px}
input,select,textarea{width:100%;padding:15px 16px;border-radius:14px;border:1px solid #d8ccbc;font:inherit}
textarea{resize:vertical}
.honeypot{display:none}
.form-note{font-size:14px;color:#5b6965}
.footer{background:#061b19;color:white;padding:70px 5vw 30px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px}
.footer-logo{height:66px;margin-bottom:18px}
.footer a{display:block;margin:10px 0;color:var(--muted)}
.footer-button{color:var(--gold)!important;font-weight:900}
.small{font-size:14px!important;color:var(--muted)}
.legal{border-top:1px solid var(--line);margin-top:35px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;color:var(--muted);font-size:13px}
.floating-call{
  position:fixed;z-index:1200;right:20px;bottom:20px;
  background:var(--gold);color:#102522;
  padding:14px 19px;border-radius:999px;
  font-weight:1000;box-shadow:0 15px 50px rgba(0,0,0,.28)
}
.cursor-glow{
  position:fixed;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,164,93,.13),transparent 65%);
  pointer-events:none;z-index:1;transform:translate(-50%,-50%);
}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}
@media(max-width:980px){
  .menu-toggle{display:block}
  .nav{position:absolute;top:78px;left:5vw;right:5vw;display:none;flex-direction:column;background:#061b19;border:1px solid var(--line);border-radius:22px;padding:20px;align-items:flex-start}
  .nav.open{display:flex}
  .hero{grid-template-columns:1fr;min-height:auto}
  h1{font-size:54px}
  .stats,.service-grid,.sector-grid,.offer-grid,.area-grid,.feature-list,.footer-grid,.contact-section,.split{grid-template-columns:1fr}
  .legal{flex-direction:column}
  .cursor-glow{display:none}
}
@media(max-width:560px){
  .site-header{padding:14px 18px}
  .brand img{height:34px}
  .hero,.page-hero{padding:115px 22px 64px}
  .section,.split{padding:70px 22px}
  h1{font-size:43px}
  h2{font-size:38px}
  .floating-call{left:14px;right:14px;text-align:center;display:flex;justify-content:center}
}


.brand img{height:54px}
.footer-logo{height:66px}
.trust-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.trust-pills span{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);font-weight:800;font-size:14px}
.micro-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.micro-links a,.micro-links span{
  padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);font-weight:800;font-size:14px
}
.micro-links.dark a,.micro-links.dark span{background:#f3ece1;border-color:#e5d8c6;color:#173f3b}
.micro-links.big a{font-size:15px;padding:12px 16px}
.keyword-cloud{display:flex;flex-wrap:wrap;gap:12px}
.keyword-cloud span{
  padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.06);
  border:1px solid var(--line);font-weight:800
}
.finn-banner{
  margin-top:28px;padding:26px;border-radius:28px;background:linear-gradient(145deg,#0d2d2a,#1d5550);color:white;
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;border:1px solid rgba(255,255,255,.1)
}
.finn-runner{font-size:64px;animation:dash 6s linear infinite}
@keyframes dash{0%{transform:translateX(0)}50%{transform:translateX(18px)}100%{transform:translateX(0)}}
.coverage-box{margin-top:18px}
.badge-line{
  margin-top:14px;display:inline-block;padding:10px 14px;border-radius:999px;
  background:#f3ece1;border:1px solid #e5d8c6;color:#173f3b;font-weight:800
}
.social-block{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.social-block span,.social-block a{
  padding:9px 12px;border-radius:999px;border:1px solid var(--line);color:var(--muted);font-size:13px
}
.area-lines{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.area-lines span{padding:6px 10px;border-radius:999px;border:1px solid var(--line)}
.mascot-hero .finn-stage{
  min-height:300px;border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.05);
  display:grid;place-items:center;position:relative;overflow:hidden
}
.finn-character{font-size:120px;animation:swim 4s ease-in-out infinite}
.finn-bubbles span{
  position:absolute;bottom:20px;width:14px;height:14px;background:rgba(255,255,255,.18);border-radius:50%;animation:rise 3.5s infinite
}
.finn-bubbles span:nth-child(1){left:30%;animation-delay:0s}
.finn-bubbles span:nth-child(2){left:50%;animation-delay:1s}
.finn-bubbles span:nth-child(3){left:70%;animation-delay:2s}
@keyframes swim{0%,100%{transform:translateX(-20px) rotate(-4deg)}50%{transform:translateX(20px) rotate(4deg)}}
@keyframes rise{0%{transform:translateY(0);opacity:0}20%{opacity:1}100%{transform:translateY(-180px);opacity:0}}

.explore-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.explore-card{
  background:#fff;border:1px solid #e4d8c7;border-radius:28px;padding:28px;min-height:230px;
  transition:.28s;display:block;color:var(--charcoal)
}
.explore-card span{
  display:inline-flex;padding:8px 12px;border-radius:999px;background:#f3ece1;color:#173f3b;
  font-size:12px;font-weight:1000;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px
}
.explore-card:hover{transform:translateY(-7px);box-shadow:0 22px 60px rgba(0,0,0,.12);border-color:#c8a45d}
.deep-footer{grid-template-columns:1.6fr 1fr 1fr 1fr 1.1fr}
@media(max-width:980px){.explore-grid,.deep-footer{grid-template-columns:1fr}}


/* V4 refinements */
.brand{display:flex;align-items:center}
.brand img{height:42px;width:auto;display:block;background:transparent}
.site-header{padding:14px 5vw;background:linear-gradient(180deg,rgba(8,36,33,.92),rgba(8,36,33,.72));backdrop-filter:blur(18px)}
.hero-rich{grid-template-columns:1fr 1fr;min-height:95vh}
.hero-media{position:relative;z-index:2;min-height:560px;border:1px solid var(--line);border-radius:34px;overflow:hidden;box-shadow:var(--shadow)}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-media:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(8,36,33,.35) 70%,rgba(8,36,33,.75) 100%)}
.hero-media-card{position:absolute;left:24px;right:24px;bottom:24px;padding:22px 24px;border-radius:24px;border:1px solid rgba(255,255,255,.16);background:rgba(7,27,24,.66);backdrop-filter:blur(14px);box-shadow:0 14px 40px rgba(0,0,0,.3)}
.hero-media-card strong{font-size:54px;color:var(--gold);display:block;margin-bottom:8px}
.scroll-cue{display:none}
.trust-pills span{font-weight:900}
.review-strip{padding-top:64px;padding-bottom:64px}
.narrow-center{text-align:center;margin-left:auto;margin-right:auto}
.review-links,.social-links{display:flex;flex-wrap:wrap;gap:12px}
.review-links{justify-content:center}
.review-links a,.social-links a{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:999px;font-weight:900;border:1px solid rgba(17,23,22,.12);background:white;color:var(--charcoal);box-shadow:0 10px 30px rgba(0,0,0,.06)}
.footer .social-links a{background:rgba(255,255,255,.05);border-color:var(--line);color:var(--muted);margin:0}
.clean-footer h3{font-size:20px;margin-bottom:14px}
.clean-footer .footer a{margin:0}
.trust-mini{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.trust-mini span{padding:9px 12px;border-radius:999px;border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:900}
.area-lines.compact span{font-size:12px;padding:7px 10px}
.image-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:center}
.image-story-copy .check-list li{color:var(--charcoal)}
.image-stack{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:end}
.image-stack .stack-one,.image-stack .stack-two,.showcase-card{border-radius:30px;overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.14)}
.image-stack img,.showcase-card img,.finn-portrait-card img,.finn-gallery-main img{width:100%;height:100%;object-fit:cover;display:block}
.image-stack .stack-one{height:500px}
.image-stack .stack-two{height:340px;transform:translateY(46px)}
.showcase-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px}
.showcase-card{position:relative;min-height:320px;border:1px solid var(--line);background:rgba(255,255,255,.05)}
.showcase-card.large{grid-row:span 1;min-height:420px}
.showcase-card div{position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border-radius:18px;background:rgba(7,27,24,.72);border:1px solid rgba(255,255,255,.12)}
.offers-plus .offer{min-height:220px}
.explore-card p,.showcase-card p{font-size:16px;line-height:1.5}
.deep-footer{grid-template-columns:1.35fr .9fr .9fr .9fr 1.15fr}
.finn-page .cursor-glow{display:none}
.finn-cursor{position:fixed;left:0;top:0;transform:translate(-50%,-50%);width:42px;height:42px;display:grid;place-items:center;font-size:28px;pointer-events:none;z-index:1400;filter:drop-shadow(0 8px 16px rgba(0,0,0,.25));opacity:0;transition:opacity .2s}
.finn-page .finn-cursor{opacity:1}
.finn-hero-rich{grid-template-columns:1fr 1fr}
.finn-hero-media{min-height:600px}
.finn-story .finn-portrait-card{border-radius:32px;overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.12);min-height:560px}
.finn-gallery{display:grid;grid-template-columns:1fr;gap:20px;max-width:1040px;margin:0 auto}
.finn-gallery-main{height:620px;border-radius:30px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.finn-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.finn-thumb{padding:0;border:2px solid transparent;border-radius:20px;overflow:hidden;background:none;cursor:pointer;min-height:150px}
.finn-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.finn-thumb.active{border-color:var(--gold);box-shadow:0 12px 30px rgba(200,164,93,.25)}
.find-finn-board{max-width:1080px;margin:0 auto;position:relative;border-radius:34px;overflow:hidden;border:1px solid var(--line);min-height:620px;box-shadow:var(--shadow)}
.find-finn-board img{width:100%;height:620px;object-fit:cover;display:block;filter:saturate(1.02)}
.hidden-fin{position:absolute;width:36px;height:36px;border:none;background:rgba(255,255,255,.26);border-radius:999px;cursor:pointer;box-shadow:0 0 0 1px rgba(255,255,255,.18) inset, 0 8px 18px rgba(0,0,0,.25)}
.hidden-fin:before{content:"🦈";font-size:18px}
.hidden-fin.found{background:var(--gold);transform:scale(1.06)}
.fin-one{top:22%;left:17%}
.fin-two{top:56%;left:67%}
.fin-three{top:74%;left:42%}
.find-counter{position:absolute;left:20px;top:20px;padding:12px 16px;border-radius:999px;background:rgba(7,27,24,.74);border:1px solid rgba(255,255,255,.14);font-weight:900}
.offer-unlock{position:absolute;right:20px;bottom:20px;max-width:360px;padding:22px;border-radius:24px;background:rgba(7,27,24,.86);border:1px solid rgba(255,255,255,.14);transform:translateY(24px);opacity:0;transition:.35s}
.offer-unlock.show{transform:translateY(0);opacity:1}
.find-finn-section .section-heading{margin-bottom:24px}
.finn-story,.finn-offers-section,.tips-section{position:relative}
@media(max-width:980px){
  .hero-rich,.finn-hero-rich,.image-story-grid,.showcase-grid{grid-template-columns:1fr}
  .hero-media,.finn-hero-media,.find-finn-board,.finn-story .finn-portrait-card{min-height:auto}
  .hero-media img,.finn-hero-media img,.find-finn-board img,.finn-gallery-main{height:auto}
  .finn-gallery-main{height:420px}
  .finn-thumbs{grid-template-columns:1fr 1fr}
  .image-stack{grid-template-columns:1fr}
  .image-stack .stack-one,.image-stack .stack-two{height:auto;transform:none}
  .deep-footer{grid-template-columns:1fr}
}
@media(max-width:560px){
  .brand img{height:34px}
  .hero-media-card strong{font-size:40px}
  .hero-media{min-height:420px}
  .review-links a,.social-links a{width:100%;justify-content:center}
  .finn-gallery-main{height:280px}
  .hidden-fin{width:32px;height:32px}
  .offer-unlock{left:16px;right:16px;max-width:none}
}


/* V5 real imagery upgrade */
.human-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr .85fr;
  gap:18px;
}
.human-card{
  position:relative;
  min-height:360px;
  overflow:hidden;
  border-radius:32px;
  background:#fff;
  border:1px solid #e4d8c7;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
}
.human-card.tall{min-height:560px}
.human-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.human-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(8,36,33,.78) 100%);
}
.human-card div{
  position:absolute;
  z-index:2;
  left:24px;
  right:24px;
  bottom:24px;
  color:white;
}
.human-card h3{font-size:34px}
.human-card p{font-size:17px;line-height:1.45}

.visual-split-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.visual-panel{
  position:relative;
  overflow:hidden;
  min-height:580px;
  border-radius:34px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.visual-panel img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.visual-panel:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 38%,rgba(7,27,24,.86) 100%);
}
.visual-caption{
  position:absolute;
  z-index:2;
  left:24px;
  right:24px;
  bottom:24px;
  padding:22px;
  border-radius:24px;
  background:rgba(7,27,24,.55);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(12px);
}
.visual-caption span{
  color:var(--gold);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:1000;
}
.visual-caption h3{margin-top:10px}
.visual-caption p{font-size:17px}

.warm-image{
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 22px 70px rgba(0,0,0,.14);
  min-height:520px;
}
.warm-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.service-photo-band .image-story-grid,
.commercial-proof .image-story-grid,
.careers-visual .showcase-grid{
  margin-top:10px;
}
.about-photo-story .visual-panel{min-height:520px}
.mini-crew-section .warm-image{min-height:480px}

@media(max-width:980px){
  .human-grid,.visual-split-grid{
    grid-template-columns:1fr;
  }
  .human-card,.human-card.tall,.visual-panel,.warm-image{
    min-height:420px;
  }
}


/* V6 final review polish */
.photo-mosaic{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
  margin-top:18px;
}
.photo-mosaic .tile{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  min-height:260px;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  border:1px solid rgba(17,53,48,.08);
}
.photo-mosaic .tile.large{grid-column:span 6; min-height:420px;}
.photo-mosaic .tile.medium{grid-column:span 3;}
.photo-mosaic .tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-mosaic .tile:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,27,24,.76) 100%);
}
.photo-mosaic .tile .caption{
  position:absolute;
  left:20px;
  right:20px;
  bottom:18px;
  z-index:2;
  color:#fff;
}
.photo-mosaic .tile .caption h3{
  margin:0 0 6px;
  font-size:24px;
}
.photo-mosaic .tile .caption p{
  margin:0;
  font-size:15px;
  line-height:1.4;
}

.trust-photo-strip{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.trust-photo-card{
  overflow:hidden;
  border-radius:30px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow);
}
.trust-photo-card img{
  width:100%;
  height:340px;
  object-fit:cover;
  display:block;
}
.trust-photo-card .copy{
  padding:22px;
}
.trust-photo-card .copy h3{
  margin:0 0 10px;
}
.trust-photo-card .copy p{
  margin:0;
}

.contact-image-card{
  margin-top:18px;
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
}
.contact-image-card img{
  width:100%;
  height:300px;
  object-fit:cover;
  display:block;
}
.contact-socials{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}
.contact-socials a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(7,27,24,.08);
  color:var(--ink);
  font-weight:800;
  text-decoration:none;
}
.contact-socials a:hover{
  background:var(--gold);
  color:#111;
}

.page-proof-band{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:18px;
  align-items:stretch;
}
.page-proof-band .proof-image,
.page-proof-band .proof-copy{
  border-radius:30px;
  overflow:hidden;
}
.page-proof-band .proof-image img{
  width:100%;
  height:100%;
  min-height:460px;
  object-fit:cover;
  display:block;
}
.page-proof-band .proof-copy{
  background:linear-gradient(180deg,#0a2d29,#08211f);
  color:#fff;
  padding:34px;
  border:1px solid rgba(255,255,255,.08);
}
.page-proof-band .proof-copy .eyebrow{color:var(--gold)}
.page-proof-band .proof-copy ul{margin:18px 0 0; padding-left:18px}
.page-proof-band .proof-copy li{margin-bottom:10px}

@media(max-width:980px){
  .photo-mosaic .tile.large,
  .photo-mosaic .tile.medium{
    grid-column:span 12;
  }
  .trust-photo-strip,
  .page-proof-band{
    grid-template-columns:1fr;
  }
}


/* V7 Mini Fixers */
.mini-fixer-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.mini-fixer-card{
  background:#fff;
  border:1px solid #e4d8c7;
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.10);
  transition:.28s;
}
.mini-fixer-card:hover{
  transform:translateY(-8px);
  box-shadow:0 28px 80px rgba(0,0,0,.16);
}
.mini-fixer-card img{
  width:100%;
  height:360px;
  object-fit:cover;
  display:block;
  object-position:top center;
}
.mini-fixer-card div{
  padding:22px;
}
.mini-fixer-card h3{
  color:var(--green);
  margin-bottom:10px;
}
.mini-fixer-card p{
  color:#45524e;
  margin:0;
  line-height:1.5;
}
.mini-fixer-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.mini-fixer-strip img{
  width:100%;
  height:340px;
  object-fit:cover;
  object-position:top center;
  border-radius:28px;
  box-shadow:0 18px 50px rgba(0,0,0,.14);
}
.mini-duo{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.mini-duo img{
  width:100%;
  height:520px;
  object-fit:cover;
  object-position:top center;
  border-radius:32px;
  box-shadow:0 22px 70px rgba(0,0,0,.14);
}
@media(max-width:980px){
  .mini-fixer-grid,
  .mini-fixer-strip,
  .mini-duo{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:560px){
  .mini-fixer-grid,
  .mini-fixer-strip,
  .mini-duo{
    grid-template-columns:1fr;
  }
  .mini-fixer-card img,
  .mini-fixer-strip img,
  .mini-duo img{
    height:420px;
  }
}


/* V8 fixes: dark-section text visibility + Find Finn 10% popup */
.page-proof-band .proof-copy,
.page-proof-band .proof-copy p,
.page-proof-band .proof-copy li,
.page-proof-band .proof-copy h2,
.page-proof-band .proof-copy h3{
  color:#ffffff !important;
}

.page-proof-band .proof-copy p,
.page-proof-band .proof-copy li{
  opacity:.92;
}

.page-proof-band .proof-copy .check-list li,
.check-list.light li{
  color:#ffffff !important;
}

.section-dark .check-list li,
.section-dark .image-story-copy p,
.section-dark .image-story-copy li{
  color:#ffffff;
}

.finn-discount-modal{
  position:fixed;
  inset:0;
  z-index:5000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(2,12,11,.72);
  backdrop-filter:blur(12px);
}
.finn-discount-modal.show{
  display:flex;
}
.finn-discount-box{
  width:min(560px,100%);
  border-radius:34px;
  padding:36px;
  background:linear-gradient(145deg,#f6f0e7,#ffffff);
  color:#102522;
  box-shadow:0 30px 100px rgba(0,0,0,.35);
  position:relative;
  text-align:center;
  border:1px solid rgba(200,164,93,.45);
}
.finn-discount-box h2{
  color:#102522;
  margin-bottom:14px;
}
.finn-discount-box p{
  color:#273c38;
  font-size:18px;
  line-height:1.5;
}
.finn-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid #e4d8c7;
  background:#fff;
  color:#102522;
  font-size:24px;
  cursor:pointer;
}
.offer-unlock h3,
.offer-unlock p{
  color:#ffffff !important;
}
.offer-unlock strong{
  color:var(--gold);
}


/* V9: area chips + richer Finn family sections */
.area-chip-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  max-width:1200px;
  margin:0 auto;
}
.area-chip-cloud span{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:10px 16px;
  border-radius:999px;
  background:#f2ede3;
  border:1px solid rgba(16,37,34,.12);
  color:#16322d;
  font-weight:600;
  letter-spacing:.01em;
}
.area-service-copy .narrow-center p,
.area-service-copy .narrow-center h2{
  color:#fff;
}
.finn-family-perks .offer,
.finn-offers-section .offer{
  border:1px solid rgba(16,37,34,.08);
}
.finn-offers-section .offer strong,
.finn-family-perks .offer strong{
  color:var(--green-900, #12312b);
}
.mini-fixer-strip img{
  object-fit:cover;
}
@media (max-width: 767px){
  .area-chip-cloud{gap:10px;}
  .area-chip-cloud span{font-size:14px;padding:9px 14px;}
}


/* V10 clean-up */
.finn-offers-section .offer-grid,
.perks-grid {
  grid-template-columns: repeat(3, 1fr);
}
@media(max-width:980px){
  .finn-offers-section .offer-grid,
  .perks-grid {
    grid-template-columns: 1fr;
  }
}


/* V11 Finn family name cards */
.named-family{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.named-family article{
  background:#ffffff;
  border:1px solid #e4d8c7;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.10);
  text-align:center;
}
.named-family img{
  width:100%;
  height:340px;
  object-fit:cover;
  object-position:top center;
  display:block;
}
.named-family h3{
  color:var(--green);
  font-size:28px;
  margin:20px 20px 8px;
}
.named-family p{
  color:#45524e;
  margin:0 20px 24px;
  font-size:16px;
  line-height:1.45;
}
@media(max-width:980px){
  .named-family{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){
  .named-family{grid-template-columns:1fr;}
  .named-family img{height:420px;}
}


/* V13 Finn page structure */
.finn-toy-section .warm-image img{
  object-position:top center;
}
.find-finn-section .hidden-fin{
  display:flex;
  align-items:center;
  justify-content:center;
}
.find-finn-section .hidden-fin:before{
  content:"🦈";
  font-size:20px;
}
.finn-hero-media img{
  object-position:top center;
}


/* V14 Finn page reordered */
.finn-three-sharks-board{max-width:900px;min-height:760px;background:linear-gradient(180deg,#062f2b 0%,#031816 100%)}
.finn-three-sharks-board img{height:760px;object-fit:contain;padding:40px;background:radial-gradient(circle at center, rgba(16,108,96,.28), rgba(3,24,22,0) 60%)}
.finn-three-sharks-board .fin-one{top:20%;left:18%}
.finn-three-sharks-board .fin-two{top:22%;right:18%;left:auto}
.finn-three-sharks-board .fin-three{bottom:18%;left:50%;transform:translateX(-50%)}
.finn-three-sharks-board .hidden-fin{background:rgba(255,255,255,.92);box-shadow:0 0 0 2px rgba(200,164,93,.55), 0 10px 26px rgba(0,0,0,.35)}
.finn-three-sharks-board .hidden-fin:before{content:"🦈";font-size:20px}
.finn-three-sharks-board .hidden-fin.found{background:var(--gold);transform:scale(1.08)}
.finn-three-sharks-board .fin-three.found{transform:translateX(-50%) scale(1.08)}
.finn-page .named-family article p{min-height:88px}
@media(max-width:980px){
  .finn-three-sharks-board{min-height:620px}
  .finn-three-sharks-board img{height:620px}
}
@media(max-width:560px){
  .finn-three-sharks-board{min-height:480px}
  .finn-three-sharks-board img{height:480px;padding:22px}
  .finn-three-sharks-board .fin-one{top:16%;left:9%}
  .finn-three-sharks-board .fin-two{top:16%;right:9%}
  .finn-three-sharks-board .fin-three{bottom:12%}
}


/* V15 polished Finn page */
.finn-main-intro .finn-soft-copy{
  max-width:760px;
  color:rgba(255,255,255,.86);
  font-size:18px;
  line-height:1.6;
  margin-top:18px;
}

.finn-family-section{
  overflow:hidden;
}

.finn-family-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.finn-family-card{
  background:#fff;
  border:1px solid #e4d8c7;
  border-radius:32px;
  overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.12);
  transition:transform .28s ease, box-shadow .28s ease;
}

.finn-family-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 100px rgba(0,0,0,.18);
}

.finn-family-card img{
  width:100%;
  height:390px;
  object-fit:cover;
  object-position:top center;
  display:block;
}

.finn-family-card div{
  padding:24px 22px 28px;
  text-align:center;
}

.finn-family-card h3{
  color:var(--green);
  font-size:32px;
  margin:0 0 10px;
}

.finn-family-card p{
  color:#45524e;
  font-size:16px;
  line-height:1.5;
  margin:0;
}

.finn-three-sharks-board{
  max-width:940px;
  min-height:760px;
  background:radial-gradient(circle at center, rgba(24,94,84,.9), rgba(3,24,22,1) 70%);
  border:1px solid rgba(255,255,255,.16);
}

.finn-three-sharks-board .finn-board-main{
  width:100%;
  height:760px;
  object-fit:contain;
  object-position:center;
  padding:42px;
  background:transparent;
}

.finn-three-sharks-board .image-fin{
  width:96px;
  height:96px;
  padding:0;
  overflow:hidden;
  border:3px solid rgba(200,164,93,.8);
  background:#fff;
  box-shadow:0 18px 45px rgba(0,0,0,.35);
}

.finn-three-sharks-board .image-fin:before{
  content:"";
}

.finn-three-sharks-board .image-fin img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  padding:0;
}

.finn-three-sharks-board .image-fin-one{
  top:15%;
  left:10%;
}

.finn-three-sharks-board .image-fin-two{
  top:18%;
  right:10%;
  left:auto;
}

.finn-three-sharks-board .image-fin-three{
  bottom:12%;
  left:50%;
  transform:translateX(-50%);
}

.finn-three-sharks-board .image-fin.found{
  background:var(--gold);
  border-color:#fff;
  transform:scale(1.08);
}

.finn-three-sharks-board .image-fin-three.found{
  transform:translateX(-50%) scale(1.08);
}

.finn-three-sharks-board .offer-unlock{
  max-width:390px;
}

.finn-final-cta .hero-actions{
  justify-content:center;
}

@media(max-width:980px){
  .finn-family-grid{
    grid-template-columns:1fr 1fr;
  }
  .finn-three-sharks-board{
    min-height:620px;
  }
  .finn-three-sharks-board .finn-board-main{
    height:620px;
    padding:30px;
  }
}

@media(max-width:560px){
  .finn-family-grid{
    grid-template-columns:1fr;
  }
  .finn-family-card img{
    height:430px;
  }
  .finn-three-sharks-board{
    min-height:500px;
  }
  .finn-three-sharks-board .finn-board-main{
    height:500px;
    padding:18px;
  }
  .finn-three-sharks-board .image-fin{
    width:68px;
    height:68px;
  }
  .finn-three-sharks-board .image-fin-one{
    top:12%;
    left:5%;
  }
  .finn-three-sharks-board .image-fin-two{
    top:12%;
    right:5%;
  }
  .finn-three-sharks-board .image-fin-three{
    bottom:8%;
  }
}



/* V17: harder Find the Sharks challenge */
.finn-three-sharks-board{
  max-width:1080px;
  min-height:680px;
  background:#041917;
}
.finn-three-sharks-board img{
  height:680px;
  object-fit:cover;
  object-position:center center;
  padding:0;
  background:none;
  filter:saturate(1.02) contrast(1.02);
}
.finn-three-sharks-board .hidden-fin{
  width:26px;
  height:26px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 4px 14px rgba(0,0,0,.28);
  backdrop-filter:blur(1px);
  opacity:.86;
}
.finn-three-sharks-board .hidden-fin:before{
  content:"🦈";
  font-size:12px;
  opacity:.92;
}
.finn-three-sharks-board .hidden-fin:hover,
.finn-three-sharks-board .hidden-fin:focus-visible{
  opacity:1;
  transform:scale(1.08);
  outline:none;
}
.finn-three-sharks-board .hidden-fin.found{
  background:rgba(200,164,93,.92);
  border-color:rgba(200,164,93,.92);
  transform:scale(1.14);
  opacity:1;
}
/* More hidden placements in detailed background */
.finn-three-sharks-board .fin-one{top:17%; left:7.8%;}
.finn-three-sharks-board .fin-two{top:63.5%; left:35.8%; right:auto;}
.finn-three-sharks-board .fin-three{top:73.8%; right:16.2%; left:auto; bottom:auto; transform:none;}
.finn-three-sharks-board .fin-three.found{transform:scale(1.14);}

/* small image sharks inside the buttons for extra challenge */
.finn-three-sharks-board .image-fin{overflow:hidden;}
.finn-three-sharks-board .image-fin img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:999px;
  padding:0;
  opacity:.42;
  mix-blend-mode:screen;
}
.finn-three-sharks-board .image-fin:before{display:none;}
.finn-three-sharks-board .image-fin.found img{opacity:1; mix-blend-mode:normal;}

@media(max-width:980px){
  .finn-three-sharks-board{min-height:560px;}
  .finn-three-sharks-board img{height:560px;}
  .finn-three-sharks-board .hidden-fin{width:24px;height:24px;}
  .finn-three-sharks-board .image-fin img{opacity:.5;}
  .finn-three-sharks-board .fin-one{top:15%; left:7.5%;}
  .finn-three-sharks-board .fin-two{top:61%; left:34.5%;}
  .finn-three-sharks-board .fin-three{top:74%; right:14%;}
}
@media(max-width:560px){
  .finn-three-sharks-board{min-height:420px;}
  .finn-three-sharks-board img{height:420px;}
  .finn-three-sharks-board .hidden-fin{width:22px;height:22px;}
  .finn-three-sharks-board .fin-one{top:14%; left:6.8%;}
  .finn-three-sharks-board .fin-two{top:60%; left:32%;}
  .finn-three-sharks-board .fin-three{top:76%; right:11%;}
}


/* V19: diverse images + seamless header + areas page */
:root{--heathstead-deep:#073a35;--heathstead-deeper:#052f2b}
.site-header{background:linear-gradient(180deg,rgba(7,58,53,.98),rgba(5,47,43,.96))!important;border-bottom:1px solid rgba(255,255,255,.06)}
.site-header.scrolled{background:rgba(7,58,53,.98)!important}
.brand,.brand img{background:transparent!important;box-shadow:none!important;border:none!important;border-radius:0!important}
.nav a{color:rgba(255,255,255,.88)}.nav a:hover{color:#fff}
.diverse-team-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.diverse-team-card{position:relative;overflow:hidden;min-height:360px;border-radius:30px;box-shadow:0 24px 70px rgba(0,0,0,.14)}
.diverse-team-card img{width:100%;height:100%;object-fit:cover;display:block}
.diverse-team-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 36%,rgba(7,27,24,.78) 100%)}
.diverse-team-card div{position:absolute;left:20px;right:20px;bottom:20px;z-index:2;color:#fff}
.diverse-team-card h3{margin:0 0 6px;font-size:24px}.diverse-team-card p{margin:0;font-size:15px;line-height:1.4}
.master-areas-hero{padding-bottom:70px}.master-area-section{border-top:1px solid rgba(7,58,53,.10)}
.master-area-block{max-width:1240px;margin:0 auto 38px}.master-area-block h2{margin-bottom:14px}.master-area-block p{max-width:880px}
.area-chip-cloud.master{margin-top:20px}
@media(max-width:980px){.diverse-team-strip{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.diverse-team-strip{grid-template-columns:1fr}}
