/* ===========================================================
   Geomancer Singapore — Shared Design System
   Used by every page. Edit here to change the whole site.
   =========================================================== */

:root{
  --ink:#12161A;
  --jade-black:#1B2420;
  --jade-black-2:#15201B;
  --gold:#C9A357;
  --gold-dim:rgba(201,163,87,0.22);
  --jade:#5C8A6E;
  --parchment:#EDE7DA;
  --muted:#8C8678;
  --serif:'Cormorant',serif;
  --serif-sc:'Cormorant SC',serif;
  --sans:'Inter',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--ink);
  color:var(--parchment);
  font-family:var(--sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
.wrap-narrow{max-width:840px;margin:0 auto;padding:0 32px;}
.eyebrow{
  font-family:var(--serif-sc);
  font-size:13px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
}
.rule{width:46px;height:1px;background:var(--gold);margin:18px 0;}
.rule.center{margin:18px auto;}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:0.01em;}
::selection{background:var(--gold-dim);color:var(--parchment);}
:focus-visible{outline:1.5px solid var(--gold);outline-offset:3px;}

/* ---------- nav ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(18,22,26,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--gold-dim);
}
nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 32px;max-width:1180px;margin:0 auto;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand-logo{width:44px;height:44px;border-radius:50%;object-fit:cover;}
.brand-name{font-family:var(--serif);font-size:19px;letter-spacing:0.02em;}
.brand-name span{color:var(--gold);font-style:italic;font-size:15px;display:block;margin-top:-2px;letter-spacing:0.04em;}
.navlinks{display:flex;gap:30px;font-size:14px;letter-spacing:0.02em;align-items:center;}
.navlinks a{color:var(--muted);transition:color .2s;}
.navlinks a:hover,.navlinks a.active{color:var(--parchment);}
.navlinks a.active{color:var(--gold);}
.has-sub{position:relative;}
.has-sub:hover .subnav{opacity:1;visibility:visible;transform:translateY(0);}
.subnav{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,6px);
  background:var(--jade-black);border:1px solid var(--gold-dim);
  border-radius:3px;padding:10px 0;min-width:200px;
  opacity:0;visibility:hidden;transition:all .18s ease;
  box-shadow:0 16px 40px rgba(0,0,0,0.4);
}
.subnav a{display:block;padding:10px 18px;font-size:13.5px;color:var(--muted);white-space:nowrap;}
.subnav a:hover{color:var(--gold);background:rgba(201,163,87,0.06);}
.nav-cta{
  border:1px solid var(--gold);color:var(--gold);
  padding:9px 20px;font-size:13px;letter-spacing:0.04em;
  border-radius:2px;transition:all .2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--gold);color:var(--ink);}
.nav-toggle{display:none;background:none;border:none;color:var(--parchment);font-size:24px;cursor:pointer;}

/* ---------- page header band (sub-pages) ---------- */
.page-header{
  padding:90px 32px 70px;
  text-align:center;
  border-bottom:1px solid var(--gold-dim);
  position:relative;
  overflow:hidden;
}
.page-header h1{font-size:clamp(34px,5vw,52px);margin-top:14px;}
.page-header .lede{color:var(--muted);max-width:560px;margin:20px auto 0;font-size:16px;}
.breadcrumb{font-size:12.5px;color:var(--muted);margin-top:18px;letter-spacing:0.03em;}
.breadcrumb a{color:var(--jade);}
.breadcrumb a:hover{color:var(--gold);}

.hero-logo-img{
  display:block;
  width:220px;height:220px;
  margin:0 auto 30px;
  border-radius:50%;
  box-shadow:0 20px 60px rgba(0,0,0,0.45);
}

/* ---------- buttons ---------- */
.btn-primary{
  display:inline-block;background:var(--gold);color:var(--ink);
  padding:15px 30px;font-size:14px;letter-spacing:0.03em;
  border-radius:2px;font-weight:600;
  transition:transform .2s,box-shadow .2s;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,163,87,0.25);}
.btn-ghost{
  display:inline-block;border:1px solid rgba(237,231,218,0.3);color:var(--parchment);
  padding:15px 30px;font-size:14px;letter-spacing:0.03em;
  border-radius:2px;transition:border-color .2s;
}
.btn-ghost:hover{border-color:var(--gold);}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;}
.cta-row.center{justify-content:center;}

/* ---------- sections ---------- */
section{padding:90px 32px;}
section.alt{background:var(--jade-black);}
.section-head{max-width:560px;}
.section-head.center{margin:0 auto;text-align:center;}
.section-head h2{font-size:clamp(28px,3.4vw,38px);margin-top:14px;}

/* ---------- pricing cards (consultation) ---------- */
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin-top:56px;border:1px solid var(--gold-dim);border-radius:2px;overflow:hidden;
}
.pricing-card{padding:40px 32px;border-right:1px solid var(--gold-dim);}
.pricing-card:last-child{border-right:none;}
.pricing-card .cat{font-family:var(--serif-sc);font-size:12px;letter-spacing:0.18em;color:var(--gold);text-transform:uppercase;}
.pricing-card h3{font-size:26px;margin:14px 0 24px;}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-top:1px solid rgba(237,231,218,0.08);font-size:14.5px;}
.price-row:first-of-type{border-top:none;}
.price-row .amt{color:var(--gold);font-family:var(--serif);font-size:17px;}
.pricing-foot{margin-top:28px;font-size:13px;color:var(--muted);line-height:1.7;}

/* ---------- process cards ---------- */
.process-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:56px;}
.process-card{border:1px solid var(--gold-dim);padding:36px;border-radius:2px;}
.process-card .day{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:15px;}
.process-card h3{font-size:22px;margin:12px 0 14px;}
.process-card p{color:var(--muted);font-size:15px;}

/* ---------- testimonial ---------- */
.testimonial{padding:100px 32px;text-align:center;border-top:1px solid var(--gold-dim);border-bottom:1px solid var(--gold-dim);}
.testimonial blockquote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(20px,2.6vw,28px);max-width:740px;margin:24px auto 0;color:var(--parchment);line-height:1.5;}
.testimonial cite{display:block;margin-top:26px;font-style:normal;font-size:13px;letter-spacing:0.06em;color:var(--muted);text-transform:uppercase;font-family:var(--serif-sc);}

/* ---------- ladder (courses) ---------- */
.ladder{margin-top:56px;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--gold-dim);border-radius:2px;overflow:hidden;}
.ladder-step{padding:34px 26px;border-right:1px solid var(--gold-dim);}
.ladder-step:last-child{border-right:none;}
.ladder-step.active{background:var(--gold);color:var(--ink);}
.ladder-step.active .stage,.ladder-step.active .price{color:var(--ink);}
.ladder-step.active p{color:rgba(18,22,26,0.7);}
.ladder-step .stage{font-family:var(--serif-sc);font-size:11px;letter-spacing:0.16em;color:var(--gold);text-transform:uppercase;}
.ladder-step h3{font-size:21px;margin:12px 0 10px;}
.ladder-step p{font-size:13.5px;color:var(--muted);margin-bottom:16px;}
.ladder-step .price{font-family:var(--serif);color:var(--gold);font-size:18px;}
.ladder-step a{display:inline-block;margin-top:14px;font-size:13px;color:var(--gold);border-bottom:1px solid var(--gold-dim);}
.ladder-step.active a{color:var(--ink);border-color:rgba(18,22,26,0.3);}

/* ---------- gallery / case studies ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px;}

/* ---------- generic feature grids (3-col / 4-col), used for "why us" and stat blocks ---------- */
.feature-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:50px;}
.feature-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:50px;}
.feature-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;}
.gallery-item{border:1px solid var(--gold-dim);border-radius:2px;overflow:hidden;}
.gallery-item img{aspect-ratio:1/1;object-fit:cover;width:100%;transition:transform .3s;}
.gallery-item:hover img{transform:scale(1.05);}
.gallery-cap{padding:14px 16px;font-size:13px;color:var(--muted);border-top:1px solid var(--gold-dim);}

/* ---------- feature split (sheng ji, about) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.split-visual{border:1px solid var(--gold-dim);border-radius:2px;overflow:hidden;}
.split-visual img{width:100%;display:block;}
.split h2{font-size:clamp(28px,3.6vw,38px);margin-bottom:20px;}
.split p{color:var(--muted);font-size:15.5px;margin-bottom:16px;max-width:480px;}
.split p strong{color:var(--parchment);font-weight:500;}

/* ---------- price list (sheng ji style) ---------- */
.price-list{margin-top:30px;display:flex;flex-direction:column;gap:10px;max-width:460px;}
.price-list .row{display:flex;justify-content:space-between;font-size:14.5px;border-top:1px solid rgba(237,231,218,0.08);padding-top:10px;}
.price-list .row:first-child{border-top:none;padding-top:0;}
.price-list .amt{color:var(--gold);font-family:var(--serif);font-size:17px;}

/* ---------- contact form ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:64px;margin-top:50px;}
.form-field{margin-bottom:22px;}
.form-field label{display:block;font-size:12.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--gold);font-family:var(--serif-sc);margin-bottom:10px;}
.form-field input,.form-field textarea,.form-field select{
  width:100%;background:var(--jade-black);border:1px solid var(--gold-dim);
  color:var(--parchment);padding:13px 16px;font-family:var(--sans);font-size:14.5px;
  border-radius:2px;transition:border-color .2s;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  outline:none;border-color:var(--gold);
}
.form-field textarea{min-height:130px;resize:vertical;}
.contact-info-card{border:1px solid var(--gold-dim);padding:36px;border-radius:2px;height:fit-content;}
.contact-info-card h3{font-size:20px;margin-bottom:22px;}
.contact-line{display:flex;flex-direction:column;gap:4px;margin-bottom:20px;}
.contact-line .ci-label{font-size:11.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);}
.contact-line a, .contact-line span{font-size:15px;color:var(--parchment);}
.contact-line a:hover{color:var(--gold);}

/* ---------- footer ---------- */
footer{padding:70px 32px 40px;border-top:1px solid var(--gold-dim);}
.footer-grid{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px;}
.footer-brand .brand-name{font-size:22px;}
.footer-links{display:flex;gap:60px;flex-wrap:wrap;}
.footer-col h4{font-family:var(--serif-sc);font-size:12px;letter-spacing:0.14em;color:var(--gold);text-transform:uppercase;margin-bottom:16px;}
.footer-col a{display:block;color:var(--muted);font-size:14px;margin-bottom:10px;transition:color .2s;}
.footer-col a:hover{color:var(--parchment);}
.footer-bottom{margin-top:60px;padding-top:24px;border-top:1px solid rgba(237,231,218,0.08);display:flex;justify-content:space-between;color:var(--muted);font-size:12.5px;flex-wrap:wrap;gap:10px;}

/* ---------- whatsapp sticky ---------- */
.wa-float{
  position:fixed;bottom:26px;right:26px;z-index:60;
  background:var(--gold);color:var(--ink);
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(0,0,0,0.4);
  transition:transform .2s;
}
.wa-float:hover{transform:scale(1.06);}

/* ---------- luopan ring (hero decoration) ---------- */
.luopan{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:920px;height:920px;opacity:0.45;pointer-events:none;}
.luopan circle{fill:none;stroke:var(--gold);}
.luopan .ring-1{stroke-opacity:0.5;}
.luopan .ring-2{stroke-opacity:0.32;}
.luopan .ring-3{stroke-opacity:0.2;}
.luopan .tick{stroke:var(--gold);stroke-opacity:0.3;}

/* ---------- responsive ---------- */
@media (max-width:880px){
  nav{position:relative;flex-wrap:wrap;}
  .navlinks{
    display:none;
    position:absolute;
    top:100%;left:0;right:0;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    background:var(--jade-black);
    border:1px solid var(--gold-dim);
    border-top:none;
    padding:8px 0;
    box-shadow:0 16px 40px rgba(0,0,0,0.45);
    z-index:40;
  }
  .navlinks.open{display:flex;}
  .navlinks a{
    width:100%;
    padding:14px 24px;
    border-bottom:1px solid rgba(201,163,87,0.08);
  }
  .navlinks a:last-child{border-bottom:none;}
  .has-sub{width:100%;}
  .has-sub:hover .subnav{display:none;} /* disable hover flyout on touch */
  .has-sub .subnav{
    position:static;
    opacity:1;visibility:visible;transform:none;
    display:none;
    border:none;border-top:1px solid rgba(201,163,87,0.08);
    box-shadow:none;
    background:rgba(0,0,0,0.15);
    margin:0;border-radius:0;
  }
  .has-sub.sub-open .subnav{display:block;}
  .subnav a{padding:12px 40px;}
  .nav-cta{
    display:none;
  }
  .nav-toggle{display:block;order:3;}
  .brand{order:1;flex:1;}
  .split,.process-grid,.contact-grid{grid-template-columns:1fr;}
  .pricing-grid{grid-template-columns:1fr;}
  .pricing-card{border-right:none;border-bottom:1px solid var(--gold-dim);}
  .ladder{grid-template-columns:1fr;}
  .ladder-step{border-right:none;border-bottom:1px solid var(--gold-dim);}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .feature-grid-3{grid-template-columns:1fr;gap:36px;}
  .feature-grid-4{grid-template-columns:repeat(2,1fr);gap:30px;}
  .feature-grid-2{grid-template-columns:1fr;}
  .luopan{width:560px;height:560px;}
  .footer-grid{flex-direction:column;}
  .hero-logo-img{width:140px;height:140px;}
}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto;}}
