*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#17B794;
  --teal-dark:#0f8f73;
  --teal-light:#e6f7f4;
  --teal-xlight:#f2fbf9;
  --cream:#fafaf8;
  --white:#ffffff;
  --ink:#0d1f1b;
  --ink-mid:#2e4a43;
  --ink-soft:#5a7570;
  --danger:#e74c3c;
  --border:#d8ede9;
  --shadow:0 4px 24px rgba(23,183,148,.10);
  --shadow-lg:0 12px 48px rgba(23,183,148,.16);
  --ff-display:'Cormorant Garamond',serif;
  --ff-body:'Inter',sans-serif;
  --radius:14px;
  --radius-lg:24px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--cream);color:var(--ink);line-height:1.6;overflow-x:hidden}

/* ─── SCROLLBAR ─────────────────────────────────────────── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:99px}

.main-content, .container{
    width: 100%;
    max-width:1200px;
    margin:0 auto; 
}
/* ─── NAV ───────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:999; 
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px); 
  padding:0 clamp(1.5rem,5vw,4rem);
  display:flex;align-items:center;justify-content:space-between;
  height:68px;
  transition:box-shadow .3s;
}
nav.scrolled{box-shadow:var(--shadow)}
.nav-logo{
  font-family:var(--ff-display);font-size:1.45rem;font-weight:900;
  color:var(--teal);letter-spacing:-.02em;text-decoration:none;
}
.text-primary{color:var(--teal)}
.text-decoration-none{text-decoration:none}
.text-muted{color:var(--ink-soft); font-weight: 200;}
.nav-logo span{color:var(--ink)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{
  color:var(--ink-soft);font-size:.9rem;font-weight:500;
  text-decoration:none;letter-spacing:.02em;transition:color .2s;
}
.nav-links a:hover{color:var(--teal)}
.nav-cta{
  background:var(--teal);color:#fff;border:none;border-radius:99px;
  padding:.55rem 1.4rem;font-family:var(--ff-body);font-weight:600;font-size:.88rem;
  cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;
  text-decoration:none;letter-spacing:.01em;
}
.nav-cta:hover{background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(23,183,148,.3)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

.d-flex{display:flex}
.justify-center{justify-content:center}
.align-center{align-items:center}
.justify-sb{justify-content:space-between}
.justify-sa{justify-content:space-around}
.flex-column{flex-direction:column}

.border-radius{border-radius:var(--radius)}
.border-radius-lg{border-radius:var(--radius-lg)}
.overflow-hidden{overflow:hidden}
.pt-0{padding-top:0}
.pb-0{padding-bottom:0}
.pt-1{padding-top:0.75rem}
.pb-1{padding-bottom:0.75rem}
.pt-2{padding-top:1.5rem}
.pb-2{padding-bottom:1.5rem}
.pt-3{padding-top:2rem}
.pb-3{padding-bottom:2rem}
p{
    margin-bottom: 15px;
}
/* ─── MOBILE DRAWER ─────────────────────────────────────── */
.nav-overlay{
  display:none;position:fixed;inset:0;background:rgba(13,31,27,.45);
  z-index:998;opacity:0;transition:opacity .3s;
}
.nav-overlay.active{display:block;opacity:1}
.nav-drawer{
  position:fixed;top:0;right:0;bottom:0;width:100%;max-width:300px;
  background:var(--white);z-index:34999;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  padding:1.5rem 1.8rem 2rem;
  box-shadow:-8px 0 40px rgba(13,31,27,.15);
}
.nav-drawer.open{transform:translateX(0)}
.nav-drawer-top{
  display:flex;align-items:center;justify-content:space-between; 
  border-bottom: 1px solid var(--border);
  padding-bottom: 15px;
  margin-bottom:2.5rem;
}
.nav-drawer-logo{font-family:var(--ff-display);font-size:1.3rem;font-weight:800;color:var(--teal);text-decoration:none}
.nav-drawer-logo span{color:var(--ink)}
.nav-drawer-close{
  width:36px;height:36px;border:none;background:var(--teal-light);
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--teal);font-size:1rem;transition:background .2s;
}
.nav-drawer-close:hover{background:var(--teal);color:#fff}
.nav-drawer-links{list-style:none;display:flex;flex-direction:column;gap:.25rem;flex:1}
.nav-drawer-links a{
  display:block;padding:.85rem 1rem;border-radius:10px;
  color:var(--ink);font-size:1rem;font-weight:500;text-decoration:none;
  transition:background .2s,color .2s;
}
.nav-drawer-links a:hover{background:var(--teal-light);color:var(--teal)}
.nav-drawer-cta{
  display:block;text-align:center;background:var(--teal);color:#fff;
  border-radius:99px;padding:.85rem 1.5rem;font-weight:700;font-size:.95rem;
  text-decoration:none;margin-top:1rem;transition:background .2s;
}
.nav-drawer-cta:hover{background:var(--teal-dark)}
/* Hamburger → X animation */
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}


.hero{
  margin-top:100px;
  position:relative;overflow:hidden;
  background:var(--white);
}
section.hero{
    padding: 0;
}
.hero-main{
  min-height:400px; 
  padding: 4rem clamp(1.5rem,5vw,4rem); 
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
}
.hero::before{
  content:'';position:absolute;
  top:-120px;right:-120px;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(23,183,148,.12) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  bottom:-80px;left:-80px;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(23,183,148,.07) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero-content{position:relative;z-index:2;}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--teal-light);color:var(--teal-dark);
  border-radius:99px;padding:.35rem 1rem;font-size:.78rem;font-weight:600;
  letter-spacing:.03em;margin-bottom:1.6rem;
  opacity:0;animation:fadeUp .6s .1s forwards;
}
.hero-badge i{font-size:.82rem}
.hero-h1{
  font-family:var(--ff-display);font-size:clamp(2.4rem,4.5vw,3.8rem);
  font-weight:900;line-height:1.1;color:var(--ink);
  letter-spacing:-.03em;margin-bottom:1.4rem;
  opacity:0;animation:fadeUp .6s .25s forwards;
}
.hero-h1 em{font-style:normal;color:var(--teal)}
.hero-sub{
  font-size:1.05rem;color:var(--ink-soft);line-height:1.7;
  margin-bottom:2.2rem; 
  opacity:0;animation:fadeUp .6s .4s forwards;
}
.hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .6s .55s forwards;
}
.btn-primary{
  background:var(--teal);color:#fff;border:none;border-radius:99px;
  padding:.8rem 2rem;font-family:var(--ff-body);font-weight:600;font-size:.95rem;
  cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;
  transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(23,183,148,.35)}
.btn-ghost{
  background:transparent;color:var(--ink);border:2px solid var(--border);
  border-radius:99px;padding:.78rem 1.8rem;font-family:var(--ff-body);font-weight:600;
  font-size:.95rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;
  transition:border-color .2s,color .2s,transform .15s;
}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}

/* Hero stats */ 

.hero-stats{
  display:none;gap:2.4rem;margin-top:2.8rem;
  opacity:0;animation:fadeUp .6s .7s forwards;
}

.hero-stats-graphics{
    position: absolute;
    bottom: 20%;
    right: 50%;
    display: flex;
    gap: 2.4rem; 
    opacity:0;animation:fadeUp .6s .7s forwards;
} 

.stat-num{font-family:var(--ff-display);font-size:2rem;font-weight:900;color:var(--ink);line-height:1}
.stat-num span{color:var(--teal)}
.stat-label{font-size:.68rem;color:var(--ink-soft);font-weight:300;letter-spacing:.03em;margin-top:.6rem}

/* Hero illustration */
.hero-visual{
  position:relative;display:flex;align-items:center;justify-content:center;
  opacity:0;animation:fadeIn .8s .4s forwards;
}
.hero-svg-wrap{
  position:relative;width:100%;max-width:520px;
}

/* ─── MARQUEE ────────────────────────────────────────────── */
.marquee-strip{
  background:var(--teal);color:#fff;
  padding:.65rem 0;overflow:hidden;white-space:nowrap;
}
.marquee-inner{
  display:inline-flex;gap:3rem;animation:marquee 22s linear infinite;
  font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
}
.marquee-inner span{opacity:.7}
.marquee-inner::after{
  content:attr(data-content);margin-left:3rem;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── SECTION SHARED ─────────────────────────────────────── */
section{padding:clamp(3.5rem,8vw,7rem) clamp(1.5rem,5vw,4rem)}
.section-label{
  font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal);margin-bottom:.8rem;display:block;
}
.section-title{
  font-family:var(--ff-display);font-size:clamp(1.9rem,3.5vw,2.9rem);
  font-weight:900;color:var(--ink);letter-spacing:-.025em;line-height:1.2;
  margin-bottom:1rem;
}
.section-sub{font-size:1rem;color:var(--ink-soft);max-width:520px;line-height:1.7}
.section-header{margin-bottom:3.5rem}
.section-header.center{text-align:center}
.section-header.center .section-sub{margin:0 auto}

/* ─── SERVICES ───────────────────────────────────────────── */
#services{background:var(--cream)}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.service-card{
  background:var(--white);border-radius:var(--radius-lg);
  padding:2rem 1.8rem;border:1px solid var(--border);
  transition:transform .25s,box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
  cursor: pointer;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal),var(--teal-dark));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:52px;height:52px;background:var(--teal-light);
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  margin-bottom:1.2rem;font-size:1.3rem;color:var(--teal);
}
.service-card h3{
  font-family:var(--ff-display);font-size:1.15rem;font-weight:700;
  color:var(--ink);margin-bottom:.6rem;
}
.service-card p{font-size:.88rem;color:var(--ink-soft);line-height:1.65}

/* ─── WHY US ─────────────────────────────────────────────── */ 
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.why-pills{display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
.pill{
  background:var(--teal-xlight);border-radius:var(--radius);
  padding:1.4rem;border:1px solid rgba(23,183,148,.15);
}
.pill-icon{font-size:1.2rem;color:var(--teal);margin-bottom:.5rem}
.pill h4{font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:.3rem}
.pill p{font-size:.82rem;color:var(--ink-soft);line-height:1.55}

/* ─── AWARD ──────────────────────────────────────────────── */
#award{background:var(--teal);color:#fff;text-align:center;padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,4rem); border-radius: 20px;}
#award .section-label{color:rgba(255,255,255,.65)}
#award .section-title{color:#fff}
.award-card-inner{
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-lg);
  display:inline-flex;align-items:center;gap:2rem;
  padding:2rem 3rem;margin-top:2.5rem;text-align:left;
}
.award-badge{
  width:80px;height:80px;background:rgba(255,255,255,.2);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:2rem;color:#fff;flex-shrink:0;
}
.award-text h3{font-family:var(--ff-display);font-size:1.3rem;font-weight:700;margin-bottom:.35rem;color:#fff}
.award-text p{font-size:.88rem;color:rgba(255,255,255,.75);margin-bottom:.9rem}
.award-text a{
  background:#fff;color:var(--teal);border-radius:99px;
  padding:.5rem 1.3rem;font-weight:700;font-size:.82rem;text-decoration:none;
  transition:transform .2s;display:inline-block;
}
.award-text a:hover{transform:translateY(-2px)}

/* ─── CONTACT ────────────────────────────────────────────── */
#contact{background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}
.contact-info{}
.contact-info h3{
  font-family:var(--ff-display);font-size:1.5rem;font-weight:700;
  color:var(--ink);margin-bottom:1.5rem;
}
.contact-detail{
  display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.3rem;
}
.contact-detail-icon{
  width:40px;height:40px;background:var(--teal-light);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:var(--teal);flex-shrink:0;
}
.contact-detail-text strong{display:block;font-size:.82rem;font-weight:700;color:var(--ink);letter-spacing:.03em;text-transform:uppercase;margin-bottom:.2rem}
.contact-detail-text span{font-size:.9rem;color:var(--ink-soft)}

/* Form */
.text-danger{color:var(--danger)}
.contact-form{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:.45rem;letter-spacing:.02em;text-transform:uppercase}
.form-group .required{color:var(--danger);margin-left:2px}
.form-group input,.form-group textarea,.form-group select{
  width:100%;background:var(--cream);border:1.5px solid var(--border);
  border-radius:10px;padding:.75rem 1rem;font-family:var(--ff-body);
  font-size:.92rem;color:var(--ink);outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--teal);box-shadow:0 0 0 3px rgba(23,183,148,.12);
}
.form-group textarea{resize:none;}
.form-submit{
  width:100%;background:var(--teal);color:#fff;border:none;
  border-radius:99px;padding:.9rem;font-family:var(--ff-body);font-weight:700;
  font-size:.98rem;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  position:relative;overflow:hidden;
}
.form-submit:hover:not(:disabled){background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 8px 28px rgba(23,183,148,.3)}
.form-submit:disabled{opacity:.7;cursor:not-allowed}

/* Form states */
.form-spinner{
  display:none;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.4);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;
}
.form-submit.loading .form-btn-text{display:none}
.form-submit.loading .form-spinner{display:block}

/* Thank you */
.form-thank-you{
  display:none;text-align:center;padding:2rem;
}
.form-thank-you .ty-icon{
  width:72px;height:72px;background:var(--teal-light);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:2rem;color:var(--teal);margin:0 auto 1.2rem;
  animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) forwards;
}
.form-thank-you h3{font-family:var(--ff-display);font-size:1.5rem;color:var(--ink);margin-bottom:.5rem}
.form-thank-you p{color:var(--ink-soft);font-size:.92rem}

/* ─── ERROR TOAST NOTIFICATION ──────────────────────────────── */
#formErrorMsg {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 9999;
    display: flex;
    align-items: center;
    gap: .75rem;
    background: #fff;
    border-left: 4px solid #e74c3c;
    border-radius: 12px;
    padding: .9rem 1.4rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .13);
    font-family: var(--ff-body);
    font-size: .9rem;
    color: #2c1a1a;
    max-width: 340px;
    transform: translateX(calc(100% + 3rem));
    opacity: 0;
    transition: transform .4s cubic-bezier(.175, .885, .32, 1.1),
                opacity .4s ease;
    pointer-events: none;
}
#formErrorMsg.visible {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}
#formErrorMsg i {
    color: #e74c3c;
    font-size: 1.1rem;
    flex-shrink: 0;
}
@media (max-width: 600px) {
    #formErrorMsg {
        bottom: 1rem;
        right: 1rem;
        left: 1rem;
        max-width: 100%;
        transform: translateY(calc(100% + 2rem));
    }
    #formErrorMsg.visible {
        transform: translateY(0);
    }
}

/* ─── FOOTER ─────────────────────────────────────────────── */
footer{
  border-radius: 20px;
  margin-bottom: 10px;
  background:var(--ink);color:rgba(255,255,255,.55);
}
.footer-inner{
  display:flex;align-items:center; gap:.5rem;
}
.footer-content{
  padding:2.5rem clamp(1.5rem,5vw,4rem);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  border-bottom: 1px solid rgba(255,255,255,.15);
  margin-bottom: 10px;
}
.footer-business{
    padding: 10px 10px 20px 10px;  
    text-align: center;
}
.footer-logo{font-family:var(--ff-display);font-size:1.2rem;font-weight:900;color:#fff}
.footer-logo span{color:var(--teal)}
footer p{font-size:.82rem}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{color:rgba(255,255,255,.45);font-size:.82rem;text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--teal)}

/* ─── SCROLL REVEAL ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:none}

/* ─── ANIMATIONS ─────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes popIn{
  0%{transform:scale(0);opacity:0}
  70%{transform:scale(1.15)}
  100%{transform:scale(1);opacity:1}
}
@keyframes checkDraw{
  to{stroke-dashoffset:0}
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:900px){
    .hero, #award{  margin-left:5px; margin-right: 5px; }
    .footer{ text-align: center; margin-left:5px; margin-right: 5px; }
    .footer-content{ justify-content: center; }
    .hero-main{grid-template-columns:1fr;text-align:center;padding-top:80px;overflow:hidden;width:100%;}
    .hero-content{width:100%;max-width:100%}
    .hero::before,.hero::after{display:none}
    .hero-visual{display:none}
    .hero-sub{justify-content:center;margin-left:auto;margin-right:auto;max-width:90%}
    .hero-actions,.hero-stats{justify-content:center}
    .hero-stats{display: flex;}
    .hero-stats-graphics{justify-content:center}
    .services-grid{grid-template-columns:1fr 1fr}
    .why-grid{grid-template-columns:1fr}
    .contact-grid{grid-template-columns:1fr}
    .award-card-inner{flex-direction:column;text-align:center;padding:2rem}
    .nav-links,.nav-cta{display:none}
    .nav-hamburger{display:flex}
    .reveal{opacity:1 !important;transform:none !important;transition:none !important;visibility:visible !important}
}
@media(max-width:600px){
    .services-grid{grid-template-columns:1fr}
    .form-row{grid-template-columns:1fr}
    .why-pills{grid-template-columns:1fr} 
}