/* ── HOME PAGE CSS ── */
.hero{min-height:calc(100vh - 62px);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:3.5rem 5%;gap:3.5rem;background:linear-gradient(160deg,#edf7ed,var(--cream));position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;top:-100px;right:-100px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(139,195,74,.14),transparent 70%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--gl);border:1px solid rgba(46,123,52,.2);color:var(--g);border-radius:50px;padding:.32rem .95rem;font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:1.2rem}
.hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.8rem,5vw,4.8rem);line-height:1;letter-spacing:2px;margin-bottom:.7rem}
.hero-sub{font-size:.95rem;color:var(--m);line-height:1.75;max-width:440px;margin-bottom:2rem;font-weight:300}
.hero-btns{display:flex;gap:.7rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2rem;margin-top:2rem;padding-top:1.8rem;border-top:1px solid var(--b)}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:2.1rem;letter-spacing:1px;color:var(--g)}
.stat-label{font-size:.71rem;color:var(--m);margin-top:.1rem}
.hero-right{position:relative}
.hero-card{background:var(--w);border:1px solid var(--b);border-radius:24px;padding:2rem;box-shadow:0 8px 36px rgba(46,123,52,.08);position:relative;overflow:hidden}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--g),var(--lime))}
.hero-ej{font-size:4.2rem;text-align:center;display:block;margin-bottom:.7rem}
.hero-card h3{font-family:'Bebas Neue',sans-serif;font-size:1.55rem;letter-spacing:1px;text-align:center;margin-bottom:.4rem;color:var(--g)}
.hero-card p{text-align:center;font-size:.83rem;color:var(--m);line-height:1.6}
.hero-pills{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:1.1rem}
.pill{background:var(--gl);border:1px solid rgba(46,123,52,.15);color:var(--g);font-size:.68rem;font-weight:700;padding:.22rem .75rem;border-radius:50px}
.float-card{position:absolute;bottom:-12px;right:-8px;background:var(--w);border:1px solid var(--b);border-radius:13px;padding:.75rem 1rem;font-size:.78rem;box-shadow:0 8px 22px rgba(0,0,0,.08)}
.float-card .stars{color:#f59e0b}
.float-card .rv{font-weight:700;margin-top:.12rem}
.float-card .rs{color:var(--m);font-size:.68rem}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.why-card{background:var(--w);border:1px solid var(--b);border-radius:17px;padding:1.5rem;transition:border-color .3s,transform .3s,box-shadow .3s;text-decoration:none;display:block;color:inherit}
.why-card:hover{border-color:rgba(46,123,52,.3);transform:translateY(-4px);box-shadow:0 10px 28px rgba(46,123,52,.1)}
.why-icon{font-size:1.5rem;margin-bottom:.8rem;width:44px;height:44px;background:var(--gl);border-radius:11px;display:flex;align-items:center;justify-content:center}
.why-card h3{font-size:.88rem;font-weight:700;margin-bottom:.4rem}
.why-card p{font-size:.8rem;color:var(--m);line-height:1.6}
@media(max-width:960px){
  .hero{grid-template-columns:1fr;text-align:center;padding:3rem 5%}
  .hero-sub{margin:0 auto 2rem}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-right{display:none}
  .why-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:580px){.why-grid{grid-template-columns:1fr}}

/* ── PORTFOLIO SECTION ── */
.portfolio-section{padding:4rem 5%;background:var(--green-pale,#f4fbf4)}

.portfolio-header{text-align:center;margin-bottom:2.5rem}
.portfolio-header .sec-label{display:block}
.portfolio-header .sec-title{margin-bottom:.5rem}
.portfolio-header p{color:var(--m);font-size:.9rem;max-width:480px;margin:0 auto}

/* Social proof bar */
.proof-bar{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2.8rem;padding-bottom:2rem;border-bottom:1px solid var(--b)}
.proof-stat{text-align:center}
.proof-num{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:1px;color:var(--g);line-height:1}
.proof-label{font-size:.72rem;font-weight:600;color:var(--m);margin-top:.2rem}

/* Cards grid */
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}

/* Card */
.tf-card{background:var(--w);border:1px solid var(--b);border-radius:22px;overflow:hidden;transition:transform .35s,box-shadow .35s;position:relative}
.tf-card:hover{transform:translateY(-6px);box-shadow:0 18px 48px rgba(46,123,52,.13)}

/* Before / After image */
.tf-img-wrap{position:relative;overflow:hidden;height:280px;background:#f0f0f0}
.tf-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .4s ease}
.tf-card:hover .tf-img-wrap img{transform:scale(1.04)}

/* Kg badge overlaid on image */
.tf-kg-badge{
    position:absolute;top:14px;right:14px;
    background:var(--g);color:#fff;
    font-family:'Bebas Neue',sans-serif;font-size:1.55rem;letter-spacing:1px;
    padding:.3rem .85rem;border-radius:50px;
    box-shadow:0 4px 14px rgba(46,123,52,.35);
    line-height:1.1;
}
.tf-kg-badge span{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.5px;opacity:.85;text-transform:uppercase;line-height:1.2}

/* Plan tag */
.tf-plan-tag{
    position:absolute;bottom:14px;left:14px;
    background:rgba(255,255,255,.92);backdrop-filter:blur(6px);
    color:var(--g);font-size:.65rem;font-weight:700;
    padding:.22rem .75rem;border-radius:50px;
    border:1px solid rgba(46,123,52,.2);
}

/* Verified badge */
.tf-verified{
    position:absolute;top:14px;left:14px;
    background:#fff;border-radius:50px;
    display:flex;align-items:center;gap:.3rem;
    padding:.22rem .7rem;font-size:.62rem;font-weight:700;color:var(--g);
    box-shadow:0 2px 8px rgba(0,0,0,.1);
}

/* Card body */
.tf-body{padding:1.3rem 1.4rem 1.5rem}

.tf-person{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.tf-avatar{
    width:38px;height:38px;border-radius:50%;
    background:linear-gradient(135deg,var(--g),var(--lime));
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;flex-shrink:0;
}
.tf-person-info{}
.tf-name{font-weight:800;font-size:.9rem;color:var(--t);line-height:1.2}
.tf-location{font-size:.72rem;color:var(--m);font-weight:500}

/* Stats row */
.tf-stats{display:flex;gap:0;margin-bottom:1rem;background:var(--gl);border-radius:10px;overflow:hidden}
.tf-stat{flex:1;text-align:center;padding:.55rem .4rem;border-right:1px solid var(--b)}
.tf-stat:last-child{border-right:none}
.tf-stat-val{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;color:var(--g);line-height:1}
.tf-stat-key{font-size:.58rem;font-weight:700;color:var(--m);text-transform:uppercase;letter-spacing:.5px;margin-top:.1rem}

/* Quote */
.tf-quote{font-size:.82rem;color:var(--m);line-height:1.65;font-style:italic;border-left:3px solid var(--lime);padding-left:.75rem}

/* Stars */
.tf-stars{color:#f59e0b;font-size:.9rem;margin-bottom:.5rem;letter-spacing:1px}

/* CTA below cards */
.portfolio-cta{text-align:center;margin-top:2.5rem}
.portfolio-cta p{font-size:.88rem;color:var(--m);margin-bottom:1.2rem}

/* ── Limit to 3 on home page ── */
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}

/* View all button row */
.portfolio-view-all{text-align:center;margin-top:2rem}
.portfolio-view-all p{font-size:.85rem;color:var(--m);margin-bottom:1rem}

/* Responsive */
@media(max-width:960px){.portfolio-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){
    .portfolio-grid{grid-template-columns:1fr}
    .proof-bar{gap:1.2rem}
    .tf-img-wrap{height:220px}
}