@font-face {
  font-family: 'SpecialGothic';
  src: url('SpecialGothicExpandedOne-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800&family=Barlow:wght@300;400;500;600&display=swap');

:root {
  --green:      #3ddc6e;
  --green-glow: rgba(61,220,110,0.3);
  --bg:         #090f0b;
  --bg2:        #0c1510;
  --bg3:        #101a12;
  --card:       #0d1810;
  --border:     rgba(61,220,110,0.2);
  --border-hi:  rgba(61,220,110,0.55);
  --white:      #ffffff;
  --muted:      #5a8060;
  --text:       #a8c8ae;
  --nav-h:      60px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Barlow',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}

/* ── HEADING FONT ── */
.hf{font-family:'SpecialGothic','Barlow Condensed',sans-serif;font-weight:normal;text-transform:uppercase}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;padding:0 40px;background:rgba(9,15,11,0.97);border-bottom:1px solid rgba(61,220,110,0.08);backdrop-filter:blur(12px)}
.nav-inner{width:100%;max-width:1260px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.85rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--white);transition:color 0.2s}
.nav-links a:hover{color:var(--green)}
.nav-links a.active{color:var(--white)}
.nav-cta{background:var(--green)!important;color:var(--bg)!important;padding:8px 20px;border-radius:4px;font-weight:800!important;transition:background 0.2s,box-shadow 0.2s!important;font-size:0.82rem!important}
.nav-cta:hover{background:#52f080!important;box-shadow:0 0 16px var(--green-glow)!important}
/* ── NAV WORDMARK ── */
.nav-wordmark{display:flex;flex-direction:column;line-height:1;gap:1px}
.nw-main{font-family:'SpecialGothic','Barlow Condensed',sans-serif;font-size:1rem;font-weight:normal;text-transform:uppercase;color:var(--white);letter-spacing:0.04em}
.nw-sub{font-family:'Barlow',sans-serif;font-size:0.6rem;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--green)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:0.3s}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── PAGE HEADER ── */
.page-header{padding:calc(var(--nav-h) + 44px) 40px 40px;border-bottom:1px solid rgba(61,220,110,0.08)}
.page-header-inner{max-width:1260px;margin:0 auto}
.eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--green);margin-bottom:8px}
.page-header h1{font-size:clamp(2.2rem,5vw,3.4rem);line-height:1;margin-bottom:12px;color:var(--white)}
.page-header .sub{font-size:0.9rem;color:var(--muted);max-width:560px;line-height:1.7}
.breadcrumb{display:flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.breadcrumb a{color:var(--muted);transition:color 0.2s}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb .arr{color:var(--green)}

/* ── LAYOUT ── */
.wrap{max-width:1260px;margin:0 auto;padding:0 40px}
.section{padding:72px 0}
.section-sm{padding:48px 0}
.section-label{font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--green);margin-bottom:8px}
.section-title{font-size:clamp(1.7rem,3.5vw,2.5rem);line-height:1.05;margin-bottom:10px;color:var(--white)}
.section-sub{font-size:0.9rem;color:var(--muted);max-width:540px;line-height:1.7}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:12px 24px;border-radius:4px;border:none;cursor:pointer;font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;transition:all 0.2s}
.btn-green{background:var(--green);color:var(--bg)}
.btn-green:hover{background:#52f080;box-shadow:0 0 22px var(--green-glow)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.25)}
.btn-outline:hover{border-color:var(--green);color:var(--green)}
.btn-full{width:100%;justify-content:center}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:var(--nav-h);text-align:center;background:radial-gradient(ellipse 70% 55% at 50% 38%,rgba(61,220,110,0.07) 0%,transparent 70%)}
.hero-location{font-family:'Barlow Condensed',sans-serif;font-size:0.78rem;font-weight:700;letter-spacing:0.32em;text-transform:uppercase;color:var(--green);margin-bottom:22px}
.hero h1{font-size:clamp(4rem,12vw,9rem);line-height:0.88;margin-bottom:28px}
.hero h1 .line1{display:block;color:var(--white)}
.hero h1 .line2{display:block;color:var(--green);text-shadow:0 0 50px rgba(61,220,110,0.45)}
.hero-sub{font-size:0.95rem;color:var(--muted);max-width:400px;margin:0 auto 36px;line-height:1.7}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero-divider{width:100px;height:1px;background:rgba(61,220,110,0.18);margin:52px auto 40px}
.hero-stats{display:flex;gap:60px;justify-content:center;flex-wrap:wrap}
.stat{text-align:center}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-size:2.2rem;font-weight:900;color:var(--green);display:block;line-height:1;text-shadow:0 0 20px rgba(61,220,110,0.35)}
.stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-top:5px;display:block}

/* ── SERVICE CARDS 5-col ── */
.svc-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:13px}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:7px;padding:20px 16px 18px;display:flex;flex-direction:column;position:relative;transition:border-color 0.3s,box-shadow 0.3s,transform 0.25s}
.svc-card:hover{border-color:var(--border-hi);box-shadow:0 0 30px rgba(61,220,110,0.08);transform:translateY(-3px)}
.svc-badge{position:absolute;top:11px;right:11px;background:var(--green);color:var(--bg);font-family:'Barlow Condensed',sans-serif;font-size:0.6rem;font-weight:900;letter-spacing:0.1em;text-transform:uppercase;padding:3px 9px;border-radius:20px}
.svc-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--green);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:0.75rem;margin-bottom:14px;flex-shrink:0}
.svc-name{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:800;text-transform:uppercase;color:var(--white);line-height:1.05;margin-bottom:10px}
.svc-desc{font-size:0.78rem;color:var(--muted);line-height:1.55;flex:1;margin-bottom:20px}
.svc-price{font-family:'Barlow Condensed',sans-serif;font-size:0.95rem;font-weight:800;color:var(--green);margin-bottom:8px}
.svc-book{display:inline-flex;align-items:center;gap:5px;font-family:'Barlow Condensed',sans-serif;font-size:0.78rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);transition:gap 0.2s}
.svc-book:hover{gap:9px}
.view-all-link{text-align:center;margin-top:28px;font-size:0.84rem;color:var(--muted)}
.view-all-link a{color:var(--muted);transition:color 0.2s;display:inline-flex;align-items:center;gap:5px}
.view-all-link a:hover{color:var(--green)}

/* ── SERVICE CARDS 3-col ── */
.svc-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.svc-card2{background:var(--card);border:1px solid var(--border);border-radius:7px;padding:26px;display:flex;flex-direction:column;transition:border-color 0.25s,box-shadow 0.25s}
.svc-card2:hover{border-color:var(--border-hi);box-shadow:0 0 20px rgba(61,220,110,0.07)}
.svc-card2 .c2-name{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;text-transform:uppercase;color:var(--white);margin-bottom:10px}
.svc-card2 .c2-desc{font-size:0.86rem;color:var(--muted);line-height:1.6;flex:1;margin-bottom:20px}
.svc-card2 .c2-row{display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(61,220,110,0.08);padding-top:16px}
.svc-card2 .c2-price{font-family:'Barlow Condensed',sans-serif;font-weight:800;color:var(--green);font-size:0.95rem}
.svc-card2 .c2-link{font-family:'Barlow Condensed',sans-serif;font-size:0.76rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:4px;transition:gap 0.2s}
.svc-card2 .c2-link:hover{gap:8px}

/* ── PRICE TABLE ── */
.ptable-wrap{overflow-x:auto}
.ptable{width:100%;border-collapse:collapse;font-size:0.86rem;min-width:360px}
.ptable th{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);padding:10px 14px;text-align:left;border-bottom:1px solid rgba(61,220,110,0.1)}
.ptable td{padding:10px 14px;color:var(--text);border-bottom:1px solid rgba(255,255,255,0.04)}
.ptable td.gp{color:var(--green);font-weight:700;font-family:'Barlow Condensed',sans-serif;font-size:0.92rem}
.ptable tr:last-child td{border-bottom:none}
.ptable tr:hover td{background:rgba(61,220,110,0.025)}

/* ── CALCULATOR ── */
.calc-box{background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.calc-head{padding:18px 22px;border-bottom:1px solid rgba(61,220,110,0.1)}
.calc-head .cl{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.28em;text-transform:uppercase;color:var(--green);margin-bottom:4px}
.calc-head .ct{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:800;text-transform:uppercase;color:var(--white)}
.calc-body{padding:20px 22px}
.calc-field{margin-bottom:14px}
.calc-field label{display:block;font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.calc-field select{width:100%;background:var(--bg3);border:1px solid rgba(61,220,110,0.14);color:var(--white);padding:10px 34px 10px 13px;font-family:'Barlow',sans-serif;font-size:0.87rem;border-radius:4px;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%233ddc6e' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color 0.2s}
.calc-field select:focus{border-color:var(--green)}
.calc-result{background:var(--bg);border:1px solid rgba(61,220,110,0.1);border-radius:5px;padding:16px;text-align:center;margin-bottom:10px}
.calc-result-lbl{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.calc-price-val{font-family:'Barlow Condensed',sans-serif;font-size:2.6rem;font-weight:900;color:var(--green);line-height:1;text-shadow:0 0 28px rgba(61,220,110,0.4);display:block}
.calc-bar{width:24px;height:2px;background:var(--green);margin:8px auto 0}
/* instalment row */
.calc-splits{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.split-opt input[type="radio"]{display:none}
.split-lbl{display:block;background:var(--bg3);border:1px solid rgba(61,220,110,0.14);border-radius:4px;padding:8px 10px;cursor:pointer;text-align:center;transition:border-color 0.2s,background 0.2s}
.split-opt input:checked + .split-lbl{border-color:var(--green);background:rgba(61,220,110,0.07)}
.split-lbl:hover{border-color:rgba(61,220,110,0.4)}
.split-title{font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;text-transform:uppercase;color:var(--white);display:block}
.split-amount{font-size:0.76rem;color:var(--green);display:block;margin-top:2px}

/* ── FEATURE LIST ── */
.feature-list{display:flex;flex-direction:column;gap:10px}
.feature-item{background:var(--card);border:1px solid rgba(61,220,110,0.1);border-radius:6px;padding:15px 17px;display:flex;gap:11px;align-items:flex-start;transition:border-color 0.2s}
.feature-item:hover{border-color:var(--border)}
.fi-check{color:var(--green);font-size:0.85rem;flex-shrink:0;margin-top:2px}
.fi-title{font-family:'Barlow Condensed',sans-serif;font-size:0.9rem;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:0.04em;margin-bottom:2px}
.fi-desc{font-size:0.8rem;color:var(--muted);line-height:1.5}

/* ── INCLUDE LIST ── */
.include-box{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:4px 22px;margin-bottom:14px}
.include-box li{display:flex;align-items:flex-start;gap:10px;font-size:0.86rem;color:var(--text);padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.include-box li:last-child{border-bottom:none}
.include-box li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0}
.duration-box{background:var(--card);border:1px solid rgba(61,220,110,0.12);border-radius:6px;padding:14px 18px;display:flex;align-items:center;gap:11px;margin-bottom:22px}
.dur-dot{width:9px;height:9px;border-radius:50%;border:2px solid var(--green);flex-shrink:0}
.dur-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:1px}
.dur-val{font-size:0.88rem;color:var(--white)}

/* ── PRICING SIDEBAR ── */
.pricing-sidebar{display:flex;flex-direction:column;gap:14px}
.price-card{background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.price-card-head{background:rgba(61,220,110,0.06);padding:13px 18px;border-bottom:1px solid rgba(61,220,110,0.1)}
.price-card-head .pch-lbl{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--green)}
.price-card-body{padding:14px 18px}
.starting-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:22px 18px;text-align:center}
.sc-lbl{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.sc-price{font-family:'Barlow Condensed',sans-serif;font-size:3rem;font-weight:900;color:var(--green);line-height:1;text-shadow:0 0 32px rgba(61,220,110,0.38);display:block;margin-bottom:4px}
.sc-note{font-size:0.8rem;color:var(--muted);display:block;margin-bottom:18px}

/* ── REVIEWS CAROUSEL ── */
.carousel-wrap{position:relative;overflow:hidden}
.carousel-track{display:flex;transition:transform 0.45s cubic-bezier(0.25,0.46,0.45,0.94)}
.review-card{background:var(--card);border:1px solid rgba(61,220,110,0.14);border-radius:8px;padding:24px;flex:0 0 calc(33.333% - 12px);margin-right:18px;transition:border-color 0.2s}
.review-card:hover{border-color:rgba(61,220,110,0.38)}
.review-stars{color:var(--green);letter-spacing:3px;font-size:0.75rem;margin-bottom:10px}
.review-text{font-size:0.84rem;line-height:1.7;color:var(--text);margin-bottom:14px;font-style:italic}
.review-author{font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:0.06em}
.carousel-controls{display:flex;align-items:center;gap:14px;margin-top:28px;justify-content:center}
.carousel-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--card);color:var(--green);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all 0.2s}
.carousel-btn:hover{border-color:var(--green);background:rgba(61,220,110,0.08)}
.carousel-dots{display:flex;gap:6px}
.cdot{width:6px;height:6px;border-radius:50%;background:rgba(61,220,110,0.2);cursor:pointer;transition:background 0.2s,width 0.2s}
.cdot.active{background:var(--green);width:18px;border-radius:3px}

/* ── FORM FIELDS ── */
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:0.83rem;color:var(--text);margin-bottom:6px;font-weight:500}
.form-field label .req{color:var(--green)}
.form-field input,.form-field textarea,.form-field select{width:100%;background:var(--bg3);border:1px solid rgba(61,220,110,0.14);color:var(--white);padding:11px 13px;font-family:'Barlow',sans-serif;font-size:0.88rem;border-radius:4px;outline:none;transition:border-color 0.2s;appearance:none}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--green)}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted)}
.form-field textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checkbox-row{display:flex;align-items:center;gap:10px;font-size:0.85rem;color:var(--muted);margin-bottom:20px}
.checkbox-row input{accent-color:var(--green);width:14px;height:14px;cursor:pointer}

/* ── CONTACT INFO CARDS ── */
.info-card{background:var(--card);border:1px solid var(--border);border-radius:7px;padding:20px;margin-bottom:12px}
.info-card .ic-lbl{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--green);margin-bottom:8px}
.info-card p{font-size:0.85rem;color:var(--muted);line-height:1.6;margin-bottom:5px}
.info-card .ic-val{color:var(--white);font-weight:700;font-size:0.9rem;display:block}
.info-card a{color:var(--green)}

/* ── BOOKING ── */
.radio-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}
.radio-opt input[type="radio"]{display:none}
.radio-lbl{display:flex;align-items:flex-start;gap:10px;background:var(--card);border:1px solid rgba(61,220,110,0.14);border-radius:6px;padding:13px 15px;cursor:pointer;transition:border-color 0.2s,background 0.2s}
.radio-opt input:checked + .radio-lbl{border-color:var(--green);background:rgba(61,220,110,0.06)}
.radio-lbl:hover{border-color:rgba(61,220,110,0.38)}
.radio-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(61,220,110,0.35);flex-shrink:0;margin-top:3px;transition:all 0.2s;position:relative}
.radio-opt input:checked + .radio-lbl .radio-dot{border-color:var(--green);background:var(--green)}
.radio-opt input:checked + .radio-lbl .radio-dot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:5px;height:5px;border-radius:50%;background:var(--bg)}
.radio-name{font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:700;text-transform:uppercase;color:var(--white);display:block;margin-bottom:2px}
.radio-price{font-size:0.76rem;color:var(--green)}
.addon-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.addon-opt input[type="checkbox"]{display:none}
.addon-lbl{display:flex;align-items:flex-start;gap:10px;background:var(--card);border:1px solid rgba(61,220,110,0.1);border-radius:6px;padding:12px 13px;cursor:pointer;transition:border-color 0.2s}
.addon-opt input:checked + .addon-lbl{border-color:var(--green);background:rgba(61,220,110,0.05)}
.addon-lbl:hover{border-color:rgba(61,220,110,0.32)}
.addon-check{width:14px;height:14px;border:2px solid rgba(61,220,110,0.3);border-radius:2px;flex-shrink:0;margin-top:3px;transition:all 0.2s}
.addon-opt input:checked + .addon-lbl .addon-check{background:var(--green);border-color:var(--green);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8'%3E%3Cpath d='M1 4l3 3 5-6' stroke='%23090f0b' stroke-width='1.8' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.addon-name{font-family:'Barlow Condensed',sans-serif;font-size:0.84rem;font-weight:700;text-transform:uppercase;color:var(--white);display:block;margin-bottom:1px}
.addon-price{font-size:0.74rem;color:var(--green)}
.step-hd{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:0.08em;margin:26px 0 13px}

/* ── WHY CHOOSE US ── */
.wcu-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:12px}
.wcu-card h3{font-family:'Barlow Condensed',sans-serif;font-size:0.85rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--white);margin-bottom:13px}
.wcu-list{display:flex;flex-direction:column;gap:9px}
.wcu-list li{display:flex;gap:9px;align-items:flex-start;font-size:0.83rem;color:var(--text);line-height:1.5}
.wcu-list li::before{content:'✓';color:var(--green);flex-shrink:0;font-weight:700;font-size:0.82rem}

/* ── NOTICE ── */
.notice{background:rgba(61,220,110,0.05);border-left:3px solid var(--green);border-radius:2px;padding:13px 17px;font-size:0.83rem;color:var(--muted);margin-bottom:18px}
.notice strong{color:var(--text)}

/* ── FORM MSG ── */
.form-msg{padding:13px 17px;border-radius:4px;font-size:0.86rem;display:none;align-items:center;gap:8px;margin-bottom:14px}
.form-msg.success{background:rgba(61,220,110,0.09);border:1px solid rgba(61,220,110,0.28);color:var(--green);display:flex}
.form-msg.error{background:rgba(220,61,61,0.09);border:1px solid rgba(220,61,61,0.28);color:#ff7070;display:flex}

/* ── CTA STRIP ── */
.cta-strip{background:var(--bg2);border-top:1px solid rgba(61,220,110,0.1);border-bottom:1px solid rgba(61,220,110,0.1);padding:52px 40px;text-align:center}
.cta-strip h2{font-size:clamp(1.7rem,3.5vw,2.5rem);color:var(--white);margin-bottom:10px}
.cta-strip p{font-size:0.9rem;color:var(--muted);margin-bottom:26px}
.cta-strip .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── PAYMENT BADGE ── */
.pay-flex-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(61,220,110,0.08);border:1px solid rgba(61,220,110,0.2);border-radius:4px;padding:5px 12px;font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-bottom:10px}

/* ── FOOTER ── */
.footer{background:var(--bg2);border-top:1px solid rgba(61,220,110,0.08);padding:56px 40px 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{height:38px;margin-bottom:13px}
.footer-wordmark{display:flex;flex-direction:column;line-height:1;gap:2px;margin-bottom:14px}
.fw-main{font-family:'SpecialGothic','Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:normal;text-transform:uppercase;color:var(--white);letter-spacing:0.04em}
.fw-sub{font-family:'Barlow',sans-serif;font-size:0.65rem;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--green)}
.footer-tag{font-size:0.83rem;color:var(--muted);line-height:1.7;max-width:230px;margin-bottom:18px}
.footer-social{display:flex;gap:8px}
.footer-social a{width:31px;height:31px;border:1px solid rgba(61,220,110,0.16);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.72rem;color:var(--muted);font-weight:700;transition:all 0.2s}
.footer-social a:hover{border-color:var(--green);color:var(--green)}
.footer-col h4{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--white);margin-bottom:16px}
.footer-col li{margin-bottom:8px}
.footer-col a{font-size:0.83rem;color:var(--muted);transition:color 0.2s}
.footer-col a:hover{color:var(--green)}
.footer-col .frow{font-size:0.83rem;color:var(--muted);margin-bottom:7px;line-height:1.5}
.footer-col .frow a{color:var(--green);display:block}
.footer-bottom{border-top:1px solid rgba(61,220,110,0.07);padding-top:18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:0.77rem;color:var(--muted)}
.pay-badges{display:flex;gap:6px;flex-wrap:wrap}
.pay-badge{background:var(--bg3);border:1px solid rgba(61,220,110,0.08);border-radius:3px;padding:3px 8px;font-size:0.67rem;color:var(--muted)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.svc-grid-5{grid-template-columns:repeat(3,1fr)}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.svc-grid-3{grid-template-columns:1fr 1fr}.review-card{flex:0 0 calc(50% - 9px)}}
@media(max-width:768px){
  .navbar{padding:0 20px}
  .nav-links{display:none;flex-direction:column;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(9,15,11,0.98);padding:16px 20px;gap:2px;border-bottom:1px solid var(--border);backdrop-filter:blur(10px)}
  .nav-links.open{display:flex}
  .nav-links a{padding:11px 14px;border-radius:4px;font-size:1rem}
  .nav-toggle{display:flex}
  .wrap{padding:0 20px}
  .page-header{padding:calc(var(--nav-h) + 30px) 20px 30px}
  .svc-grid-5{grid-template-columns:1fr 1fr}
  .svc-grid-3{grid-template-columns:1fr}
  .radio-grid{grid-template-columns:1fr}
  .addon-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-stats{gap:32px}
  .cta-strip{padding:40px 20px}
  .footer{padding:40px 20px 24px}
  .review-card{flex:0 0 calc(100% - 0px);margin-right:0}
  .calc-splits{grid-template-columns:1fr}
}
@media(max-width:480px){.svc-grid-5{grid-template-columns:1fr}.hero h1{font-size:3.5rem}}

/* ── IMAGE GALLERY / CAROUSEL ── */
.img-carousel-wrap{position:relative;overflow:hidden;border-radius:8px;background:var(--card)}
.img-carousel-track{display:flex;gap:18px;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94)}
.img-slide{flex:0 0 100%;position:relative;aspect-ratio:16/9;overflow:hidden}
.img-slide img{width:100%;height:100%;object-fit:cover;display:block}
.img-placeholder{width:100%;aspect-ratio:16/9;background:var(--bg3);border:1px dashed rgba(61,220,110,0.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:0.82rem}
.img-placeholder .ip-icon{font-size:2rem;opacity:0.3}
.img-placeholder .ip-label{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase}
.img-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(9,15,11,0.8);border:1px solid var(--border);color:var(--green);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.9rem;z-index:10;transition:all 0.2s;backdrop-filter:blur(4px)}
.img-carousel-btn:hover{background:rgba(61,220,110,0.15);border-color:var(--green)}
.img-carousel-btn.prev{left:12px}
.img-carousel-btn.next{right:12px}
.img-dots{display:flex;gap:6px;justify-content:center;margin-top:12px}
.img-dot{width:6px;height:6px;border-radius:50%;background:rgba(61,220,110,0.2);cursor:pointer;transition:all 0.2s}
.img-dot.active{background:var(--green);width:18px;border-radius:3px}

/* Service page image grid */
.svc-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
.svc-img-grid.three{grid-template-columns:1fr 1fr 1fr}
.svc-img-item{border-radius:6px;overflow:hidden;aspect-ratio:4/3}
.svc-img-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s}
.svc-img-item:hover img{transform:scale(1.04)}
.svc-img-item .img-placeholder{aspect-ratio:4/3}

@media(max-width:768px){.svc-img-grid,.svc-img-grid.three{grid-template-columns:1fr}}

/* Portrait → landscape crop: keep subject centred */
.img-slide img { object-fit:cover; object-position:center 30%; width:100%; height:100% }
.svc-img-item img { object-fit:cover; object-position:center 25%; width:100%; height:100% }

/* ── HERO PHOTO FADE ── */
.hero-photo{position:relative;overflow:hidden;text-align:left;align-items:flex-start}
.hero-photo-bg{position:absolute;inset:0;background-size:cover;background-position:center 25%;z-index:0}
.hero-photo-fade-r{position:absolute;inset:0;z-index:1;background:linear-gradient(to right,#090f0b 0%,#090f0b 30%,rgba(9,15,11,0.7) 44%,rgba(9,15,11,0.15) 62%,rgba(9,15,11,0.0) 80%)}
.hero-photo-fade-b{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,#090f0b 0%,#090f0b 6%,rgba(9,15,11,0.6) 22%,transparent 50%)}
.hero-photo-fade-t{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,#090f0b 0%,rgba(9,15,11,0.5) 12%,transparent 35%)}
.hero-inner{position:relative;z-index:2;max-width:560px;padding:0 40px}
.hero-photo .hero-stats{justify-content:flex-start}
@media(max-width:768px){
  .hero-photo-bg{background-position:70% 25%}
  .hero-photo-fade-r{background:linear-gradient(to right,#090f0b 0%,#090f0b 20%,rgba(9,15,11,0.92) 50%,rgba(9,15,11,0.7) 100%)}
  .hero-inner{padding:0 20px;max-width:100%}
  .hero-photo .hero-stats{justify-content:center}
}

/* ── SERVICE PAGE IMAGES — portrait-friendly aspect ratio ── */
.svc-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}
.svc-img-item{border-radius:6px;overflow:hidden;aspect-ratio:3/4}
.svc-img-item img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;transition:transform 0.4s}
.svc-img-item:hover img{transform:scale(1.04)}

/* ── HOMEPAGE GALLERY — portrait-friendly too ── */
.img-slide{flex:0 0 calc(50% - 9px);position:relative;overflow:hidden;height:340px;background:var(--card);border-radius:6px}
.img-slide img{width:100%;height:100%;object-fit:contain;object-position:center center;display:block}
@media(max-width:768px){.img-slide{flex:0 0 100%;height:240px}}

/* ── MOBILE OVERHAUL ── */

/* Hero — shrink heading, fix stats wrapping */
@media(max-width:768px){
  .hero{padding:calc(var(--nav-h) + 28px) 0 36px}
  .hero-inner{padding:0 18px}
  .hero h1,.hero-photo h1{font-size:3.2rem;line-height:0.9}
  .hero-location{font-size:0.65rem;letter-spacing:0.18em;margin-bottom:14px}
  .hero-sub{font-size:0.88rem;margin-bottom:20px}
  .hero-btns{flex-direction:column;gap:8px}
  .hero-btns .btn{width:100%;text-align:center;padding:13px 20px}
  .hero-divider{margin:24px 0 20px}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px 0;justify-items:center}
  .stat-num{font-size:1.6rem}
  .stat-lbl{font-size:0.62rem}
}
@media(max-width:380px){
  .hero h1,.hero-photo h1{font-size:2.6rem}
}

/* Service cards — 2 col on tablet, 1 col on small mobile */
@media(max-width:768px){
  .svc-grid-5{grid-template-columns:1fr 1fr}
  .svc-card{padding:20px 16px}
  .svc-card-title{font-size:0.9rem}
}
@media(max-width:420px){
  .svc-grid-5{grid-template-columns:1fr}
}

/* Service detail pages — stack sidebar below content */
@media(max-width:768px){
  .svc-detail-grid{grid-template-columns:1fr !important;gap:28px}
  .svc-sidebar{position:static !important;top:auto !important}
  .svc-img-grid,.svc-img-grid.three{grid-template-columns:1fr 1fr}
  .svc-img-item{aspect-ratio:3/4}
}
@media(max-width:480px){
  .svc-img-grid,.svc-img-grid.three{grid-template-columns:1fr}
}

/* Pricing table — allow horizontal scroll if needed */
@media(max-width:768px){
  .pricing-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .pricing-table{min-width:340px;font-size:0.82rem}
  .pricing-table th,.pricing-table td{padding:10px 10px}
}

/* Booking page */
@media(max-width:768px){
  .booking-grid{grid-template-columns:1fr !important}
  .radio-grid{grid-template-columns:1fr 1fr}
  .addon-grid{grid-template-columns:1fr}
  .instalment-toggle{flex-direction:column;gap:8px}
  .instalment-btn{width:100%;text-align:center}
}
@media(max-width:420px){
  .radio-grid{grid-template-columns:1fr}
}

/* Reviews carousel */
@media(max-width:768px){
  .reviews-track .review-card{flex:0 0 100%;min-width:0}
  .review-card{padding:20px 18px}
  .review-text{font-size:0.85rem}
}

/* Homepage gallery — smaller on mobile, single col */
@media(max-width:768px){
  .img-slide{flex:0 0 100% !important;height:220px !important}
  .img-carousel-btn{width:30px;height:30px;font-size:0.8rem}
}

/* Footer */
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .pay-badges{flex-wrap:wrap}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}

/* Nav — ensure hamburger tap area is large enough */
@media(max-width:768px){
  .nav-toggle{width:40px;height:40px;align-items:center;justify-content:center}
  .nav-logo-link{font-size:1rem}
}

/* General spacing reductions on small screens */
@media(max-width:768px){
  .section{padding:44px 0}
  .section-title{font-size:1.8rem}
  .wrap{padding:0 18px}
  .page-header h1{font-size:2.4rem}
  .cta-strip h2{font-size:1.8rem}
  .cta-strip{padding:36px 20px;text-align:center}
  .cta-strip .btn{width:100%;text-align:center;margin-top:4px}
}

/* Contact page */
@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr !important}
  .contact-info-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .contact-info-cards{grid-template-columns:1fr}
}

/* Calc page */
@media(max-width:768px){
  .calc-grid{grid-template-columns:1fr !important}
  .calc-result{font-size:2.2rem}
}

/* Prevent any element overflowing viewport width */
*{box-sizing:border-box}
body{overflow-x:hidden}
img{max-width:100%;height:auto}

/* ── CONTACT & BOOKING RESPONSIVE LAYOUT ── */
.page-two-col{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}
@media(max-width:900px){
  .page-two-col{grid-template-columns:1fr 300px;gap:32px}
}
@media(max-width:768px){
  .page-two-col{grid-template-columns:1fr;gap:36px}
}

/* ── REVIEWS — fix cramping on mobile ── */
@media(max-width:768px){
  .reviews-wrap,.reviews-section{padding-left:18px;padding-right:18px}
  .review-card{padding:20px 16px}
  .review-text{font-size:0.87rem;line-height:1.75}
  .reviews-track{gap:14px}
}

/* ── CALCULATOR — more breathing room on mobile ── */
@media(max-width:768px){
  .calc-box{margin-bottom:16px}
  .calc-body{padding:18px 16px}
  .calc-head{padding:14px 16px}
  .calc-price-val{font-size:2.2rem}
  .calc-splits{grid-template-columns:1fr 1fr;gap:8px}
  .split-lbl{font-size:0.8rem;padding:10px 8px}
}

/* ── BOOKING PAGE — more space, clearer sections ── */
@media(max-width:768px){
  .radio-grid{grid-template-columns:1fr}
  .radio-lbl{padding:14px 14px}
  .radio-name{font-size:0.95rem}
  .addon-grid{grid-template-columns:1fr}
  .addon-lbl{padding:14px 13px}
  .addon-name{font-size:0.88rem}
  .form-field{margin-bottom:16px}
  .form-field input,.form-field select,.form-field textarea{font-size:1rem;padding:12px 14px}
  .btn-full{padding:15px;font-size:1rem}
}

/* ── CONTACT PAGE — info cards stack cleanly ── */
@media(max-width:768px){
  .info-card{padding:18px 16px;margin-bottom:12px}
  .ic-lbl{font-size:0.7rem;margin-bottom:6px}
  .ic-val{font-size:0.95rem}
  .form-field input,.form-field textarea{font-size:1rem;padding:12px 14px}
}

/* ── GLOBAL FORM INPUT SIZE — prevent iOS zoom (needs 16px) ── */
input,select,textarea{font-size:16px !important}

/* ── SERVICE PAGES — stacked layout ── */
.svc-stacked{max-width:860px;margin:0 auto}
.svc-desc{font-size:0.95rem;color:var(--muted);line-height:1.85;margin-bottom:32px}
.svc-section-h{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--white);margin:32px 0 16px;padding-bottom:8px;border-bottom:1px solid rgba(61,220,110,0.12)}
.svc-pricing-row{display:grid;grid-template-columns:1fr 260px;gap:24px;align-items:start;margin-bottom:8px}
.svc-price-table-wrap{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px 22px}
@media(max-width:680px){
  .svc-pricing-row{grid-template-columns:1fr}
  .svc-stacked{max-width:100%}
}

/* ── CALCULATOR — centred full-width ── */
.calc-center-wrap{max-width:680px;margin:0 auto}
.calc-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.calc-two-col{grid-template-columns:1fr}}

/* ── REVIEWS — fix overflow clipping ── */
.carousel-wrap{overflow:hidden;width:100%}
.carousel-track{display:flex;gap:18px;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94)}
.review-card{flex:0 0 calc(33.333% - 12px);min-width:0;word-break:break-word}
@media(max-width:900px){.review-card{flex:0 0 calc(50% - 9px)}}
@media(max-width:600px){.review-card{flex:0 0 100%;margin-right:0}}
.review-text{overflow-wrap:break-word;word-wrap:break-word}
