/* ============================================================
   BLACKGREEN — style.css v2
   ============================================================ */

:root {
  --black:   #0B0F14;
  --black-2: #111720;
  --black-3: #1A2233;
  --green:   #23C55E;
  --green-dk:#1AA34A;
  --green-lt:#4ADE80;
  --white:   #FFFFFF;
  --gray:    #94A3B8;
  --gray-dk: #64748B;
  --gray-lt: #CBD5E1;

  --bg:         var(--black);
  --bg-2:       var(--black-2);
  --bg-3:       var(--black-3);
  --text:       var(--white);
  --text-muted: var(--gray);
  --border:     rgba(255,255,255,0.08);
  --border-g:   rgba(35,197,94,0.35);
  --card-bg:    var(--black-2);
  --card-b:     rgba(255,255,255,0.06);
  --input-bg:   var(--black-3);

  --font-d: 'Plus Jakarta Sans', sans-serif;
  --font-b: 'DM Sans', sans-serif;

  --sec-pad: clamp(4rem, 8vw, 7rem);
  --wrap:    1200px;
  --r:       12px;
  --r-lg:    20px;
  --ease:    cubic-bezier(0.4,0,0.2,1);
  --t:       0.22s;
}

[data-theme="light"] {
  --bg:         #F8FAFC;
  --bg-2:       #FFFFFF;
  --bg-3:       #F1F5F9;
  --text:       #0F172A;
  --text-muted: #64748B;
  --border:     rgba(0,0,0,0.08);
  --card-bg:    #FFFFFF;
  --card-b:     rgba(0,0,0,0.07);
  --input-bg:   #F1F5F9;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background var(--t),color var(--t)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit}
ul{list-style:none}
input,textarea,select{font:inherit;outline:none}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.25rem,4vw,2.5rem)}
.sec{padding-block:var(--sec-pad)}

/* ---- SECTION HEADER ---- */
.sec-hd{text-align:center;max-width:620px;margin-inline:auto;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-tag{display:inline-block;font-family:var(--font-d);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:.6rem}
.sec-title{font-family:var(--font-d);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700;line-height:1.18;margin-bottom:.75rem;color:var(--text)}
.sec-desc{font-size:1rem;color:var(--text-muted);line-height:1.7}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-d);font-weight:600;border-radius:8px;transition:all var(--t) var(--ease);white-space:nowrap;cursor:pointer}
.btn-sm{font-size:.82rem;padding:.45rem 1rem}
.btn-md{font-size:.9rem;padding:.65rem 1.4rem}
.btn-lg{font-size:.95rem;padding:.8rem 1.65rem}
.btn-full{width:100%;justify-content:center}
.btn-green{background:var(--green);color:#000}
.btn-green:hover{background:var(--green-lt);transform:translateY(-2px);box-shadow:0 8px 28px rgba(35,197,94,.3)}
.btn-green:active{transform:translateY(0)}
.btn-outline{border:1.5px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px)}

/* ---- TOPBAR ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(11,15,20,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:background var(--t)}
[data-theme="light"] .topbar{background:rgba(248,250,252,.88)}
.topbar.scrolled{background:rgba(11,15,20,.98)}
[data-theme="light"] .topbar.scrolled{background:rgba(248,250,252,.98)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:1rem}
.logo{font-family:var(--font-d);font-size:1.3rem;font-weight:800;letter-spacing:-.03em;flex-shrink:0}
.logo-b{color:var(--text)}.logo-g{color:var(--green)}
.topbar-nav{display:flex;gap:.15rem;align-items:center}
.nav-a{font-family:var(--font-d);font-size:.82rem;font-weight:500;color:var(--text-muted);padding:.38rem .7rem;border-radius:6px;transition:color var(--t),background var(--t)}
.nav-a:hover,.nav-a.act{color:var(--text);background:var(--border)}
.topbar-actions{display:flex;align-items:center;gap:.6rem}
.theme-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-muted);transition:all var(--t);flex-shrink:0}
.theme-btn:hover{border-color:var(--green);color:var(--green)}
.ti{display:none}
[data-theme="dark"] .ti-dark{display:block}
[data-theme="light"] .ti-light{display:block}
.burger{display:none;flex-direction:column;gap:5px;padding:6px}
.burger span{display:block;width:21px;height:2px;background:var(--text);border-radius:2px;transition:all var(--t)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-menu{display:flex;flex-direction:column;padding:.75rem 1.25rem 1.25rem;border-top:1px solid var(--border);background:var(--bg);animation:slideDown .22s var(--ease)}
.mob-menu[hidden]{display:none}
.mob-a{font-family:var(--font-d);font-size:.95rem;font-weight:500;color:var(--text-muted);padding:.7rem .4rem;border-bottom:1px solid var(--border);transition:color var(--t)}
.mob-a:last-child{border:none}
.mob-a:hover{color:var(--green)}
.mob-cta{margin-top:.6rem;text-align:center;border:none!important}

/* ---- HERO ---- */
.hero{position:relative;display:flex;align-items:center;padding-top:64px;overflow:hidden;min-height:92vh}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(35,197,94,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(35,197,94,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 40%,transparent 100%);pointer-events:none}
.hero-glow{position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);width:600px;height:320px;background:radial-gradient(ellipse,rgba(35,197,94,.1) 0%,transparent 70%);pointer-events:none}
.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;padding-block:clamp(2rem,5vw,3.5rem);max-width:740px}
.hero-badge{display:inline-flex;align-items:center;gap:.45rem;font-size:.72rem;font-weight:600;color:var(--green);border:1px solid rgba(35,197,94,.3);background:rgba(35,197,94,.08);padding:.28rem .8rem;border-radius:999px;margin-bottom:1rem}
.badge-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s ease infinite}
.hero-h1{font-family:var(--font-d);font-size:clamp(1.7rem,2.6vw,2.5rem);font-weight:800;line-height:1.18;letter-spacing:-.02em;margin-bottom:.9rem;color:var(--text)}
.hero-h1 em{font-style:normal;color:var(--green)}
.hero-sub{font-size:clamp(.88rem,1.3vw,1rem);color:var(--text-muted);line-height:1.72;max-width:500px;margin-bottom:1.75rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:2.25rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.65rem}
.trust-c{display:flex;flex-direction:column;gap:.12rem;padding:.75rem 1rem;border:1px solid var(--card-b);background:var(--card-bg);border-radius:var(--r);min-width:145px;transition:border-color var(--t)}
.trust-c:hover{border-color:var(--border-g)}
.trust-ic{font-size:1rem;margin-bottom:.25rem}
.trust-c strong{font-family:var(--font-d);font-size:.82rem;color:var(--text)}
.trust-c span{font-size:.72rem;color:var(--text-muted)}

/* ---- SERVICES ---- */
.services{background:var(--bg-2)}
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:1.1rem}
.srv-card{background:var(--bg-3);border:1px solid var(--card-b);border-radius:var(--r-lg);padding:1.75rem;display:flex;flex-direction:column;gap:.85rem;transition:border-color var(--t),transform var(--t),box-shadow var(--t);position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;inset:0;border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(35,197,94,.05),transparent);opacity:0;transition:opacity var(--t)}
.srv-card:hover{border-color:var(--border-g);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.18)}
.srv-card:hover::before{opacity:1}
.srv-card.feat{border-color:rgba(35,197,94,.22)}
.srv-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(35,197,94,.1);border-radius:10px;padding:9px;color:var(--green)}
.srv-icon svg{width:100%;height:100%}
.srv-title{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--text)}
.srv-desc{font-size:.85rem;color:var(--text-muted);line-height:1.62}
.srv-bul{display:flex;flex-direction:column;gap:.45rem;flex:1}
.srv-bul li{font-size:.8rem;color:var(--text-muted);padding-left:1rem;position:relative}
.srv-bul li::before{content:'';position:absolute;left:0;top:.55em;width:5px;height:5px;background:var(--green);border-radius:50%}
.srv-more{margin-top:auto;align-self:flex-start;font-family:var(--font-d);font-size:.82rem;font-weight:700;color:var(--green);display:flex;align-items:center;gap:.35rem;transition:gap var(--t)}
.srv-more:hover{gap:.6rem}

/* ---- PORTFOLIO ---- */
.portfolio{background:var(--bg)}
.pf-filters{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;margin-bottom:2.5rem}
.pf-btn{font-family:var(--font-d);font-size:.82rem;font-weight:500;color:var(--text-muted);background:var(--bg-2);border:1px solid var(--card-b);border-radius:999px;padding:.4rem 1rem;transition:all var(--t)}
.pf-btn:hover,.pf-btn.act{color:#000;background:var(--green);border-color:var(--green)}
.pf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(290px,100%),1fr));gap:1.1rem}
.pf-card{background:var(--card-bg);border:1px solid var(--card-b);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:all var(--t)}
.pf-card:hover{border-color:var(--border-g);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.18)}
.pf-img{width:100%;aspect-ratio:16/9;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative;overflow:hidden}
.pf-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.pf-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(35,197,94,.06),transparent)}
.pf-body{padding:1.1rem}
.pf-tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:.4rem;display:block}
.pf-title{font-family:var(--font-d);font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.4rem}
.pf-desc{font-size:.8rem;color:var(--text-muted);line-height:1.6}

/* ---- TESTIMONIALS ---- */
.testimonials{background:var(--bg-2)}
.tsl-wrap{overflow:hidden;position:relative}
.tsl-track{display:flex;transition:transform .48s var(--ease)}
.tsl-card{min-width:100%;padding:0 clamp(0rem,5vw,5rem);display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.25rem}
.tsl-q{font-size:clamp(.95rem,1.7vw,1.15rem);color:var(--text);line-height:1.72;max-width:660px;font-style:italic;position:relative}
.tsl-q::before{content:'"';font-size:4.5rem;line-height:0;color:var(--green);opacity:.18;position:absolute;top:1.4rem;left:-1.2rem;font-family:var(--font-d)}
.tsl-av{width:48px;height:48px;border-radius:50%;background:var(--bg-3);border:2px solid rgba(35,197,94,.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:1rem;color:var(--green);margin-bottom:.3rem}
.tsl-name{font-family:var(--font-d);font-weight:700;font-size:.9rem;color:var(--text)}
.tsl-role{font-size:.78rem;color:var(--text-muted)}
.tsl-stars{color:var(--green);font-size:.85rem;letter-spacing:2px}
.tsl-ctrl{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin-top:2rem}
.sl-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--t)}
.sl-btn:hover{border-color:var(--green);color:var(--green);background:rgba(35,197,94,.08)}
.sl-dots{display:flex;gap:.45rem}
.sl-dot{width:7px;height:7px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:all var(--t)}
.sl-dot.act{background:var(--green);width:22px;border-radius:4px}

/* ---- ABOUT ---- */
.about{background:var(--bg)}
.about-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:start}
.about-text .sec-title{text-align:left;margin-bottom:1.25rem}
.about-text p{color:var(--text-muted);line-height:1.75;margin-bottom:.9rem;font-size:.95rem}
.about-vals{margin-top:1.75rem}
.about-vals h3{font-family:var(--font-d);font-size:.95rem;font-weight:700;margin-bottom:.85rem;color:var(--text)}
.val-list{display:flex;flex-direction:column;gap:.65rem}
.val-list li{display:flex;align-items:flex-start;gap:.7rem;font-size:.88rem;color:var(--text-muted);line-height:1.5}
.val-dot{flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--green);margin-top:.48em}
.val-list strong{color:var(--text)}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-content:start}
.stat-c{background:var(--card-bg);border:1px solid var(--card-b);border-radius:var(--r-lg);padding:1.75rem 1.25rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.3rem;transition:border-color var(--t)}
.stat-c:hover{border-color:var(--border-g)}
.stat-n{font-family:var(--font-d);font-size:clamp(2rem,4vw,2.75rem);font-weight:800;color:var(--green);line-height:1}
.stat-p{font-family:var(--font-d);font-size:1.4rem;font-weight:700;color:var(--green);display:inline}
.stat-l{font-size:.78rem;color:var(--text-muted);margin-top:.3rem}

/* ---- CONTACT ---- */
.contact{background:var(--bg-2)}
.contact-in{display:grid;grid-template-columns:1fr 360px;gap:clamp(2rem,4vw,4.5rem);align-items:start}
.cform{display:flex;flex-direction:column;gap:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-family:var(--font-d);font-size:.82rem;font-weight:600;color:var(--text)}
.fg label span{color:var(--green)}
.fg input,.fg textarea,.fg select{background:var(--input-bg);border:1px solid var(--border);border-radius:8px;padding:.7rem .95rem;color:var(--text);font-size:.9rem;transition:border-color var(--t),box-shadow var(--t);width:100%;-webkit-appearance:none;appearance:none}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .95rem center;padding-right:2.2rem}
.fg select option{background:var(--bg-3);color:var(--text)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--gray-dk, #64748B)}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(35,197,94,.1)}
.fg input.inv,.fg select.inv{border-color:#EF4444}
.ferr{font-size:.75rem;color:#EF4444;min-height:1em}
.fg textarea{resize:vertical;min-height:110px}
.fsuccess{background:rgba(35,197,94,.1);border:1px solid rgba(35,197,94,.3);color:var(--green);padding:.9rem 1.1rem;border-radius:var(--r);font-size:.88rem;text-align:center}
.fsuccess[hidden]{display:none}
.wa-card{display:flex;align-items:center;gap:.9rem;padding:1.1rem;background:rgba(35,197,94,.09);border:1.5px solid rgba(35,197,94,.28);border-radius:var(--r-lg);transition:all var(--t);color:var(--text)}
.wa-card:hover{background:rgba(35,197,94,.15);transform:translateY(-2px);box-shadow:0 8px 26px rgba(35,197,94,.18)}
.wa-ic{width:48px;height:48px;background:var(--green);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#000;flex-shrink:0}
.wa-card strong{display:block;font-family:var(--font-d);font-size:.9rem}
.wa-card span{font-size:.78rem;color:var(--text-muted)}
.wa-arr{color:var(--green);margin-left:auto;flex-shrink:0}
.cmeta{display:flex;flex-direction:column;border:1px solid var(--card-b);border-radius:var(--r-lg);overflow:hidden}
.cm-item{display:flex;flex-direction:column;gap:.18rem;padding:.9rem 1.1rem;border-bottom:1px solid var(--card-b)}
.cm-item:last-child{border-bottom:none}
.cm-label{font-size:.74rem;color:var(--text-muted)}
.cm-val{font-family:var(--font-d);font-size:.88rem;font-weight:600;color:var(--text)}

/* ---- FOOTER ---- */
.footer{background:var(--bg);border-top:1px solid var(--border);padding-top:3.5rem}
.footer-in{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem}
.footer-brand p{font-size:.85rem;color:var(--text-muted);max-width:270px;line-height:1.62;margin-top:.65rem;margin-bottom:1.25rem}
.soc-links{display:flex;gap:.65rem}
.soc-a{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--t)}
.soc-a:hover{border-color:var(--green);color:var(--green);background:rgba(35,197,94,.08)}
.footer-col{display:flex;flex-direction:column;gap:.55rem}
.footer-col h4{font-family:var(--font-d);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text);margin-bottom:.4rem}
.footer-col a{font-size:.85rem;color:var(--text-muted);transition:color var(--t)}
.footer-col a:hover{color:var(--green)}
.footer-col span{font-size:.85rem;color:var(--text-muted)}
.footer-bot{border-top:1px solid var(--border)}
.footer-bot-in{display:flex;align-items:center;justify-content:space-between;padding-block:1.25rem;font-size:.78rem;color:var(--text-muted)}

/* ---- MODALS ---- */
.modal-ov{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.72);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1.25rem;animation:fadeIn .2s var(--ease)}
.modal-ov[hidden]{display:none}
.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:2.25rem;max-width:500px;width:100%;position:relative;max-height:90vh;overflow-y:auto;animation:slideUp .28s var(--ease)}
.modal-pf{max-width:660px;padding:0;overflow:hidden}
.m-close{position:absolute;top:.9rem;right:.9rem;width:34px;height:34px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--t);z-index:2}
.m-close:hover{background:rgba(35,197,94,.18);color:var(--green)}
.m-icon{width:52px;height:52px;background:rgba(35,197,94,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--green);margin-bottom:1.1rem}
.m-icon svg{width:26px;height:26px}
.m-title{font-family:var(--font-d);font-size:1.25rem;font-weight:700;margin-bottom:.85rem;color:var(--text)}
.m-body{font-size:.88rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.1rem}
.m-list{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.6rem}
.m-list li{font-size:.85rem;color:var(--text-muted);padding-left:1rem;position:relative}
.m-list li::before{content:'';position:absolute;left:0;top:.55em;width:5px;height:5px;background:var(--green);border-radius:50%}
.m-ctas{display:flex;gap:.65rem;flex-wrap:wrap}
.pm-img{width:100%;aspect-ratio:16/8;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative}
.pm-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.18))}
.pm-content{padding:1.75rem}
.pm-tag{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:.5rem}
.pm-meta{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin:1.1rem 0;padding:1.1rem;background:var(--bg-3);border-radius:var(--r)}
.pm-meta>div{display:flex;flex-direction:column;gap:.28rem}
.pm-meta strong{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green)}
.pm-meta span{font-size:.83rem;color:var(--text-muted)}
.pm-tech{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.4rem}
.tech-tag{font-size:.72rem;font-weight:500;color:var(--text-muted);background:var(--bg-3);border:1px solid var(--card-b);border-radius:999px;padding:.22rem .65rem}

/* ---- WA FLOAT ---- */
.wa-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:800;width:54px;height:54px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#000;box-shadow:0 5px 22px rgba(35,197,94,.38);transition:transform var(--t),box-shadow var(--t)}
.wa-float:hover{transform:scale(1.1);box-shadow:0 9px 32px rgba(35,197,94,.48)}

/* ---- BLOG CARDS (index preview) ---- */
.blog-prev{background:var(--bg-2)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:1.1rem}
.blog-card{background:var(--card-bg);border:1px solid var(--card-b);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t);display:flex;flex-direction:column}
.blog-card:hover{border-color:var(--border-g);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.16)}
.bc-img{width:100%;aspect-ratio:16/9;background:var(--bg-3);overflow:hidden}
.bc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.blog-card:hover .bc-img img{transform:scale(1.04)}
.bc-body{padding:1.1rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.bc-cat{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--green)}
.bc-title{font-family:var(--font-d);font-size:.95rem;font-weight:700;color:var(--text);line-height:1.35}
.bc-exc{font-size:.82rem;color:var(--text-muted);line-height:1.6}
.bc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted)}
.bc-read{color:var(--green);font-weight:600;font-size:.78rem;transition:gap var(--t);display:inline-flex;align-items:center;gap:.3rem}
.bc-read:hover{gap:.5rem}

/* ---- ANIMATIONS ---- */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideDown{from{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.afu{opacity:0;transform:translateY(24px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.afu.vis{opacity:1;transform:translateY(0)}
.hero-badge.afu{transition-delay:.08s}
.hero-h1.afu{transition-delay:.16s}
.hero-sub.afu{transition-delay:.24s}
.hero-ctas.afu{transition-delay:.32s}
.hero-trust.afu{transition-delay:.4s}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .topbar-nav{display:none}
  .topbar-cta{display:none}
  .burger{display:flex}
  .about-in{grid-template-columns:1fr;gap:2.5rem}
  .about-stats{grid-template-columns:repeat(4,1fr)}
  .footer-in{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:768px){
  .hero{min-height:auto;padding-bottom:2.5rem}
  .hero-content{padding-block:1.75rem 1.25rem}
  .hero-h1{font-size:clamp(1.45rem,5.5vw,1.85rem)}
  .hero-sub{font-size:.88rem;margin-bottom:1.4rem}
  .hero-ctas{gap:.55rem;margin-bottom:1.6rem}
  .trust-c{min-width:calc(50% - .35rem)}
  .contact-in{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .footer-in{grid-template-columns:1fr;gap:1.75rem}
  .footer-bot-in{flex-direction:column;gap:.4rem;text-align:center}
  .tsl-q::before{display:none}
  .tsl-card{padding:0 .75rem}
}
@media(max-width:480px){
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%;justify-content:center}
  .hero-h1{font-size:1.45rem}
  .trust-c{min-width:100%}
  .pm-meta{grid-template-columns:1fr}
  .m-ctas{flex-direction:column}
  .m-ctas .btn{width:100%;justify-content:center}
  .pf-grid,.srv-grid{grid-template-columns:1fr}
}

:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:3px}
::selection{background:rgba(35,197,94,.22);color:var(--text)}
