:root{
  --o:#FF9F1C; --dark:#0e0e0e; --w:#f7f5f1; --m:rgba(247,245,241,.5);
  --glass:rgba(10,10,10,.55);
  --glass-border:rgba(255,255,255,.09);
  --glass-hi:rgba(255,255,255,.04);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden;background:var(--dark);color:var(--w);font-family:'DM Sans',sans-serif;cursor:none}

/* cursor */
#cur{position:fixed;z-index:9999;pointer-events:none;width:10px;height:10px;border-radius:50%;background:var(--o);transform:translate(-50%,-50%);transition:transform .15s}
#cur-r{position:fixed;z-index:9998;pointer-events:none;width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(255,159,28,.5);transform:translate(-50%,-50%);transition:transform .2s ease-out}

/* canvas */
#c3{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px 44px;background:linear-gradient(to bottom,rgba(6,6,6,.88) 0%,transparent 100%)}
.lmark{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',cursive;font-size:20px;color:#111;box-shadow:0 0 18px rgba(255,159,28,.45);flex-shrink:0}
.lname{font-family:'Bebas Neue',cursive;font-size:22px;letter-spacing:4px;margin-left:10px}
.lname em{color:var(--o);font-style:normal}
.logo{display:flex;align-items:center;text-decoration:none}
nav ul{list-style:none;display:flex;gap:28px}
nav a{color:rgba(255,255,255,.45);text-decoration:none;font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s;cursor:none}
nav a:hover{color:var(--o)}
.ncta{background:var(--o)!important;color:#111!important;padding:8px 20px;border-radius:50px;font-weight:700!important}

/* sections wrapper */
#sw{position:fixed;inset:0;z-index:10;pointer-events:none}
.sec{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:88px 52px 52px;
  opacity:0;pointer-events:none;
}
.sec.on{pointer-events:all}

/* glass card */
.glass-card{
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:24px;
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  box-shadow:0 8px 48px rgba(0,0,0,.45), inset 0 1px 0 var(--glass-hi);
  padding:40px 44px;
}

/* hero */
#s0{flex-direction:column;text-align:center;gap:0}
.htag{font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--o);margin-bottom:20px;opacity:0;transform:translateY(14px);animation:fu .7s .2s forwards}
.hh1{font-family:'Bebas Neue',cursive;font-size:clamp(62px,10vw,140px);line-height:.88;letter-spacing:2px;opacity:0;transform:translateY(22px);animation:fu .7s .4s forwards}
.hh2{font-family:'Bebas Neue',cursive;font-size:clamp(30px,5vw,70px);line-height:.88;letter-spacing:2px;opacity:0;transform:translateY(22px);animation:fu .7s .4s forwards}
.hh1 .a{color:var(--o)}
.hsub{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(14px,1.7vw,19px);color:var(--m);margin-top:18px;max-width:460px;line-height:1.65;opacity:0;transform:translateY(14px);animation:fu .7s .6s forwards}
.hact{display:flex;gap:12px;margin-top:32px;opacity:0;animation:fu .7s .8s forwards}
.btn{padding:12px 28px;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;text-decoration:none;border:none;cursor:none;transition:transform .25s,box-shadow .25s;display:inline-block}
.btn:hover{transform:translateY(-2px)}
.bf{background:var(--o);color:#111}
.bf:hover{box-shadow:0 8px 30px rgba(255,159,28,.4)}
.bg_{background:transparent;color:var(--w);border:1px solid rgba(255,255,255,.2)}
.bg_:hover{border-color:var(--o);color:var(--o)}
@keyframes fu{to{opacity:1;transform:translateY(0)}}

/* scroll nudge */
#nudge{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:200;text-align:center;opacity:1;transition:opacity .5s}
#nudge.h{opacity:0}
.nt{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--m);margin-bottom:8px}
.nw{width:20px;height:32px;border:2px solid rgba(255,255,255,.18);border-radius:10px;margin:0 auto;position:relative}
.nd{width:3px;height:7px;background:var(--o);border-radius:2px;position:absolute;left:50%;top:4px;transform:translateX(-50%);animation:ws 1.6s infinite}
@keyframes ws{0%{top:4px;opacity:1}70%{top:16px;opacity:0}100%{top:4px;opacity:0}}

/* SERVICE SECTIONS */
.ssec {align-items:center;justify-content:flex-start;}
.ssec .glass-card {
  position:absolute;
  left:5vw;
  top:50%;
  transform:translateY(-50%);
  width:48%;
  min-width:420px;
  max-width:580px;
}
.ssec.flip .glass-card {
  left:auto;
  right:5vw;
}

.sinner {display:flex;gap:24px;align-items:flex-start;width:100%;}
.sl {flex:1;}
.sr {flex:0 0 120px;display:flex;align-items:center;justify-content:center;}

.spill{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,159,28,.1);border:1px solid rgba(255,159,28,.25);
  border-radius:50px;padding:5px 15px;font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--o);margin-bottom:20px
}
.spill .sn{background:var(--o);color:#111;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.stitle{font-family:'Bebas Neue',cursive;font-size:clamp(42px,5.2vw,68px);letter-spacing:1.8px;line-height:0.92;margin-bottom:16px}
.stitle .hl{color:var(--o)}
.sdesc{font-size:14.5px;line-height:1.78;color:var(--m);margin-bottom:22px;max-width:460px}
.fl{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}
.fl li{font-size:13.2px;color:rgba(247,245,241,.55);display:flex;align-items:flex-start;gap:9px;line-height:1.65}
.fl li::before{content:'';flex-shrink:0;width:5px;height:5px;border-radius:50%;background:var(--o);margin-top:5px}

/* icon badge */
.ic{width:110px;height:110px;background:rgba(255,159,28,.08);border:1px solid rgba(255,159,28,.2);border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.ic .ii{font-size:38px}
.ic .il{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--o);text-align:center;padding:0 8px}

/* WHY section */
#s8{align-items:center;justify-content:center}
.why-wrap{width:100%;max-width:1000px}
.why-wrap .glass-card{max-width:100%}
.wh{font-family:'Bebas Neue',cursive;font-size:clamp(48px,7.2vw,94px);letter-spacing:2.4px;margin-bottom:10px}
.wh span{color:var(--o)}
.wsub{font-family:'Playfair Display',serif;font-style:italic;color:var(--m);font-size:16.5px;margin-bottom:36px}
.wg{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.wc{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:22px 18px;transition:all .3s}
.wc:hover{background:rgba(255,159,28,.07);border-color:rgba(255,159,28,.28);transform:translateY(-3px)}
.wci{font-size:24px;margin-bottom:10px}
.wc h3{font-size:13.5px;font-weight:600;margin-bottom:8px;line-height:1.4}
.wc p{font-size:12.2px;color:var(--m);line-height:1.65}

/* CONTACT */
#s9{align-items:center;justify-content:center}
.contact-wrap{width:100%;max-width:860px}
.contact-wrap .glass-card{max-width:100%}
.cinner{display:flex;gap:48px;align-items:flex-start}
.cl{flex:1}
.cl h2{font-family:'Bebas Neue',cursive;font-size:clamp(48px,6.5vw,84px);letter-spacing:2.2px;line-height:.95}
.cl h2 span{color:var(--o)}
.cl p{color:var(--m);font-size:14px;line-height:1.75;margin-top:16px;max-width:340px}
.ci{font-family:'Playfair Display',serif;font-style:italic;color:rgba(255,159,28,.65)!important;margin-top:12px!important}
.cf{flex:1;display:flex;flex-direction:column;gap:10px}
.cf input,.cf textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:14px 18px;color:var(--w);font-family:'DM Sans',sans-serif;font-size:14.5px;outline:none;transition:border-color .3s,box-shadow .3s}
.cf input:focus,.cf textarea:focus{border-color:var(--o);box-shadow:0 0 0 3px rgba(255,159,28,.1)}
.cf textarea{min-height:90px;resize:vertical}
.cf button{background:var(--o);color:#111;border:none;border-radius:50px;padding:14px 32px;font-family:'DM Sans',sans-serif;font-size:14.5px;font-weight:700;cursor:none;transition:all .3s}
.cf button:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,159,28,.4)}

/* progress track */
#pt{position:fixed;right:22px;top:50%;transform:translateY(-50%);z-index:200;display:flex;flex-direction:column;align-items:center}
.tl{width:1px;height:18px;background:rgba(255,255,255,.1)}
.td{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.18);cursor:none;transition:all .35s}
.td.active{background:var(--o);border-color:var(--o);box-shadow:0 0 8px var(--o);transform:scale(1.4)}
.td.past{background:rgba(255,159,28,.4);border-color:rgba(255,159,28,.4)}

/* counter */
#ctr{position:fixed;left:28px;bottom:28px;z-index:200;font-family:'Bebas Neue',cursive;font-size:11px;letter-spacing:3px;color:rgba(255,255,255,.2)}
#ctr .cc{font-size:21px;color:var(--o)}

/* tree label */
#tlbl{position:fixed;left:50%;bottom:60px;transform:translateX(-50%);z-index:200;font-size:9px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,159,28,.55);opacity:0;transition:opacity .5s;white-space:nowrap}
#tlbl.show{opacity:1}

@media(max-width:768px){
  nav ul{display:none}nav{padding:14px 18px}
  .ssec .glass-card,.ssec.flip .glass-card{position:relative;left:auto;right:auto;top:auto;transform:none;width:100%;min-width:unset;max-width:100%;padding:28px 22px}
  .sinner{flex-direction:column;gap:16px}.sr{display:none}
  .fl{grid-template-columns:1fr}
  .wg{grid-template-columns:1fr 1fr}
  .cinner{flex-direction:column}
  .sec{padding:70px 16px 36px}
}
/* ── Custom Checkboxes for Services ──────────────────────────────── */

.checkbox-group {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 15px 0 25px;
}

.check-label {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14.5px;
  color: var(--w);
  cursor: pointer;
  user-select: none;
  transition: all .2s;
}

.check-label:hover {
  color: var(--o);
}

.check-label input[type="checkbox"] {
  appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255,255,255,.3);
  border-radius: 6px;
  background: rgba(255,255,255,.05);
  cursor: pointer;
  position: relative;
  transition: all .25s ease;
}

.check-label input[type="checkbox"]:checked {
  background: var(--o);
  border-color: var(--o);
}

.check-label input[type="checkbox"]:checked::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #111;
  font-size: 14px;
  font-weight: bold;
}

.check-label input[type="checkbox"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,159,28,.25);
}

/* Hover box color */
.check-label:hover input[type="checkbox"] {
  background: rgba(255,159,28,.25);
  border-color: var(--o);
}

/* Hover tick (faint) */
.check-label:hover input[type="checkbox"]::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  font-size: 14px;
  color: rgba(0,0,0,.8);
}

.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(8px);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
.modal-content {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 32px;
  max-width: 420px;
  width: 90%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  backdrop-filter: blur(20px);
}
.modal-success .modal-content {
  border-color: #2a6b24;
}
.modal-error .modal-content {
  border-color: #8b2a2a;
}
.modal h2 {
  margin: 0 0 16px;
  font-family: 'Bebas Neue', cursive;
  font-size: 38px;
  letter-spacing: 1px;
}
.modal-success h2 { color: #4caf50; }
.modal-error h2   { color: #ff5252; }
.modal p {
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--m);
}
.modal button {
  background: var(--o);
  color: #111;
  border: none;
  padding: 12px 32px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all .25s;
}
.modal button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(255,159,28,0.4);
}

/* Checkbox styles (already good, keeping them) */
.checkbox-group { display:flex; flex-direction:column; gap:14px; margin:8px 0 28px; }
.check-label { display:flex; align-items:center; gap:12px; font-size:14.5px; color:var(--w); cursor:pointer; transition:all .2s; }
.check-label:hover { color:var(--o); }
.check-label input[type="checkbox"] { appearance:none; width:20px; height:20px; border:2px solid rgba(255,255,255,.3); border-radius:6px; background:rgba(255,255,255,.05); cursor:pointer; position:relative; transition:all .25s; }
.check-label input[type="checkbox"]:checked { background:var(--o); border-color:var(--o); }
.check-label input[type="checkbox"]:checked::after { content:'✓'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:#111; font-size:14px; font-weight:bold; }
.checkbox-question { font-size:15px; font-weight:500; color:var(--o); margin-bottom:12px; letter-spacing:0.5px; }
.form-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:.35s;
  z-index:9999;
}

.form-modal.show{
  opacity:1;
  pointer-events:auto;
}

.form-modal-box{
  background:#111;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:28px 34px;
  max-width:420px;
  text-align:center;
  color:#fff;
  box-shadow:0 15px 60px rgba(0,0,0,.6);
}

.form-modal-box.success{
  border-color:#3A8228;
}

.form-modal-box.error{
  border-color:#c0392b;
}

#modalClose{
  position:absolute;
  right:18px;
  top:12px;
  cursor:pointer;
  font-size:22px;
  opacity:.6;
}

#modalClose:hover{
  opacity:1;
}

.lmark img{
  width:32px;
  height:32px;
}