#fott-coop-v2,
#fott-coop-v2 * { box-sizing: border-box; }
#fott-coop-v2 { color:#16324f; background:#f7f4ee; font-family:inherit; }
#fott-coop-v2 a { text-decoration:none; }
.fott-coop-wrap { width:min(1180px, calc(100% - 48px)); margin:0 auto; }
.fott-coop-section { padding:88px 0; }
.fott-coop-kicker { margin:0 0 18px; color:#b84e31; font-size:14px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; }
.fott-coop-heading { max-width:760px; margin-bottom:38px; }
.fott-coop-heading h2,
.fott-coop-two-col h2,
.fott-coop-audience h2,
.fott-coop-cta h2 { margin:0 0 18px; color:#16324f; font-size:clamp(36px, 4.2vw, 58px); line-height:1.05; letter-spacing:-.03em; }
.fott-coop-heading p,
.fott-coop-audience p,
.fott-coop-cta p { font-size:18px; line-height:1.7; color:#4d5f70; }

.fott-coop-hero { padding:92px 0 82px; background:linear-gradient(135deg,#f7f4ee 0%,#ffffff 58%,#e9e2d7 100%); }
.fott-coop-hero-grid { display:grid; grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr); gap:72px; align-items:center; }
.fott-coop-hero h1 { margin:0 0 24px; max-width:820px; font-size:clamp(50px,6vw,82px); line-height:.98; letter-spacing:-.045em; }
.fott-coop-lead { margin:0 0 12px; max-width:760px; font-size:22px; line-height:1.55; color:#263d52; }
.fott-coop-sublead { margin:0; max-width:730px; font-size:17px; line-height:1.7; color:#61717f; }
.fott-coop-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.fott-coop-btn { display:inline-flex; align-items:center; justify-content:center; min-height:54px; padding:14px 24px; border-radius:999px; font-weight:800; transition:.2s ease; }
.fott-coop-btn:hover { transform:translateY(-2px); }
.fott-coop-btn-primary { background:#b84e31; color:#fff; box-shadow:0 12px 28px rgba(184,78,49,.22); }
.fott-coop-btn-secondary { border:2px solid #aeb8c0; color:#16324f; background:rgba(255,255,255,.55); }
.fott-coop-hero-visual { position:relative; min-height:430px; border-radius:36px; overflow:hidden; background:linear-gradient(145deg,#16324f,#477881); box-shadow:0 28px 55px rgba(22,50,79,.22); }
.fott-coop-orbit { position:absolute; border:1px solid rgba(255,255,255,.28); border-radius:50%; }
.fott-coop-orbit-one { width:360px; height:360px; right:-70px; top:-50px; }
.fott-coop-orbit-two { width:250px; height:250px; left:-45px; bottom:-35px; }
.fott-coop-badge { position:absolute; left:50%; top:44%; transform:translate(-50%,-50%); width:180px; height:180px; border-radius:50%; display:grid; place-items:center; color:#fff; font-size:30px; font-weight:900; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.35); backdrop-filter:blur(8px); }
.fott-coop-visual-label { position:absolute; left:34px; right:34px; bottom:34px; padding-top:20px; border-top:1px solid rgba(255,255,255,.28); text-align:center; color:#fff; font-weight:700; letter-spacing:.06em; }

.fott-coop-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.fott-coop-card { position:relative; min-height:210px; padding:0 !important; border-radius:28px; overflow:hidden; border:1px solid #dfe3e6; background:#fff; box-shadow:0 18px 38px rgba(22,50,79,.08); }

.fott-coop-card-inner {
  height:100%;
  padding:30px 30px 28px !important;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.fott-coop-card-accent { background:linear-gradient(145deg,#f5eee4,#fff); }
.fott-coop-card h3 { margin:0 0 14px !important; font-size:23px; line-height:1.22; }
.fott-coop-card p { margin:0 !important; color:#607180; font-size:16px; line-height:1.65; }

.fott-coop-soft { background:#e9e2d7; border-radius:34px; margin:0 22px; }
.fott-coop-two-col { display:grid; grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr); gap:70px; align-items:start; }
.fott-coop-values { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.fott-coop-value { padding:26px; border-radius:22px; background:rgba(255,255,255,.72); }
.fott-coop-value h3 { margin:0 0 10px; font-size:21px; }
.fott-coop-value p { margin:0; color:#5b6c7a; line-height:1.6; }

.fott-coop-audience { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:70px; align-items:center; }
.fott-coop-audience-list { display:grid; gap:14px; }
.fott-coop-audience-list span { position:relative; display:block; padding:19px 22px 19px 54px; border-radius:18px; background:#fff; border:1px solid #dde2e5; font-weight:700; }
.fott-coop-audience-list span:before { content:'✓'; position:absolute; left:20px; top:18px; color:#b84e31; font-weight:900; }

.fott-coop-cta { padding:42px 0 82px; }
.fott-coop-cta-inner { display:grid; grid-template-columns:minmax(0,1.25fr) minmax(260px,.75fr); gap:50px; align-items:center; padding:52px 56px; border-radius:32px; background:#16324f; color:#fff; }
.fott-coop-cta .fott-coop-kicker { color:#e9a990; }
.fott-coop-cta h2 { color:#fff; }
.fott-coop-cta p { color:#d9e0e6; margin-bottom:0; }
.fott-coop-cta-actions { display:flex; flex-direction:column; align-items:flex-start; gap:16px; }
.fott-coop-mail { color:#fff; font-size:18px; font-weight:800; border-bottom:1px solid rgba(255,255,255,.55); }

@media (max-width: 980px) {
  .fott-coop-hero-grid,
  .fott-coop-two-col,
  .fott-coop-audience,
  .fott-coop-cta-inner { grid-template-columns:1fr; }
  .fott-coop-hero-visual { min-height:340px; }
  .fott-coop-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .fott-coop-two-col,
  .fott-coop-audience { gap:38px; }
}

@media (max-width: 700px) {
  .fott-coop-wrap { width:min(100% - 28px, 1180px); }
  .fott-coop-hero { padding:42px 0 38px; }
  .fott-coop-hero-grid { gap:24px; }
  .fott-coop-kicker { margin-bottom:12px; font-size:12px; letter-spacing:.12em; }
  .fott-coop-hero h1 { margin-bottom:18px; font-size:clamp(38px,10.5vw,48px); line-height:1.02; }
  .fott-coop-lead { margin-bottom:10px; font-size:18px; line-height:1.48; }
  .fott-coop-sublead { font-size:15px; line-height:1.55; }
  .fott-coop-actions { gap:10px; margin-top:24px; flex-direction:column; }
  .fott-coop-btn { width:100%; min-height:50px; padding:12px 18px; font-size:16px; }
  .fott-coop-hero-visual { min-height:240px; border-radius:24px; }
  .fott-coop-badge { width:120px; height:120px; font-size:22px; }
  .fott-coop-visual-label { left:24px; right:24px; bottom:24px; padding-top:14px; font-size:13px; }

  .fott-coop-section { padding:46px 0; }
  .fott-coop-heading { margin-bottom:24px; }
  .fott-coop-heading h2,
  .fott-coop-two-col h2,
  .fott-coop-audience h2,
  .fott-coop-cta h2 { margin-bottom:14px; font-size:clamp(32px,8.6vw,40px); line-height:1.08; }
  .fott-coop-heading p,
  .fott-coop-audience p,
  .fott-coop-cta p { font-size:16px; line-height:1.55; }

  .fott-coop-grid,
  .fott-coop-values { grid-template-columns:1fr; gap:12px; }
  .fott-coop-card { min-height:0; padding:0 !important; border-radius:20px; box-shadow:0 10px 24px rgba(22,50,79,.07); }
  .fott-coop-card-inner { padding:22px 20px 20px !important; }
  .fott-coop-card h3 { margin-bottom:10px; font-size:22px; line-height:1.18; }
  .fott-coop-card p { font-size:15px; line-height:1.5; }

  .fott-coop-soft { margin:0; border-radius:0; }
  .fott-coop-two-col,
  .fott-coop-audience { gap:24px; }
  .fott-coop-value { padding:20px; border-radius:18px; }
  .fott-coop-value h3 { margin-bottom:7px; font-size:19px; }
  .fott-coop-value p { font-size:15px; line-height:1.5; }

  .fott-coop-audience-list { gap:10px; }
  .fott-coop-audience-list span { padding:15px 18px 15px 48px; border-radius:16px; font-size:15px; line-height:1.35; }
  .fott-coop-audience-list span:before { left:18px; top:14px; }

  .fott-coop-cta { padding:18px 0 46px; }
  .fott-coop-cta-inner { gap:24px; padding:28px 22px; border-radius:22px; }
  .fott-coop-cta-actions { gap:12px; }
  .fott-coop-mail { font-size:16px; }
}

@media (max-width: 420px) {
  .fott-coop-wrap { width:min(100% - 22px, 1180px); }
  .fott-coop-hero h1 { font-size:36px; }
  .fott-coop-heading h2,
  .fott-coop-two-col h2,
  .fott-coop-audience h2,
  .fott-coop-cta h2 { font-size:30px; }
  .fott-coop-card h3 { font-size:20px; }
}
