/* ── IAP DESIGN SYSTEM ── */
:root {
  --green:#1E7B4B; --green-light:#28A463; --green-pale:#EAF5EE;
  --grey-dark:#2C2C2C; --grey-mid:#6B6B6B; --grey-light:#F4F4F4;
  --border:#E2E2E2; --white:#FFFFFF;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.06);
  --shadow-md:0 4px 20px rgba(0,0,0,0.1);
  --shadow-green:0 6px 20px rgba(30,123,75,0.25);
  --radius:10px; --radius-lg:14px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Sora',sans-serif;background:var(--white);color:var(--grey-dark);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;height:68px;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 56px;justify-content:space-between;transition:box-shadow 0.3s;}
nav.scrolled{box-shadow:var(--shadow-md);}
.nav-logo{display:flex;align-items:center;gap:11px;cursor:pointer;text-decoration:none;}
.logo-mark{width:38px;height:38px;background:var(--green);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background 0.2s;}
.logo-mark:hover{background:var(--green-light);}
.logo-mark svg{width:22px;height:22px;}
.logo-iap{font-size:15px;font-weight:700;color:var(--green);letter-spacing:1px;line-height:1;}
.logo-tag{font-size:9px;font-weight:400;color:var(--grey-mid);letter-spacing:1.8px;text-transform:uppercase;margin-top:2px;}
.nav-links{display:flex;gap:2px;list-style:none;align-items:center;}
.nav-links a{color:var(--grey-mid);font-size:12.5px;font-weight:500;padding:7px 11px;border-radius:6px;transition:all 0.2s;white-space:nowrap;}
.nav-links a:hover,.nav-links a.active{color:var(--green);background:var(--green-pale);}
.nav-links .nav-cta{background:var(--green);color:var(--white)!important;padding:8px 20px;margin-left:6px;}
.nav-links .nav-cta:hover,.nav-links .nav-cta.active{background:var(--green-light);}
.nav-dropdown{position:relative;}
.nav-dropdown>a::after{content:' ▾';font-size:10px;}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);left:0;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:200px;padding:6px;z-index:200;}
.nav-dropdown:hover .dropdown-menu{display:block;}
.dropdown-menu a{display:block;padding:9px 14px;font-size:13px;color:var(--grey-dark);border-radius:6px;}
.dropdown-menu a:hover{background:var(--green-pale);color:var(--green);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{width:24px;height:2px;background:var(--grey-dark);border-radius:2px;transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;z-index:99;background:var(--white);border-bottom:1px solid var(--border);padding:12px 20px 20px;flex-direction:column;gap:2px;box-shadow:var(--shadow-md);}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:var(--grey-mid);font-size:14px;font-weight:500;padding:11px 14px;border-radius:7px;}
.mobile-menu a:hover{background:var(--green-pale);color:var(--green);}
.mobile-menu .mob-cta{background:var(--green);color:var(--white)!important;margin-top:8px;text-align:center;font-weight:600;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Sora',sans-serif;font-size:13.5px;font-weight:600;padding:12px 28px;border-radius:7px;cursor:pointer;transition:all 0.2s;border:none;text-decoration:none;white-space:nowrap;}
.btn-primary{background:var(--green);color:var(--white);}
.btn-primary:hover{background:var(--green-light);transform:translateY(-2px);box-shadow:var(--shadow-green);}
.btn-outline{background:transparent;color:var(--grey-dark);border:1.5px solid var(--border);}
.btn-outline:hover{border-color:var(--green);color:var(--green);}
.btn-white{background:var(--white);color:var(--green);font-weight:700;}
.btn-white:hover{background:var(--green-pale);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:rgba(255,255,255,0.85);border:1.5px solid rgba(255,255,255,0.35);}
.btn-ghost:hover{border-color:white;color:white;}
.btn-lg{font-size:15px;padding:15px 40px;}
.btn-sm{font-size:12px;padding:8px 18px;}

/* SECTIONS */
.sec{padding:96px 56px;}.sec-sm{padding:64px 56px;}
.sec-green{background:var(--green);padding:80px 56px;}
.sec-pale{background:var(--green-pale);padding:80px 56px;}
.sec-grey{background:var(--grey-light);padding:80px 56px;}
.sec-tag{font-size:10.5px;letter-spacing:3px;text-transform:uppercase;color:var(--green);font-weight:700;margin-bottom:10px;display:block;}
.sec-tag-light{font-size:10.5px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.65);font-weight:700;margin-bottom:10px;display:block;}
.sec-title{font-family:'Lora',serif;font-size:clamp(24px,3vw,38px);font-weight:600;line-height:1.25;color:var(--grey-dark);margin-bottom:14px;letter-spacing:-0.3px;}
.sec-title-light{font-family:'Lora',serif;font-size:clamp(24px,3vw,38px);font-weight:600;line-height:1.25;color:var(--white);margin-bottom:14px;letter-spacing:-0.3px;}
.sec-sub{font-size:15.5px;line-height:1.85;color:var(--grey-mid);font-weight:300;max-width:520px;}
.sec-sub-light{font-size:15.5px;line-height:1.85;color:rgba(255,255,255,0.72);font-weight:300;max-width:520px;}
.center{text-align:center;}.center .sec-sub,.center .sec-sub-light{margin-left:auto;margin-right:auto;}
.page-hero{padding:130px 56px 72px;background:var(--green-pale);border-bottom:1px solid rgba(30,123,75,0.1);}
.page-hero h1{font-family:'Lora',serif;font-size:clamp(28px,4vw,48px);font-weight:600;color:var(--grey-dark);line-height:1.2;max-width:700px;letter-spacing:-0.3px;margin-top:8px;}
.page-hero p{font-size:16px;color:var(--grey-mid);font-weight:300;line-height:1.85;max-width:560px;margin-top:14px;}
.page-hero-green{background:var(--green);border:none;}
.page-hero-green h1{color:var(--white);}
.page-hero-green p{color:rgba(255,255,255,0.78);}
.page-hero-green .sec-tag{color:rgba(255,255,255,0.65);}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.grid-center{align-items:center;}
.gap-col{display:flex;flex-direction:column;gap:12px;}

/* CARDS */
.card{border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px 24px;transition:all 0.25s;background:var(--white);}
.card:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(30,123,75,0.08);transform:translateY(-2px);}
.card-icon{width:42px;height:42px;background:var(--green-pale);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:14px;}
.card h4{font-size:14.5px;font-weight:600;color:var(--grey-dark);margin-bottom:6px;}
.card p{font-size:13px;color:var(--grey-mid);line-height:1.65;font-weight:300;}
.card-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);background:var(--green-pale);padding:3px 9px;border-radius:4px;display:inline-block;margin-top:12px;}
.card-tag-grey{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-mid);background:var(--grey-light);padding:3px 9px;border-radius:4px;display:inline-block;margin-top:12px;}
.coming-soon{opacity:0.55;}
.who-card{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all 0.25s;}
.who-card:hover{border-color:var(--green);box-shadow:var(--shadow-sm);transform:translateY(-2px);}
.who-icon{width:38px;height:38px;flex-shrink:0;background:var(--green-pale);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:17px;}
.who-card h4{font-size:13.5px;font-weight:600;color:var(--grey-dark);margin-bottom:3px;}
.who-card p{font-size:12.5px;color:var(--grey-mid);line-height:1.6;font-weight:300;}
.pillar{padding:26px 22px;border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius);background:rgba(255,255,255,0.07);transition:all 0.25s;}
.pillar:hover{background:rgba(255,255,255,0.13);}
.pillar-icon{font-size:22px;margin-bottom:12px;}
.pillar h4{font-size:14px;font-weight:600;color:var(--white);margin-bottom:5px;}
.pillar p{font-size:12px;color:rgba(255,255,255,0.65);line-height:1.6;font-weight:300;}
.person-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 26px;text-align:center;position:relative;overflow:hidden;}
.person-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--green);}
.person-photo{width:90px;height:90px;border-radius:50%;object-fit:cover;object-position:top;border:3px solid var(--green);margin:0 auto 14px;display:block;}
.person-name{font-family:'Lora',serif;font-size:18px;font-weight:600;color:var(--grey-dark);margin-bottom:3px;}
.person-role{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:14px;font-weight:700;}
.person-bio{font-size:13px;color:var(--grey-mid);line-height:1.7;font-weight:300;text-align:left;margin-top:12px;}
.person-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:14px;}
.tag{background:var(--green-pale);border:1px solid rgba(30,123,75,0.15);color:var(--green);padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600;}

/* MISC */
.benefit-list{display:flex;flex-direction:column;gap:16px;}
.benefit-row{display:flex;gap:13px;align-items:flex-start;}
.benefit-icon{width:34px;height:34px;flex-shrink:0;background:var(--green-pale);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;}
.benefit-row h5{font-size:13.5px;font-weight:600;color:var(--grey-dark);margin-bottom:2px;}
.benefit-row p{font-size:12px;color:var(--grey-mid);line-height:1.6;font-weight:300;}
.value-item{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;background:var(--grey-light);border-radius:var(--radius);border-left:3px solid var(--green);margin-bottom:12px;}
.value-num{font-family:'Lora',serif;font-size:18px;font-weight:600;color:var(--green);line-height:1;flex-shrink:0;min-width:26px;}
.value-item h5{font-size:13.5px;font-weight:600;color:var(--grey-dark);margin-bottom:3px;}
.value-item p{font-size:12.5px;color:var(--grey-mid);line-height:1.6;font-weight:300;}
.stat-num{font-family:'Lora',serif;font-size:30px;font-weight:600;color:var(--green);line-height:1;}
.stat-label{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-mid);margin-top:5px;font-weight:500;}
.stat-row{display:flex;gap:40px;padding-top:36px;border-top:1px solid var(--border);flex-wrap:wrap;}
.advisory-slot{border:1.5px dashed var(--border);border-radius:var(--radius-lg);padding:26px 22px;text-align:center;}
.badge{display:inline-flex;align-items:center;gap:7px;background:var(--green-pale);border:1px solid rgba(30,123,75,0.2);border-radius:100px;padding:5px 14px;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--green);font-weight:700;margin-bottom:20px;}
.badge::before{content:'';width:6px;height:6px;background:var(--green);border-radius:50%;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.topic-tag{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--grey-mid);background:var(--grey-light);padding:2px 8px;border-radius:4px;margin-right:5px;margin-bottom:5px;display:inline-block;}
.prog-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap;}
.prog-tab{padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);color:var(--grey-mid);background:var(--white);transition:all 0.2s;font-family:'Sora',sans-serif;}
.prog-tab.active,.prog-tab:hover{background:var(--green);border-color:var(--green);color:var(--white);}
.prog-panel{display:none;}
.prog-panel.active{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}

/* FLOATING JOIN */
.float-join{position:fixed;bottom:28px;right:28px;z-index:90;opacity:0;pointer-events:none;transition:all 0.3s;transform:translateY(10px);}
.float-join.show{opacity:1;pointer-events:all;transform:translateY(0);}
.float-join a{display:flex;align-items:center;gap:8px;background:var(--green);color:white;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;padding:12px 22px;border-radius:100px;box-shadow:0 4px 20px rgba(30,123,75,0.4);text-decoration:none;transition:all 0.2s;}
.float-join a:hover{background:var(--green-light);transform:translateY(-2px);}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.55s ease,transform 0.55s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* FOOTER */
footer{background:#1A1A1A;padding:48px 56px 28px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:24px;}
.footer-brand .logo-iap{color:#EAF5EE;font-size:15px;}
.footer-brand .logo-tag{color:rgba(255,255,255,0.65);}
.footer-tagline{font-size:13px;color:rgba(255,255,255,0.72);font-weight:300;line-height:1.7;margin-top:12px;max-width:230px;}
.footer-social{display:flex;gap:9px;margin-top:18px;}
.social-btn{width:33px;height:33px;border-radius:7px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;text-decoration:none;font-size:13px;color:rgba(255,255,255,0.82);}
.social-btn:hover{background:var(--green);border-color:var(--green);color:white;}
.footer-col h5{font-size:10.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.9);margin-bottom:14px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,0.72);text-decoration:none;font-weight:300;transition:color 0.2s;}
.footer-col ul li a:hover{color:#EAF5EE;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;}
.footer-copy{font-size:11.5px;color:rgba(255,255,255,0.55);font-weight:300;}

/* FORMS */
.form-wrap{background:var(--grey-light);border:1px solid var(--border);border-radius:var(--radius-lg);padding:38px 34px;}
.form-wrap h3{font-family:'Lora',serif;font-size:19px;font-weight:600;color:var(--grey-dark);margin-bottom:6px;}
.form-wrap .sub{font-size:13px;color:var(--grey-mid);font-weight:300;margin-bottom:24px;line-height:1.6;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.form-group{margin-bottom:14px;}
.form-group label{display:block;font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--grey-mid);margin-bottom:6px;font-weight:600;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 13px;background:var(--white);border:1px solid var(--border);border-radius:7px;color:var(--grey-dark);font-family:'Sora',sans-serif;font-size:13px;transition:border 0.2s;outline:none;}
.form-group input::placeholder,.form-group textarea::placeholder{color:#C0C0C0;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(30,123,75,0.08);}
.form-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%236B6B6B' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;}
.btn-submit{width:100%;padding:13px;background:var(--green);color:var(--white);border:none;border-radius:7px;font-family:'Sora',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;margin-top:6px;}
.btn-submit:hover{background:var(--green-light);transform:translateY(-2px);box-shadow:var(--shadow-green);}
.form-note{font-size:11px;color:var(--grey-mid);text-align:center;margin-top:10px;font-weight:300;}
.form-loading{display:none;text-align:center;padding:14px 0;font-size:13.5px;color:var(--grey-mid);}
.form-loading.show{display:block;}
.success-msg{display:none;text-align:center;padding:40px 16px;}
.success-msg.show{display:block;}
.success-icon{font-size:42px;margin-bottom:14px;}
.success-msg h3{font-family:'Lora',serif;font-size:21px;color:var(--grey-dark);margin-bottom:8px;}
.success-msg p{font-size:13.5px;color:var(--grey-mid);line-height:1.7;font-weight:300;}
.form-content.hide{display:none;}

/* RESPONSIVE */
@media(max-width:1100px){nav{padding:0 28px;}.sec,.sec-sm{padding:72px 28px;}.sec-green,.sec-pale,.sec-grey{padding:64px 28px;}.page-hero{padding:110px 28px 60px;}footer{padding:40px 28px 24px;}.footer-top{grid-template-columns:1fr 1fr;gap:28px;}}
@media(max-width:900px){.nav-links{display:none;}.hamburger{display:flex;}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:20px;}.prog-panel.active{grid-template-columns:1fr;}.form-row{grid-template-columns:1fr;}.stat-row{gap:24px;}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr;}.footer-bottom{flex-direction:column;gap:8px;text-align:center;}.float-join{bottom:16px;right:16px;}}

/* ── BLOG CARDS ── */
.blog-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all 0.25s;cursor:pointer;background:var(--white);}
.blog-card:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(30,123,75,0.08);transform:translateY(-2px);}
.blog-top{height:130px;display:flex;align-items:center;justify-content:center;font-size:36px;}
.blog-body{padding:22px;}
.blog-cat{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:9px;}
.blog-body h4{font-family:'Lora',serif;font-size:17px;font-weight:600;color:var(--grey-dark);line-height:1.4;margin-bottom:9px;}
.blog-body p{font-size:13px;color:var(--grey-mid);line-height:1.7;font-weight:300;}
.blog-meta{font-size:11px;color:var(--grey-mid);margin-top:14px;font-weight:500;display:flex;gap:12px;flex-wrap:wrap;}

/* ── EVENT CARDS ── */
.event-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all 0.25s;margin-bottom:14px;}
.event-card:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(30,123,75,0.08);}
.event-top{background:var(--green-pale);padding:18px 22px;display:flex;justify-content:space-between;align-items:flex-start;}
.event-date{font-family:'Lora',serif;font-size:13px;color:var(--green);font-weight:600;}
.event-type{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-mid);background:var(--white);padding:3px 9px;border-radius:4px;}
.event-body{padding:18px 22px;}
.event-body h4{font-family:'Lora',serif;font-size:17px;font-weight:600;color:var(--grey-dark);margin-bottom:7px;}
.event-body p{font-size:13px;color:var(--grey-mid);line-height:1.7;font-weight:300;margin-bottom:14px;}
.event-meta{display:flex;gap:18px;font-size:12px;color:var(--grey-mid);font-weight:500;flex-wrap:wrap;}

/* ── BOOK CARDS ── */
.book-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all 0.25s;background:var(--white);}
.book-card:hover{border-color:var(--green);box-shadow:0 4px 20px rgba(30,123,75,0.1);transform:translateY(-3px);}
.book-cover{height:170px;display:flex;align-items:center;justify-content:center;font-size:36px;overflow:hidden;}
.book-cover img{width:100%;height:100%;object-fit:cover;}
.book-body{padding:18px 20px;}
.book-body h4{font-family:'Lora',serif;font-size:15px;font-weight:600;color:var(--grey-dark);margin-bottom:7px;line-height:1.4;}
.book-body p{font-size:12.5px;color:var(--grey-mid);line-height:1.65;font-weight:300;margin-bottom:10px;}
.book-author-line{font-size:11px;font-weight:600;color:var(--green);letter-spacing:0.5px;}
.author-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;}
.author-header img{width:64px;height:64px;border-radius:50%;object-fit:cover;object-position:top;border:2px solid var(--green);flex-shrink:0;}

/* ── TBD BANNER ── */
.tbd-banner{background:var(--grey-light);border:1px dashed var(--border);border-radius:var(--radius-lg);padding:36px;text-align:center;margin-top:20px;}
.tbd-banner h4{font-family:'Lora',serif;font-size:19px;font-weight:600;color:var(--grey-dark);margin-bottom:7px;}
.tbd-banner p{font-size:13.5px;color:var(--grey-mid);font-weight:300;margin-bottom:18px;}

/* ── COUNTER ── */
.count-up{display:inline-block;}

/* ── CITY CARDS ── */
.city-card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all 0.25s;}
.city-card:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:0 8px 24px rgba(30,123,75,0.1);}
.city-top{padding:22px;text-align:center;}
.city-top h4{font-size:16px;font-weight:700;color:white;margin-bottom:6px;}
.city-pill{font-size:10px;background:rgba(255,255,255,0.2);color:white;padding:3px 10px;border-radius:100px;display:inline-block;letter-spacing:1px;}
.city-body{padding:16px 18px;text-align:center;}
.city-body p{font-size:12px;color:var(--grey-mid);font-weight:300;line-height:1.6;margin-bottom:12px;}

/* ── BENEFIT HERO ── */
.benefit-hero{grid-column:1/-1;border:2px solid var(--green);border-radius:14px;padding:32px 36px;background:var(--green-pale);display:flex;gap:28px;align-items:center;flex-wrap:wrap;}
.benefit-hero-icon{font-size:52px;flex-shrink:0;}

/* ── STEP CIRCLE ── */
.step-circle{width:54px;height:54px;background:rgba(255,255,255,0.15);border:2px solid rgba(255,255,255,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-family:'Lora',serif;font-size:20px;font-weight:600;color:white;}

/* ── CERT MOCKUP ── */
.cert-mockup{background:white;border:2px solid var(--green);border-radius:8px;padding:36px;max-width:580px;margin:0 auto;box-shadow:0 8px 32px rgba(0,0,0,0.1);}
.cert-mockup-header{background:var(--green);margin:-36px -36px 24px;padding:18px 28px;display:flex;justify-content:space-between;align-items:center;border-radius:6px 6px 0 0;}

/* ── WHAT GRID (chapters page) ── */
.what-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.what-item{background:var(--green-pale);border-radius:10px;padding:18px;text-align:center;}
.what-item .wi{font-size:22px;margin-bottom:8px;}
.what-item h5{font-size:13px;font-weight:600;color:var(--grey-dark);margin-bottom:3px;}
.what-item p{font-size:11.5px;color:var(--grey-mid);font-weight:300;line-height:1.5;}

/* ── BENEFITS GRID (membership page) ── */
.benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:860px;margin:0 auto 48px;}

/* ── RESPONSIVE ADDITIONS ── */
@media(max-width:900px){
  .what-grid{grid-template-columns:1fr;}
  .benefits-grid{grid-template-columns:1fr;}
  .benefit-hero{flex-direction:column;text-align:center;}
  .city-grid{grid-template-columns:1fr 1fr;}
  .author-header{flex-direction:column;text-align:center;}
}
@media(max-width:560px){
  .city-grid{grid-template-columns:1fr;}
}
