/* Variables */
:root{
  --primary:#0a8a0a;
  --accent:#0b7a7a;
  --dark:#066606;
  --bg:#0f0f10;
  --muted:#9ca3af;
  --white:#fff;
  --container:1100px;
}
*{box-sizing:border-box}
body{font-family:'Poppins',Segoe UI,Roboto,Arial; margin:0;background:var(--bg);color:var(--white);line-height:1.5}
.container{max-width:var(--container);margin:0 auto;padding:0 18px}
a{color:inherit}

/* Skip link */
.skip-link{position:fixed;left:8px;top:8px;background:#000;color:#fff;padding:8px 10px;border-radius:6px;z-index:2000;transform:translateY(-120%);transition:transform .18s}
.skip-link:focus{transform:translateY(0)}

/* Topbar */
.topbar{background:rgba(0,0,0,0.85);font-size:14px}
.topbar .topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:6px 18px}
.topbar a{color:#d1d5db}

/* Header */
header{position:fixed;left:0;right:0;top:40px;padding:12px 18px;z-index:1500;backdrop-filter:blur(4px)}
header.transparent{background:transparent}
header.solid{background:rgba(0,0,0,0.7)}
header .container{display:flex;align-items:center;justify-content:space-between}
.logo img{height:44px}
nav{display:flex;align-items:center}
.nav-links{display:flex;list-style:none;padding:0;margin:0}
.nav-links li{margin:0 10px}
.nav-links a{
  padding:8px 12px;
  border-radius:8px;
  text-decoration:none;
  color:var(--white);
  font-weight:600;
  transition:background-color 0.2s, color 0.2s;
  letter-spacing:0.3px
}
.nav-links a:hover{
  background:rgba(255,255,255,0.08);
  color:var(--primary)
}
.nav-links a.active{
  background:rgba(10,138,10,0.15);
  color:var(--primary)
}
.menu-toggle{display:none;font-size:24px;cursor:pointer}

/* Hero */
.hero{min-height:100vh;background-image:url('images/image1.jpg');background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;position:relative;padding-top:110px}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,0.14);pointer-events:none;z-index:1;backdrop-filter:blur(1px)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.event-subpages .grid{align-items:start}
.event-subpages .service-card{padding:18px}

/* Pricing packages */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.package{background:rgba(255,255,255,0.02);padding:18px;border-radius:12px;text-align:left}
.package h4{margin:0 0 6px}
.package .price{font-size:20px;font-weight:700;color:var(--primary);margin-bottom:8px}
.package ul{margin:0;padding-left:18px;color:var(--muted)}
.package .book-btn{
  display:inline-block;
  margin-top:10px;
  background:var(--primary);
  color:var(--white);
  padding:10px 14px;
  border-radius:8px;
  text-decoration:none;
  cursor:pointer;
  transition:transform 0.2s, background-color 0.2s;
}

.package .book-btn:hover {
  background:var(--dark);
  transform:translateY(-2px);
}

.package .book-btn.clicked {
  background:var(--accent);
}

/* Booking modal (injected by script.js) */
.booking-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,0.6);z-index:2500}
.booking-modal .modal-card{background:linear-gradient(180deg,#07120a,#0b1410);padding:20px;border-radius:12px;max-width:680px;width:94%;color:var(--white)}
.booking-modal h3{margin:0 0 8px}
.booking-modal label{display:block;font-size:13px;margin-top:10px}
.booking-modal input,.booking-modal textarea,.booking-modal select{width:100%;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--white);margin-top:6px}
.booking-modal .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}
.booking-modal .btn{padding:8px 12px;border-radius:8px}
.booking-modal .btn.cancel{background:transparent;border:1px solid rgba(255,255,255,0.08);color:var(--white)}

@media(max-width:992px){.grid{grid-template-columns:repeat(2,1fr)}.packages{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.grid{grid-template-columns:1fr}.packages{grid-template-columns:1fr}}
.hero-overlay{position:relative;z-index:2;background:linear-gradient(180deg,rgba(10,10,10,0.38),rgba(10,10,10,0.32));padding:40px 36px;border-radius:14px;text-align:center;color:var(--white);max-width:920px;margin:0 18px}
.hero-logo{height:64px;margin-bottom:14px;display:inline-block}
.hero h1{font-size:48px;margin:0 0 10px;font-weight:700;letter-spacing:0.2px}
.hero-tag{
  color:var(--muted);
  max-width:720px;
  margin:0 auto 22px;
  font-size:18px;
  font-weight:300;
  line-height:1.6;
  letter-spacing:0.2px;
  text-align:center
}
.btn{display:inline-block;padding:12px 22px;border-radius:10px;text-decoration:none}
.explore-btn{background:linear-gradient(90deg,var(--primary),var(--accent));color:var(--white);font-weight:700;box-shadow:0 6px 18px rgba(10,10,10,0.45);transition:transform .16s,box-shadow .16s}
.explore-btn:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(10,10,10,0.5)}

/* Quick links */
.quick-links{padding:22px 0;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent)}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.quick-card{display:flex;gap:12px;align-items:center;padding:12px;background:#fff;color:#111;border-radius:10px;text-decoration:none}
.quick-card img{width:56px;height:56px}

/* News */
.section{padding:48px 0}
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.news-card{background:#fff;color:#111;border-radius:8px;overflow:hidden}
.news-card img{width:100%;height:140px;object-fit:cover}
.news-body{padding:12px}
.news-body h3{margin:0 0 8px}
.news-body .meta{color:var(--muted);font-size:13px}

/* Footer */
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;padding:24px 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.04);padding:12px 0;text-align:center}
.home-footer{position:fixed;left:0;right:0;bottom:0;background:rgba(0,0,0,0.92);padding:10px 0;text-align:center;font-size:13px;color:var(--white);z-index:1800}

/* Topbar and header (homepage) */
.site-topbar{background:#000;color:var(--white);font-size:13px}
.site-topbar .topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:6px 18px}
.site-topbar .topbar-left span{margin-right:12px}

/* Topbar ticker (scrolling bullet list of services) */
.topbar-ticker{display:inline-block;overflow:hidden;vertical-align:middle;margin-right:12px;max-width:58vw}
.topbar-ticker .ticker-list{display:inline-flex;gap:18px;align-items:center;white-space:nowrap;padding:0;margin:0;list-style:none;animation:tickermove 18s linear infinite}
.topbar-ticker .ticker-list li{padding:4px 0;color:var(--white);opacity:0.95;font-size:13px}
.topbar-ticker .ticker-list li::after{content:" •";color:rgba(255,255,255,0.6);margin-left:6px}

@keyframes tickermove{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* make sure ticker shrinks nicely on mobile */
@media(max-width:640px){
  .topbar-ticker{max-width:70vw}
  .topbar-ticker .ticker-list{animation-duration:22s}
}
.site-topbar a{color:var(--white);text-decoration:none}

.site-header{position:sticky;top:0;z-index:1600;padding:10px 0;background:transparent;backdrop-filter:blur(4px)}
.site-header .header-inner{display:flex;align-items:center;justify-content:space-between}
.site-header .logo img{height:44px}
.nav-links{display:flex;gap:12px;list-style:none;padding:0;margin:0}
.nav-links a{color:var(--white);text-decoration:none;padding:8px 10px;border-radius:8px;font-weight:600}
.nav-links a.active{background:rgba(10,138,10,0.12);color:var(--primary)}

@media(max-width:640px){
  .site-topbar .topbar-inner{flex-direction:column;gap:6px}
  .nav-links{display:none}
}

/* Services page styles */
.services-hero{
  padding:60px 0;
  background:linear-gradient(180deg,rgba(10,138,10,0.08),rgba(255,255,255,0.01));
  color:var(--white);
  border-bottom:1px solid rgba(255,255,255,0.04);
}

.services-hero .container {
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
}

.services-hero .breadcrumb{
  color:var(--muted);
  font-size:14px;
  margin-bottom:12px;
}

.services-hero h1.decorated{
  font-size:42px;
  margin:0 0 16px;
  background:linear-gradient(90deg,var(--white),rgba(255,255,255,0.9));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.services-hero .lead{
  color:var(--muted);
  font-size:18px;
  line-height:1.6;
  max-width:680px;
  margin:16px 0 0;
}

/* Section styles */
.section-lead {
  color:var(--muted);
  font-size:18px;
  line-height:1.6;
  max-width:720px;
  margin:16px 0 32px;
}

h2.decorated {
  font-size:32px;
  margin:0;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  display:inline-block;
}

h2.decorated::after {
  content:"";
  display:block;
  height:4px;
  width:60%;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  margin-top:8px;
  border-radius:4px;
  opacity:0.9;
}

/* Decorative text styles */
.decorated{background:linear-gradient(90deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700;display:inline-block}
.decorated::after{content:"";display:block;height:4px;width:48%;background:linear-gradient(90deg,var(--primary),var(--accent));margin-top:8px;border-radius:4px;opacity:0.95}

/* Slightly lighter cards on services/event subpages to improve contrast */
.service-card, .package{background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0.01))}
.services-hero .breadcrumb{color:var(--muted);font-size:14px;margin-bottom:8px}
.services-hero .breadcrumb a{text-decoration:none;color:var(--muted);transition:color 0.2s}
.services-hero .breadcrumb a:hover{color:var(--primary)}
.services-hero h1{font-size:36px;margin:6px 0;font-weight:700;letter-spacing:0.5px}
.services-hero .lead{color:var(--muted);max-width:820px;font-size:18px;line-height:1.6;font-weight:300}

.services-grid .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-card{background:rgba(255,255,255,0.03);padding:18px;border-radius:12px;text-align:left}
.service-card img{width:100%;height:160px;object-fit:cover;border-radius:8px;margin-bottom:12px}
.service-card h3{margin:0 0 8px}
.service-card h3 a{text-decoration:none;color:var(--white);transition:color 0.2s}
.service-card h3 a:hover{color:var(--primary)}
.service-card p{color:var(--muted);font-size:15px;margin:0 0 12px;line-height:1.6}
.service-card .btn{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--white)}
.service-card.muted{opacity:0.7}

.why-choose{padding:40px 0}
.features{display:flex;gap:18px}
.feature{background:rgba(255,255,255,0.02);padding:18px;border-radius:10px;flex:1}
.feature p{color:var(--muted);margin:8px 0 0}

.contact-cta{padding:30px 0}
.cta-card{background:linear-gradient(90deg,rgba(10,138,10,0.12),rgba(11,122,122,0.08));padding:22px;border-radius:12px;display:flex;gap:18px;align-items:center;justify-content:space-between}
.cta-card h3{margin:0}

@media(max-width:992px){.services-grid .grid{grid-template-columns:repeat(2,1fr)}.features{flex-direction:column}}
@media(max-width:640px){.services-grid .grid{grid-template-columns:1fr}.cta-card{flex-direction:column;align-items:stretch}}

/* Micro-interactions & animations */
.service-card{transition:transform .28s cubic-bezier(.2,.9,.3,1),box-shadow .28s,opacity .28s}
.service-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 20px 40px rgba(2,6,23,0.45);opacity:1}
.service-card img{transition:transform .36s ease,filter .28s ease;border-radius:8px}
.service-card:hover img{transform:scale(1.06);filter:brightness(.95)}
.service-card .btn{transition:transform .18s ease,box-shadow .18s ease}
.service-card .btn:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(2,6,23,0.3)}

/* subtle entrance */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.services-grid .service-card,.why-choose .feature{animation:fadeUp .6s ease both}

/* CTA subtle pulse */
.explore-btn{transition:transform .18s ease,box-shadow .18s ease}
.explore-btn:active{transform:scale(.99)}

/* Accessibility focus states */
.nav-links a:focus,.btn:focus{outline:3px solid rgba(10,138,10,0.18);outline-offset:3px}

/* Responsive */
@media(max-width:992px){.quick-grid,.news-grid{grid-template-columns:repeat(2,1fr)};header{top:36px}}
@media(max-width:640px){
  .quick-grid,.news-grid{grid-template-columns:1fr}
  .menu-toggle{display:block;background:transparent;border:0;color:var(--white);font-size:26px;cursor:pointer}
  .nav-links{display:none;position:absolute;right:18px;top:86px;background:rgba(0,0,0,0.92);padding:12px;border-radius:8px;flex-direction:column;min-width:180px}
  .nav-links.active{display:flex}
  .nav-links a{display:block;padding:8px 10px}
}

/* Paybill card - modern, compact box */
.paybill-wrapper{max-width:var(--container);margin:18px auto;padding:0 18px}
.paybill-card{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 18px;border-radius:12px;background:linear-gradient(180deg,rgba(10,138,10,0.12),rgba(11,122,122,0.06));box-shadow:0 10px 26px rgba(2,6,23,0.45);border:1px solid rgba(255,255,255,0.04);color:var(--white)}
.paybill-info{display:flex;flex-direction:column}
.paybill-title{font-size:13px;color:var(--muted);font-weight:600}
.paybill-business{font-weight:700;font-size:18px;margin-top:4px}
.paybill-number{font-weight:800;font-size:20px;color:var(--white);margin-top:6px;background:rgba(0,0,0,0.16);padding:6px 10px;border-radius:8px;display:inline-block}
.paybill-actions{display:flex;gap:10px;align-items:center}
.paybill-actions .btn{padding:8px 12px;border-radius:10px;font-weight:700}
.copy-btn{background:transparent;border:1px solid rgba(255,255,255,0.12);color:var(--white)}
.copy-btn:hover{background:rgba(255,255,255,0.02)}
.copy-msg{font-size:13px;color:var(--muted);margin-top:8px}

/* Remove underlines for Quick Links and contact anchors (footer and topbar) */
.footer-col a, .footer-grid a, .site-topbar a, .topbar-right a, .footer-bottom a{color:inherit;text-decoration:none}
.footer-col a:hover, .site-topbar a:hover{text-decoration:underline;color:var(--primary)}

/* Email link styling */
a[href^="mailto:"]{
  color: var(--primary);
  font-weight: 500;
  transition: color 0.2s ease;
  text-decoration: none;
  padding: 2px 4px;
  border-radius: 4px;
  background: rgba(10,138,10,0.08);
}
a[href^="mailto:"]:hover{
  color: var(--accent);
  background: rgba(10,138,10,0.12);
  text-decoration: none;
}

@media(max-width:640px){
  .paybill-card{flex-direction:column;align-items:flex-start}
  .paybill-actions{width:100%;justify-content:flex-start}
}

/* Payment confirmation modal */
.payment-confirm-modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(2,6,23,0.6);
  z-index: 2500;
}

.payment-confirm-modal .modal-card {
  background: linear-gradient(180deg,#07120a,#0b1410);
  padding: 24px;
  border-radius: 12px;
  max-width: 520px;
  width: 94%;
  color: var(--white);
  box-shadow: 0 20px 40px rgba(2,6,23,0.45);
}

.payment-confirm-modal h3 {
  margin: 0 0 16px;
  font-size: 22px;
}

.payment-confirm-modal label {
  display: block;
  font-size: 14px;
  margin-top: 12px;
  color: var(--muted);
}

.payment-confirm-modal input,
.payment-confirm-modal textarea {
  width: 100%;
  padding: 10px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.2);
  color: var(--white);
  margin-top: 6px;
  font-size: 15px;
}

.payment-confirm-modal .modal-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 24px;
}

.payment-confirm-modal .btn {
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
}

.payment-confirm-modal .submit-btn {
  background: var(--primary);
  color: var(--white);
  border: none;
}

.payment-confirm-modal .cancel-btn {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--white);
}

/* Payment buttons styling */
.paybill-info .copy-paybill,.paybill-info .copy-acc{background:#10b981;color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;margin-right:10px;transition:transform 0.2s, background 0.2s}
.paybill-info .copy-paybill:hover,.paybill-info .copy-acc:hover{background:#059669;transform:translateY(-2px)}
.paybill-info .open-pay-confirm{background:#2563eb;color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;margin-left:10px;transition:transform 0.2s, background 0.2s}
.paybill-info .open-pay-confirm:hover{background:#1d4ed8;transform:translateY(-2px)}
.paybill-info{margin-top:12px;padding:16px;border-radius:12px;background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02));}
