/* Grovora Tech Solutions — Pure CSS */
:root{
  --bg:#0b1124; --bg-2:#121a33; --fg:#f1f3f8; --muted:#9aa3bd;
  --card:rgba(255,255,255,.04); --border:rgba(255,255,255,.10);
  --primary:#4ad6a0; --primary-2:#37c08c; --gold:#e9c275; --gold-2:#c9a25b;
  --radius:14px; --radius-lg:22px;
  --shadow:0 20px 50px -20px rgba(0,0,0,.6);
  --glow:0 0 60px -10px rgba(74,214,160,.4);
  --font-display:"Cormorant Garamond", Georgia, serif;
  --font-sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --grad:linear-gradient(135deg,var(--primary),var(--gold));
  --maxw:1200px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--fg); font-family:var(--font-sans); line-height:1.5;
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 800px 500px at 10% -10%, rgba(74,214,160,.18), transparent),
    radial-gradient(ellipse 700px 500px at 110% 20%, rgba(233,194,117,.10), transparent);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block; height:auto}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display); letter-spacing:-.01em; font-weight:500; line-height:1.05; margin:0}
p{margin:0}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}
.italic{font-style:italic}
.gold{color:var(--gold)}
.text-muted{color:var(--muted)}
.text-primary{color:var(--primary)}
.text-gradient-gold{background:linear-gradient(135deg,#f1d28c,#c69a4e); -webkit-background-clip:text; background-clip:text; color:transparent}
.text-gradient-green{background:linear-gradient(135deg,#7fe5b8,#3fbf8a); -webkit-background-clip:text; background-clip:text; color:transparent}
.eyebrow{display:inline-flex; align-items:center; gap:12px; color:var(--primary); text-transform:uppercase; letter-spacing:.25em; font-size:12px; font-weight:600}
.eyebrow::before{content:""; height:1px; width:32px; background:var(--primary)}
.card{
  background:linear-gradient(160deg, rgba(40,52,90,.6), rgba(20,28,55,.55));
  border:1px solid var(--border); border-radius:var(--radius-lg);
  backdrop-filter: blur(8px);
}
.btn{
  display:inline-flex; align-items:center; gap:10px; padding:14px 26px; border-radius:999px;
  font-weight:600; font-size:15px; cursor:pointer; transition:all .25s ease; border:1px solid transparent;
}
.btn-outline{border-color:rgba(233,194,117,.6); color:var(--fg); background:transparent}
.btn-outline:hover{background:var(--gold); color:#1a1430; box-shadow:var(--glow)}
.btn-primary{background:var(--grad); color:#0b1124}
.btn-primary:hover{box-shadow:var(--glow)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* NAV */
.nav{position:fixed; inset:0 0 auto 0; z-index:50; transition:background .3s, backdrop-filter .3s, border-color .3s; border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(11,17,36,.7); backdrop-filter:blur(14px); border-bottom-color:var(--border)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:72px}
.brand{display:flex; align-items:center; gap:12px}
.brand-logo{height:46px; width:46px; border-radius:999px; background:#fff; padding:4px; object-fit:contain; box-shadow:0 0 0 1px rgba(74,214,160,.35)}
.brand-text .t1{font-family:var(--font-display); font-style:italic; font-weight:700; font-size:15px; letter-spacing:.04em}
.brand-text .t2{color:var(--gold); font-size:10px; letter-spacing:.22em}
.nav-links{display:flex; gap:30px; align-items:center}
.nav-links a{font-size:13px; font-weight:500; text-transform:uppercase; letter-spacing:.12em; color:rgba(241,243,248,.8); transition:color .2s}
.nav-links a:hover, .nav-links a.active{color:var(--gold)}
.nav-toggle{display:none; background:transparent; border:0; color:var(--fg); padding:8px; cursor:pointer}
.nav-mobile{display:none; border-top:1px solid var(--border); background:rgba(11,17,36,.96); backdrop-filter:blur(14px)}
.nav-mobile.open{display:block; animation:slide .25s ease}
.nav-mobile a{display:block; padding:14px 20px; font-size:13px; text-transform:uppercase; letter-spacing:.12em; border-radius:8px; margin:2px 14px}
.nav-mobile a:hover, .nav-mobile a.active{background:rgba(255,255,255,.05); color:var(--gold)}
@keyframes slide{from{opacity:0; transform:translateY(-8px)} to{opacity:1; transform:none}}

/* SECTIONS */
main{padding-top:72px}
section{padding:60px 0}
@media(min-width:768px){section{padding:90px 0}}
.section-heading{font-size:clamp(34px,5vw,58px); line-height:1.05}
h1.hero{font-size:clamp(46px,8vw,96px); line-height:.95; font-weight:400}
h1.page{font-size:clamp(36px,6vw,64px); line-height:1.05}

/* HERO */
.hero-grid{display:grid; gap:48px; align-items:center; padding-top:30px}
@media(min-width:992px){.hero-grid{grid-template-columns:1fr 1fr; padding-top:60px}}
.hero-img-wrap{position:relative}
.hero-img-wrap::before{content:""; position:absolute; inset:-16px; background:var(--grad); opacity:.18; filter:blur(60px); border-radius:30px}
.hero-img{position:relative; border-radius:24px; overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow)}
.hero-img img{width:100%; aspect-ratio:4/3; object-fit:cover}
.hero-badge{position:absolute; bottom:-22px; left:-22px; padding:14px 18px; border-radius:18px; display:none}
@media(min-width:640px){.hero-badge{display:block}}
.hero-badge .v{font-family:var(--font-display); font-size:26px}
.hero-badge .l{font-size:11px; color:var(--muted)}

/* GRID */
.grid{display:grid; gap:24px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr 1fr}
@media(min-width:640px){.grid-3{grid-template-columns:1fr 1fr} .grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:992px){.grid-2{grid-template-columns:1fr 1fr} .grid-3{grid-template-columns:repeat(3,1fr)} .grid-4{grid-template-columns:repeat(4,1fr)}}

/* CARDS */
.feature{padding:22px; display:flex; gap:16px; align-items:flex-start; transition:transform .25s}
.feature:hover{transform:translateY(-4px)}
.feature .icon{height:42px; width:42px; border-radius:12px; display:grid; place-items:center; background:var(--grad); color:#0b1124; flex-shrink:0}
.svc{padding:26px; height:100%; position:relative; overflow:hidden; transition:transform .25s}
.svc:hover{transform:translateY(-6px)}
.svc .icon-box{height:48px; width:48px; border-radius:14px; display:grid; place-items:center; background:rgba(255,255,255,.04); color:var(--primary); border:1px solid rgba(74,214,160,.3); margin-bottom:18px}
.svc h3{font-size:26px; margin-bottom:8px}
.tile{padding:28px; text-align:center; font-size:18px; font-weight:600; transition:transform .25s}
.tile:hover{transform:translateY(-4px)}

/* PORTFOLIO / BLOG cards */
.work{overflow:hidden; transition:transform .3s}
.work:hover{transform:translateY(-8px)}
.work .img{aspect-ratio:4/3; overflow:hidden}
.work .img img{width:100%; height:100%; object-fit:cover; transition:transform .7s}
.work:hover .img img{transform:scale(1.08)}
.work .body{padding:22px}
.tag{font-size:11px; text-transform:uppercase; letter-spacing:.2em; color:var(--gold)}
.post .img{aspect-ratio:16/10; overflow:hidden}
.post .img img{width:100%; height:100%; object-fit:cover; transition:transform .7s}
.post:hover .img img{transform:scale(1.08)}
.post .body{padding:20px}
.chip{display:inline-block; font-size:10px; text-transform:uppercase; letter-spacing:.15em; padding:4px 10px; border-radius:999px; background:rgba(74,214,160,.15); color:var(--primary)}
.meta{display:flex; gap:10px; font-size:11px; color:var(--muted); align-items:center; flex-wrap:wrap}
.read-link{display:inline-flex; gap:8px; align-items:center; color:var(--primary); font-weight:600; font-size:14px; margin-top:14px; transition:gap .25s}
.read-link:hover{gap:12px}

/* SIDEBAR (blog) */
.blog-grid{display:grid; gap:28px}
@media(min-width:992px){.blog-grid{grid-template-columns:2fr 1fr}}
.posts-grid{display:grid; gap:22px}
@media(min-width:640px){.posts-grid{grid-template-columns:1fr 1fr}}
.aside{display:grid; gap:22px}
.search-wrap{position:relative}
.search-wrap input{width:100%; padding:12px 14px 12px 40px; background:rgba(11,17,36,.6); border:1px solid var(--border); border-radius:12px; color:var(--fg); font-size:14px; outline:none; transition:border-color .2s}
.search-wrap input:focus{border-color:var(--gold)}
.search-wrap svg{position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--muted)}
.cat-list{list-style:none; padding:0; margin:0; display:grid; gap:12px; font-size:14px}
.cat-list li{display:flex; justify-content:space-between; color:var(--muted); cursor:pointer; transition:color .2s}
.cat-list li:hover{color:var(--fg)}
.cat-list .n{color:var(--gold); font-weight:600}

/* CONTACT */
.contact-grid{display:grid; gap:48px}
@media(min-width:992px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-item{display:flex; gap:16px; align-items:flex-start; margin-bottom:18px}
.contact-item .ic{height:44px; width:44px; border-radius:999px; border:1px solid var(--border); display:grid; place-items:center; color:var(--primary); flex-shrink:0}
.contact-item .lbl{font-weight:600}
.contact-item a{color:var(--muted)} .contact-item a:hover{color:var(--fg)}
.social-row{display:flex; gap:10px; margin-top:24px; flex-wrap:wrap}
.social-pill{display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px; border:1px solid var(--border); font-size:13px; transition:all .2s}
.social-pill:hover{border-color:var(--gold); color:var(--gold)}
form.contact-form{padding:28px; display:grid; gap:16px}
.field label{font-size:14px; font-weight:500}
.field .input, .field input, .field textarea{
  width:100%; padding:13px 16px; margin-top:8px; background:rgba(11,17,36,.7);
  border:1px solid var(--border); border-radius:12px; color:var(--fg); font-family:inherit; font-size:15px; outline:none; transition:border-color .2s;
}
.field input:focus, .field textarea:focus{border-color:var(--gold)}
.field .err{color:#ff8b8b; font-size:12px; margin-top:6px; display:block}
.row2{display:grid; gap:16px; grid-template-columns:1fr}
@media(min-width:640px){.row2{grid-template-columns:1fr 1fr}}

/* CTA */
.cta-card{padding:36px; display:flex; flex-direction:column; gap:24px; justify-content:space-between; position:relative; overflow:hidden}
.cta-card::before{content:""; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(74,214,160,.25), transparent 60%); pointer-events:none}
.cta-card h3{font-size:28px; position:relative}
@media(min-width:768px){.cta-card{flex-direction:row; align-items:center; padding:48px}}

/* FOOTER */
footer{border-top:1px solid var(--border); margin-top:80px; background:rgba(255,255,255,.02)}
.footer-grid{display:grid; gap:36px; padding:56px 0}
@media(min-width:768px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1.4fr}}
.footer h4{color:var(--gold); font-family:var(--font-sans); font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.2em; margin-bottom:14px}
.footer ul{list-style:none; padding:0; margin:0; display:grid; gap:9px; font-size:14px; color:var(--muted)}
.footer ul a:hover{color:var(--fg)}
.footer-bottom{border-top:1px solid var(--border); padding:18px 0; font-size:12px; color:var(--muted); display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px}
.icon-circle{height:36px; width:36px; border-radius:999px; border:1px solid var(--border); display:inline-grid; place-items:center; transition:all .2s}
.icon-circle:hover{border-color:var(--gold); color:var(--gold)}

/* WhatsApp floating */
.wa{position:fixed; right:20px; bottom:20px; height:56px; width:56px; border-radius:999px; background:#25D366; color:#fff; display:grid; place-items:center; z-index:50; box-shadow:0 10px 30px -8px rgba(37,211,102,.55); transition:transform .2s}
.wa:hover{transform:scale(1.08)}
.wa::before{content:""; position:absolute; inset:0; border-radius:999px; background:#25D366; opacity:.35; animation:ping 1.8s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping{75%,100%{transform:scale(1.6); opacity:0}}

/* Reveal animation */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:none}
.float{animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)}}

/* Responsive nav */
@media(max-width:991px){
  .nav-links{display:none}
  .nav-toggle{display:inline-flex}
  .brand-text{display:none}
}
@media(min-width:640px){.brand-text{display:block}}
