:root{
  --green:#075755;
  --brown:#44210D;
  --brownDark:#2A1208;
  --cream:#FAF9F6;
  --beige:#F1E7DC;
  --text:#1f1f1f;
}
*{box-sizing:border-box}
::selection{background:var(--green);color:#fff}
html,body{height:100%}
body{
  margin:0; background:var(--cream); color:var(--text);
  font-family:'Unbounded',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  cursor:none; overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
p{line-height:1.6;margin:0}

.cursor-dot{
  position:fixed; top:0; left:0; width:10px; height:10px; border-radius:999px;
  background:var(--green); transform:translate(-50%,-50%); pointer-events:none; z-index:9999;
  box-shadow:0 0 0 4px rgba(7,87,85,.12);
}
h1,h2,h3{font-family:'Aladin',cursive;color:var(--brown);margin:0}
.section{padding:4.4rem 1rem}
.container{max-width:1120px;margin:0 auto}
.section-title{text-align:center;font-size:clamp(2.9rem,4.9vw,3.7rem)}
.section-sub{
  text-align:center;max-width:940px;margin:1rem auto 0;opacity:.92
}
.center-stack{display:flex;flex-direction:column;align-items:center;text-align:center}

.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(250,249,246,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(42,18,8,.12);
}
.navbar{
  max-width:1200px;margin:0 auto;padding:.9rem 1rem;
  display:flex;align-items:center;justify-content:space-between;
}
.brand img{width:185px;height:52px;object-fit:contain}
.nav-links{display:flex;gap:1.6rem;justify-content:flex-end;align-items:center}
.nav-link{
  position:relative;color:var(--brownDark);font-weight:700;padding:.2rem 0;
  transition:transform .2s ease,color .2s ease;
}
.nav-link::after{
  content:"";position:absolute;left:0;bottom:-6px;height:3px;width:100%;
  background:var(--green);border-radius:999px;transform:scaleX(0);
  transform-origin:left;transition:transform .25s ease;
}
.nav-link:hover{color:var(--green);transform:translateY(-2px)}
.nav-link:hover::after{transform:scaleX(1)}

.hamburger{display:none;width:44px;height:44px;border:0;background:transparent;cursor:none;position:relative}
.hamburger span{
  position:absolute;left:10px;right:10px;height:3px;border-radius:999px;
  background:var(--brownDark);transition:transform .25s ease,top .25s ease,opacity .2s ease,background .2s ease;
}
.hamburger span:nth-child(1){top:14px}
.hamburger span:nth-child(2){top:20.5px}
.hamburger span:nth-child(3){top:27px}
.hamburger.open span{background:var(--green)}
.hamburger.open span:nth-child(1){top:20.5px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:20.5px;transform:rotate(-45deg)}

.mobile-menu{display:none;max-width:1200px;margin:0 auto;padding:0 1rem 1rem;overflow:hidden}
.mobile-inner{
  background:rgba(255,255,255,.55);border:1px solid rgba(42,18,8,.10);
  border-radius:16px;padding:.4rem .8rem;
}
.mobile-inner a{
  display:block;padding:.95rem .25rem;color:var(--brownDark);font-weight:800;
  border-top:1px solid rgba(42,18,8,.08);transition:transform .2s ease,color .2s ease;
}
.mobile-inner a:first-child{border-top:0}
.mobile-inner a:hover{color:var(--green);transform:translateY(-2px)}

.hero{padding:3.2rem 1rem 2.2rem;text-align:center}
.hero-inner{max-width:980px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.85rem}
.hero-graphic{
  width:min(520px,88vw);height:auto;filter:drop-shadow(0 18px 35px rgba(0,0,0,.08));cursor:none
}
.hero-title{font-size:clamp(3.2rem,6.1vw,4.3rem)}
.badges{display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center}
.badge-pill{
  background:rgba(241,231,220,.9);border:1px solid rgba(42,18,8,.10);
  border-radius:999px;padding:.5rem .85rem;font-weight:800;color:var(--brownDark)
}
.hero-tagline{font-family:'Aladin',cursive;font-size:2.15rem;color:var(--brown)}
.hero-lead{font-size:clamp(1.02rem,2.2vw,1.18rem);max-width:880px}
.scroll-hint{
  margin-top:1rem;width:46px;height:46px;border-radius:999px;border:1px solid rgba(42,18,8,.18);
  display:flex;align-items:center;justify-content:center;opacity:.9
}
.scroll-line{width:2px;height:16px;background:rgba(42,18,8,.55);border-radius:999px;transform:translateY(-2px)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1.02rem 1.45rem;border-radius:14px;border:0;
  font-family:'Aladin',cursive;font-size:1.95rem;
  background:var(--brown);color:#fff;cursor:none;
  box-shadow:0 14px 30px rgba(68,33,13,.22);
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  will-change:transform;
}
.btn:hover{background:var(--green);box-shadow:0 18px 34px rgba(7,87,85,.24)}
.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 1.15rem;border-radius:14px;border:2px solid var(--brown);
  background:transparent;color:var(--brownDark);font-weight:800;cursor:none;
  transition:transform .2s ease,color .2s ease,border-color .2s ease;
}
.btn-outline:hover{color:var(--green);border-color:var(--green);transform:translateY(-2px)}

.media{
  display:grid;grid-template-columns:1.1fr .9fr;gap:2.2rem;align-items:center;margin-top:2rem
}
.graphic{
  width:100%;height:auto;max-height:360px;object-fit:contain;
  filter:drop-shadow(0 18px 35px rgba(0,0,0,.06));
}
.graphic.sm{max-height:260px}

.why-list{list-style:none;padding-left:0;margin:1.6rem 0 0}
.why-list li{
  padding:1.1rem 1.15rem;margin-bottom:.9rem;border-radius:16px;
  background:rgba(255,255,255,.75);box-shadow:0 10px 25px rgba(0,0,0,.04);
  font-size:1.14rem
}
.why-strong{color:var(--green);font-weight:900}

.cards{
  display:grid;grid-template-columns:repeat(12,1fr);gap:1.25rem;margin-top:2rem
}
.card{
  grid-column:span 4;background:#fff;border-radius:18px;padding:1.7rem 1.4rem;
  box-shadow:0 10px 25px rgba(0,0,0,.05);min-height:285px;
  display:flex;flex-direction:column;justify-content:center;text-align:center;
  transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;
  position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:-40%;left:-60%;width:40%;height:180%;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.38),rgba(255,255,255,0));
  transform:rotate(25deg);opacity:0;
}
.card h3{font-size:2.25rem;line-height:1.05;word-break:break-word;overflow-wrap:anywhere}
.card p{margin-top:.95rem;font-size:1.03rem;opacity:.95}
.card:hover{background:var(--green);color:#fff;transform:translateY(-7px);box-shadow:0 18px 32px rgba(0,0,0,.08)}
.card:hover h3{color:#fff}
.card:hover::before{opacity:1;animation:shine .9s ease forwards}
@keyframes shine{0%{left:-60%}100%{left:140%}}

.card.narrow{grid-column:span 3}
.card.wide{grid-column:span 6}

.about-box{
  background:rgba(255,255,255,.70);border:1px solid rgba(42,18,8,.08);
  border-radius:22px;padding:2rem 1.4rem;box-shadow:0 14px 35px rgba(0,0,0,.05);
}

.timeline{margin-top:1.8rem;position:relative}
.line{
  position:absolute;top:62px;left:46px;right:46px;height:4px;border-radius:999px;
  background:rgba(42,18,8,.12);overflow:hidden;pointer-events:none;
}
.line-fill{width:100%;height:100%;background:rgba(7,87,85,.65);transform:scaleX(0);transform-origin:left}
.steps{display:flex;gap:1.4rem;justify-content:space-between;position:relative;z-index:1}
.step{
  flex:1;background:#fff;border-radius:18px;padding:1.55rem 1.2rem;min-height:270px;
  box-shadow:0 10px 25px rgba(0,0,0,.05);text-align:center;transition:transform .2s ease;
}
.step:hover{transform:translateY(-6px)}
.icon{
  width:92px;height:92px;border-radius:999px;background:rgba(7,87,85,.10);
  margin:0 auto .95rem;display:flex;align-items:center;justify-content:center;overflow:hidden
}
.icon img{width:64px;height:64px;object-fit:contain;opacity:.95}

.faq{margin-top:2rem;display:flex;flex-direction:column;gap:.9rem}
.faq-item{border-radius:18px;overflow:hidden;border:1px solid rgba(42,18,8,.10);background:var(--beige)}
.faq-btn{
  width:100%;text-align:left;padding:1.05rem 1.1rem;background:transparent;border:0;
  font-weight:800;color:var(--brownDark);display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:none
}
.faq-btn span{font-family:'Unbounded',sans-serif;font-size:1rem}
.faq-ic{
  width:36px;height:36px;border-radius:999px;background:rgba(42,18,8,.10);
  display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease;
}
.faq-ic::before{content:"+";font-weight:900;color:var(--brownDark)}
.faq-panel{height:0;overflow:hidden}
.faq-inner{padding:0 1.1rem 1.15rem;color:rgba(31,31,31,.92);font-size:.98rem}
.faq-item.active{background:var(--green);border-color:rgba(7,87,85,.45)}
.faq-item.active .faq-btn{color:#fff}
.faq-item.active .faq-ic{background:rgba(255,255,255,.22);transform:rotate(45deg)}
.faq-item.active .faq-ic::before{color:#fff}
.faq-item.active .faq-inner{color:rgba(255,255,255,.95)}

.actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.2rem}

.reveal-item{opacity:0;transform:translateY(18px)}

.footer{
  background:var(--brown);color:#fff;padding:3.2rem 1rem;position:relative;overflow:hidden
}
.footer-bg{position:absolute;inset:0;opacity:.18;pointer-events:none;display:flex;justify-content:flex-end;align-items:flex-end}
.footer-bg img{width:min(560px,88vw);height:auto;object-fit:contain;transform:translate(6%,14%)}
.footer-inner{
  max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  position:relative;z-index:1
}
.footer-brand{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start}
.footer-brand img{width:210px;height:auto;object-fit:contain}
.footer-tag{max-width:520px;opacity:.92;font-size:.98rem}
.footer-links{display:flex;flex-direction:column;gap:.55rem;opacity:.92}
.footer-links a{color:#fff;text-decoration:underline;text-underline-offset:4px}
.footer-copy{opacity:.92;font-size:.95rem}

/* enquiry */
.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.2rem}
.form-sec{
  grid-column:span 6;background:rgba(255,255,255,.70);border:1px solid rgba(42,18,8,.08);
  border-radius:18px;padding:1.2rem 1.1rem
}
.form-title{font-size:2.2rem;margin-bottom:.8rem;color:var(--brown);font-family:'Aladin',cursive}
.label{display:block;font-weight:800;font-size:.92rem;color:var(--brownDark);margin:.9rem 0 .35rem}
.input{
  width:100%;padding:.9rem .95rem;border-radius:14px;border:1px solid rgba(42,18,8,.14);
  background:rgba(250,249,246,.8);outline:none;font-family:'Unbounded',sans-serif;font-size:.92rem;
  transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;cursor:none
}
.input:focus{border-color:rgba(7,87,85,.45);box-shadow:0 0 0 4px rgba(7,87,85,.12)}
.row{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.4rem}
.pill{
  display:flex;gap:.55rem;align-items:center;background:rgba(241,231,220,.85);
  border:1px solid rgba(42,18,8,.10);border-radius:999px;padding:.55rem .8rem;
  font-weight:800;color:var(--brownDark);cursor:none
}
.pill input{accent-color:var(--green)}
.pill input[type="checkbox"]{width:16px;height:16px;accent-color:var(--brown)}
.btn.submitted{background:var(--green)!important;color:#fff!important;box-shadow:0 18px 34px rgba(7,87,85,.24)!important}

@media (max-width:992px){
  .media{grid-template-columns:1fr}
  .card{grid-column:span 6}
  .card.narrow,.card.wide{grid-column:span 12}
  .line{display:none}
  .steps{flex-direction:column}
  .form-sec{grid-column:span 12}
}
@media (max-width:768px){
  .nav-links{display:none}
  .hamburger{display:block}
  .mobile-menu{display:block}
  .card{grid-column:span 12}
  .brand img{width:160px}
  .footer-inner{flex-direction:column;align-items:flex-start}
}


.cards-center{max-width:980px;margin:2rem auto 0;}


/* active nav item */
.nav-link.active{
  color: var(--green);
  transform: translateY(-2px);
}
.nav-link.active::after{ transform: scaleX(1); }

/* footer tweaks */
.footer-links a{ font-size: 1.05rem; }
.footer-tag .brew{ color: var(--green); font-weight: 900; }

/* make navbar feel tighter + centered on mobile */
.navbar{ min-height: 74px; }
.brand{ display:flex; align-items:center; }
.hamburger{ align-items:center; justify-content:center; }

/* hide custom cursor on touch devices */
@media (hover: none) and (pointer: coarse){
  body{ cursor: auto; }
  .cursor-dot{ display:none; }
}
