:root {
    --ati-green: #006b55;
    --ati-green-dark: #004f43;
    --ati-teal: #12cda7;
    --ati-teal-soft: #eafff9;
    --ati-orange: #ff6b2c;
    --ati-orange-soft: #fff2ea;
    --ati-ink: #17342f;
    --ati-muted: #697c78;
    --ati-line: #dcebe7;
    --ati-bg: #fbfffd;
    --ati-white: #ffffff;
    --ati-radius: 24px;
    --ati-shadow: 0 18px 45px rgba(0, 79, 67, .09);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: 'Plus Jakarta Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--ati-ink);
    background: var(--ati-bg);
    line-height: 1.65;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.section { padding: 74px 0; }
.section-pad { padding: 118px 0 74px; }
.soft { background: linear-gradient(180deg, rgba(234,255,249,.35), rgba(255,255,255,0)); }

.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(255,255,255,.88);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(220,235,231,.78);
}
.nav-wrap { display: flex; align-items: center; justify-content: space-between; height: 82px; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 166px; }
.brand img { width: 118px; height: 58px; object-fit: contain; object-position: left center; }
.main-nav { display: flex; align-items: center; gap: 30px; font-size: 14px; font-weight: 700; color: #2e4b46; }
.main-nav a { position: relative; padding: 28px 0; }
.main-nav a.active, .main-nav a:hover { color: var(--ati-green); }
.main-nav a.active::after, .main-nav a:hover::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 18px; height: 3px; border-radius: 99px; background: var(--ati-teal);
}
.nav-toggle { display:none; width:42px; height:42px; border:0; background:var(--ati-teal-soft); border-radius:12px; padding:10px; }
.nav-toggle span { display:block; height:2px; background:var(--ati-green); margin:5px 0; border-radius:99px; }

.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    min-height: 48px; padding: 0 22px; border-radius: 14px;
    font-weight: 800; font-size: 14px; border: 1px solid transparent;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--ati-shadow); }
.btn-orange { background: var(--ati-orange); color: #fff; }
.btn-outline { border-color: rgba(0,107,85,.35); color: var(--ati-green); background: #fff; }
.btn-small { min-height: 44px; padding-inline: 18px; }

.hero { position: relative; overflow: hidden; background: radial-gradient(circle at 84% 12%, rgba(18,205,167,.16), transparent 32%), #fff; }
.hero-grid { display: grid; grid-template-columns: 1fr .95fr; align-items: center; gap: 78px; }
.eyebrow { display:inline-flex; color: var(--ati-green); font-weight:800; background:var(--ati-teal-soft); border:1px solid var(--ati-line); border-radius:99px; padding:7px 12px; margin-bottom:18px; }
.hero h1 { margin: 0; font-size: clamp(42px, 5vw, 72px); line-height: 1.05; letter-spacing: -.045em; color: var(--ati-green-dark); }
.hero h1 span { color: var(--ati-orange); }
.hero p { max-width: 560px; margin: 24px 0 30px; font-size: 17px; color: var(--ati-muted); }
.hero-actions { display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.trust-list { display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 44px; max-width: 610px; }
.trust-list div { display:grid; grid-template-columns: 32px 1fr; gap: 2px 10px; align-items:start; }
.trust-list i { grid-row: span 2; font-size: 26px; color: var(--ati-green); }
.trust-list b { font-size: 13px; color: var(--ati-ink); }
.trust-list small { color: var(--ati-muted); font-size: 12px; }

.hero-visual { position: relative; min-height: 520px; }
.photo-card { position:absolute; inset: 34px 0 0 28px; border-radius: 42% 26% 38% 24%; overflow: hidden; box-shadow: var(--ati-shadow); background:#eef8f5; border: 10px solid #fff; z-index:2; }
.fake-photo { position:relative; width:100%; height:100%; background: linear-gradient(180deg, #bfe5eb 0 38%, #7dc4c4 38% 56%, #f6e2bd 56% 100%); }
.sun { width:70px; height:70px; border-radius:50%; background:#ffd08a; position:absolute; right:70px; top:52px; opacity:.9; }
.mountain { position:absolute; bottom: 42%; width: 75%; height: 34%; background:#5ca477; clip-path: polygon(0 100%, 45% 0, 100% 100%); opacity:.9; }
.m1 { left:-10%; } .m2 { right:-18%; background:#2d8b70; transform:scale(.85); }
.sea { position:absolute; bottom:0; left:0; right:0; height:44%; background:linear-gradient(180deg,#7ecdd2,#eaf9f1); }
.people { position:absolute; bottom:34px; width:74px; height:110px; border-radius:40px 40px 20px 20px; background:var(--ati-green); }
.people::before { content:""; position:absolute; left:18px; top:-32px; width:38px; height:38px; border-radius:50%; background:#8d5b3f; }
.p1 { left:62px; background:#ff8a45; transform:rotate(-5deg); }
.p2 { left:170px; background:#2db99a; height:130px; }
.p3 { right:180px; background:#506c77; height:116px; }
.p4 { right:70px; background:#0d765e; height:138px; }
.organic-shape { position:absolute; right:-12px; bottom:10px; width:220px; height:180px; background:var(--ati-green); border-radius: 60% 40% 70% 30%; z-index:1; }
.dot-pattern { position:absolute; top:0; left:40px; width:170px; height:160px; background-image: radial-gradient(var(--ati-orange) 2px, transparent 2px); background-size: 15px 15px; opacity:.72; z-index:3; }

.section-heading { text-align:center; margin-bottom:34px; }
.section-heading h2, .section-title-row h2 { margin:0; color:var(--ati-green); font-size: clamp(28px, 3vw, 40px); line-height:1.15; letter-spacing:-.03em; }
.section-heading p, .section-title-row p { margin:10px auto 0; color:var(--ati-muted); max-width:620px; }
.section-title-row { display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:28px; }
.section-title-row a { color:var(--ati-green); font-weight:800; }
.cards { display:grid; gap:22px; }
.three { grid-template-columns: repeat(3, 1fr); }
.four { grid-template-columns: repeat(4, 1fr); }
.card { background:#fff; border:1px solid var(--ati-line); border-radius: var(--ati-radius); padding:26px; box-shadow: 0 10px 30px rgba(0,79,67,.05); transition:.22s ease; }
.card:hover { transform: translateY(-4px); box-shadow: var(--ati-shadow); }
.service-card { background: linear-gradient(135deg, var(--ati-teal-soft), #fff 65%); }
.service-card.accent-orange { background: linear-gradient(135deg, var(--ati-orange-soft), #fff 65%); border-color:#ffd3bf; }
.icon-bubble { width:68px; height:68px; display:grid; place-items:center; border-radius:22px; background:var(--ati-green); color:#fff; font-size:30px; margin-bottom:20px; }
.accent-orange .icon-bubble { background:var(--ati-orange); }
.card h3 { margin:0 0 10px; font-size:18px; color:var(--ati-green-dark); line-height:1.3; }
.card p { color:var(--ati-muted); font-size:14px; margin:0 0 20px; }
.link-btn, .research-card a, .audience-card a { color:var(--ati-green); font-weight:800; font-size:14px; }
.link-btn { display:inline-flex; gap:8px; align-items:center; padding:10px 14px; background:var(--ati-green); color:#fff; border-radius:10px; }
.accent-orange .link-btn { background:var(--ati-orange); }
.research-card { position:relative; min-height:255px; }
.research-card .number { display:block; color:rgba(18,205,167,.62); font-size:42px; font-weight:800; line-height:1; margin-bottom:20px; }
.research-card > i { position:absolute; right:24px; top:30px; font-size:42px; color:var(--ati-teal); }
.cta-banner { margin: 10px 0 0; display:grid; grid-template-columns: 80px 1fr auto; gap:22px; align-items:center; padding:34px 42px; background:linear-gradient(135deg,var(--ati-green-dark),#008064); border-radius:24px; color:#fff; box-shadow: var(--ati-shadow); position:relative; overflow:hidden; }
.cta-banner::after { content:""; position:absolute; right:-20px; top:-60px; width:260px; height:260px; border:1px solid rgba(255,255,255,.15); border-radius:50%; }
.cta-icon { width:70px; height:70px; border-radius:50%; background:#fff; color:var(--ati-green); display:grid; place-items:center; font-size:34px; }
.cta-banner h2 { margin:0 0 4px; font-size:30px; }
.cta-banner p { margin:0; color:rgba(255,255,255,.82); }
.audience-card { text-align:left; background: linear-gradient(180deg,#fff,#fff8f4); border-color:#ffd8c7; }
.audience-card .emoji { width:88px; height:88px; display:grid; place-items:center; font-size:36px; font-weight:800; color:var(--ati-orange); background:var(--ati-orange-soft); border-radius:24px; margin-bottom:18px; }
.collaboration-card { background: linear-gradient(180deg, #f5fffc, #ffffff); }
.blog-card { background: linear-gradient(180deg, #ffffff, #f8fffd); }
.testimonial-card .stars { color:#ffae2b; letter-spacing:2px; margin-bottom:14px; }
.profile-mini { display:flex; align-items:center; gap:12px; margin-top:18px; }
.profile-mini span { width:42px; height:42px; display:grid; place-items:center; border-radius:50%; background:var(--ati-teal-soft); color:var(--ati-green); font-weight:900; }
.profile-mini b, .profile-mini small { display:block; }
.profile-mini small { color:var(--ati-muted); font-size:12px; }
.profile-mini.small span { width:34px; height:34px; font-size:12px; }
.dots { text-align:center; margin-top:24px; }
.dots span { display:inline-block; width:8px; height:8px; border-radius:50%; background:#cbd9d5; margin:0 4px; }
.dots .active { width:24px; border-radius:99px; background:var(--ati-green); }
.event-card .badge { display:inline-flex; color:var(--ati-green); font-size:11px; font-weight:900; background:var(--ati-teal-soft); padding:6px 9px; border-radius:9px; margin-bottom:18px; }
.event-card .meta { color:var(--ati-muted); font-size:13px; display:flex; gap:8px; margin:7px 0; }
.event-card .meta i { color:var(--ati-green); }
.event-link { display:inline-flex; gap:8px; align-items:center; margin-top:18px; color:var(--ati-orange); font-weight:900; }
.team-card { text-align:center; padding:0 0 24px; overflow:hidden; }
.team-photo { height:170px; background:linear-gradient(135deg,#b8e8dd,#fff1e8); position:relative; }
.team-photo::after { content:""; position:absolute; left:50%; bottom:-28px; transform:translateX(-50%); width:94px; height:94px; border-radius:50%; background:linear-gradient(180deg,#ffe1cd,#b96b4b); border:8px solid #fff; }
.team-card h3 { padding:44px 18px 0; font-size:15px; }
.team-social { display:flex; justify-content:center; gap:14px; color:var(--ati-green); }
.partner-grid { display:grid; grid-template-columns: repeat(6, 1fr); gap:14px; }
.partner-card { min-height:82px; background:#fff; border:1px solid var(--ati-line); border-radius:16px; display:grid; place-items:center; text-align:center; color:#16876f; font-weight:900; padding:10px; box-shadow:0 8px 24px rgba(0,79,67,.04); }
.footer { position:relative; background:linear-gradient(135deg,var(--ati-green-dark),#007961); color:#fff; padding:90px 0 0; overflow:hidden; }
.footer-wave { position:absolute; left:-5%; right:-5%; top:-70px; height:130px; background:var(--ati-bg); border-radius:0 0 50% 50%; }
.footer-grid { display:grid; grid-template-columns: 1.4fr .7fr .7fr 1fr; gap:48px; position:relative; z-index:1; }
.footer img { width:126px; height:74px; object-fit:contain; object-position:left center; background:rgba(255,255,255,.96); border-radius:14px; padding:6px; margin-bottom:18px; }
.footer p { color:rgba(255,255,255,.78); font-size:14px; }
.footer h4 { margin:0 0 16px; }
.footer a { display:block; color:rgba(255,255,255,.78); margin:8px 0; font-size:14px; }
.socials { display:flex; gap:10px; }
.socials a { width:34px; height:34px; display:grid; place-items:center; border-radius:50%; background:rgba(255,255,255,.12); margin:0; }
.newsletter { display:flex; background:#fff; padding:6px; border-radius:12px; }
.newsletter input { border:0; outline:0; flex:1; min-width:0; padding:0 12px; font-family:inherit; }
.newsletter button { border:0; background:var(--ati-orange); color:#fff; border-radius:9px; padding:0 16px; font-weight:800; }
.copyright { margin-top:50px; border-top:1px solid rgba(255,255,255,.12); text-align:center; padding:18px; color:rgba(255,255,255,.72); font-size:14px; }

@media (max-width: 1024px) {
    .hero-grid { grid-template-columns:1fr; gap:34px; }
    .hero-visual { min-height:420px; }
    .three, .four { grid-template-columns: repeat(2, 1fr); }
    .partner-grid { grid-template-columns: repeat(3, 1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .cta-banner { grid-template-columns:80px 1fr; }
    .cta-banner .btn { grid-column:2; justify-self:start; }
}
@media (max-width: 760px) {
    .container { width:min(100% - 28px, 1180px); }
    .nav-wrap { height:74px; }
    .brand img { width:96px; height:54px; }
    .nav-toggle { display:block; }
    .main-nav { position:absolute; top:74px; left:14px; right:14px; flex-direction:column; align-items:flex-start; background:#fff; border:1px solid var(--ati-line); border-radius:18px; padding:16px; gap:4px; box-shadow:var(--ati-shadow); display:none; }
    .main-nav.is-open { display:flex; }
    .main-nav a { padding:10px 0; }
    .nav-wrap > .btn { display:none; }
    .section-pad { padding-top:92px; }
    .trust-list, .three, .four, .footer-grid, .partner-grid { grid-template-columns:1fr; }
    .section-title-row { align-items:flex-start; flex-direction:column; }
    .cta-banner { grid-template-columns:1fr; padding:28px; }
    .cta-banner .btn { grid-column:auto; }
    .hero-visual { min-height:340px; }
    .photo-card { inset:24px 0 0 0; }
    .footer { padding-top:70px; }
}
