/* =====================
   THE ROCK LEAF — PRO STYLE
   ===================== */
:root{
  --brand-green:#2E7D32;
  --brand-purple:#6A1B9A;
  --text:#222;
  --muted:#666;
  --bg:#ffffff;
  --card:#f7f7f8;
  --shadow:0 8px 24px rgba(0,0,0,.08);
  --radius:14px;
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Utilities */
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.h1,.h2,.h3{line-height:1.2;margin:0 0 12px}
.h1{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.02em}
.h2{font-size:clamp(24px,3vw,32px);font-weight:800;color:var(--brand-green)}
.h3{font-size:20px;font-weight:700;color:var(--brand-purple)}
.lead{font-size:clamp(16px,2.1vw,18px);color:var(--muted);margin:0 0 18px}

/* Buttons */
.btn{
  display:inline-block;border:0;cursor:pointer;
  padding:12px 22px;border-radius:12px;font-weight:700;
  background:var(--brand-purple);color:#fff;text-decoration:none;
  transition:transform .15s ease, box-shadow .15s ease, background .2s ease, color .2s ease;
  box-shadow:0 4px 12px rgba(106,27,154,.25);
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--brand-purple);border:2px solid var(--brand-purple)}
.btn--wa{background:#25D366;color:#fff;box-shadow:0 4px 12px rgba(37,211,102,.25)}
.btn--wa:hover{filter:brightness(.95)}
.btn--buy{background:var(--brand-purple);color:#fff}
.actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Header / Nav */
.site-header{background:var(--brand-green);padding:15px 40px}
.navbar{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo img{height:70px;display:block}

nav ul{display:flex;gap:20px;list-style:none;margin:0;padding:0}
nav a{
  color:#fff;
  text-decoration:none;
  font-weight:600;
  padding:8px 10px;
  border-radius:10px;
  transition:color .15s ease, background .15s ease, border-color .15s ease;
}
nav a:hover{color:#d1c4e9}
/* Link activ (pagina curentă) – alb + linie jos */
nav a.active{
  color:#fff !important;
  font-weight:700 !important;
  border-bottom:3px solid #fff !important;
}

/* Mobile nav */
.nav-toggle{
  display:none;background:transparent;border:none;font-size:28px;line-height:1;color:#fff;cursor:pointer
}
@media (max-width:860px){
  .nav-toggle{display:block}
  .navbar{gap:10px}
  .navbar nav ul{
    position:fixed; top:68px; right:0;
    background:var(--brand-green);
    flex-direction:column; width:240px; height:calc(100% - 68px);
    padding:20px; gap:16px; transform:translateX(100%);
    transition:transform .3s ease; box-shadow:-4px 0 12px rgba(0,0,0,.2);
    z-index:60;
  }
  .navbar nav ul.open{transform:translateX(0)}
  .navbar nav a{color:#fff}
  .navbar nav a.active{border-bottom:2px solid #fff !important}
}

/* Hero */
.hero{
  position:relative; min-height:86vh; display:grid; place-items:center; text-align:center;
  color:#fff; padding:28px;
  background: url("hero-bg.jpg") no-repeat center/cover;
}
.hero::after{
  content:""; position:absolute; inset:0;
  /* overlay mai închis pentru contrast mare */
  background: rgba(0,0,0,0.35);
  /* combinat cu tentă verde subtilă */
  box-shadow: inset 0 0 0 100vmax rgba(46,125,50,0.15);
}
.hero .inner{
  position:relative; z-index:2; max-width:940px; padding:12px 18px;
  /* gradient discret în spatele textului pt lizibilitate pe orice foto */
  background: linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,0));
  border-radius:12px;
}
.hero h1{
  font-size:clamp(30px,5.2vw,46px);
  font-weight:800; color:#fff;
  margin-bottom:18px;
  text-shadow:2px 2px 6px rgba(0,0,0,0.85);
}
/* Text din Hero – ultra vizibil */
.hero-subtext,
.hero .lead,
.hero p{
  color:#ffffff !important;
  font-weight:700 !important;
  font-size:20px !important;
  line-height:1.7 !important;
  text-shadow:2px 2px 6px rgba(0,0,0,0.85) !important;
  margin-bottom:24px !important;
}

/* Cards (generic) */
.cards{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{
  background:var(--card); border-radius:var(--radius); padding:20px;
  box-shadow:var(--shadow); transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.12)}

/* Services detailed */
.services-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.service{background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.service h2{color:var(--brand-purple);margin:0 0 6px}

/* Gallery – modern grid */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.gallery-item{background:#fafafa;border-radius:12px;overflow:hidden;box-shadow:0 4px 10px rgba(0,0,0,.08);padding:16px}
.gallery-before,.gallery-after{position:relative}
.gallery-before img,.gallery-after img{width:100%;border-radius:8px;display:block}
.gallery-before .tag,.gallery-after .tag{
  position:absolute;top:10px;left:10px;background:rgba(0,0,0,.7);color:#fff;
  font-size:14px;padding:2px 8px;border-radius:4px
}
@media (max-width:780px){.gallery-grid{grid-template-columns:1fr}}

/* Shop */
.cards.products{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.product-buttons{display:flex;gap:10px;margin-top:auto}
.card img{width:100%;border-radius:8px;display:block}

/* Contact */
.contact .contact-container{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media (max-width:860px){.contact .contact-container{grid-template-columns:1fr}}
.contact .contact-info{background:var(--card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow)}

/* Footer */
footer.site-footer{background:#0f1114;color:#d6d6d6;padding:28px 0;margin-top:48px}
.footer-grid{display:grid;gap:18px;grid-template-columns:2fr 1fr 1fr}
.footer-grid a{color:#d6d6d6;text-decoration:none}
.footer-grid a:hover{text-decoration:underline}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr}}

/* WhatsApp floating button */
.whatsapp-btn{
  position:fixed; right:20px; bottom:20px; width:56px; height:56px;
  display:grid; place-items:center; background:#25D366; color:#fff; text-decoration:none;
  border-radius:50%; font-size:22px; box-shadow:0 10px 24px rgba(0,0,0,.25); z-index:60;
}
.whatsapp-btn:hover{filter:brightness(.92)}

/* Reveal animation */
.reveal{opacity:0; transform:translateY(14px); animation:reveal .5s ease forwards}
@keyframes reveal{to{opacity:1; transform:translateY(0)}}
/* Iconiță mică în butonul WhatsApp */
.btn--wa .wa-icon {
  margin-right: 8px;
  font-size: 18px;
}