/* ════════════════════════════════════════════════════════════════════
   KINGSLEY WINDOW FURNISHING — shared stylesheet
   Heartland warmth + workshop competence. Mandarin-friendly.
   ──────────────────────────────────────────────────────────────────── */

:root{
  --paper:        #f7f1e6;
  --paper-2:      #efe7d6;
  --paper-3:      #fbf7ee;
  --card:         #fdfaf2;
  --ink:          #14110d;
  --ink-2:        #2c2823;
  --muted:        #6b665c;
  --faint:        #a8a195;
  --rule:         #e2dac6;
  --rule-2:       #d2c8af;
  --accent:       #2d4f4a;
  --accent-2:     #1f3935;
  --accent-soft:  #d8e3df;
  --accent-bg:    #eef3ef;
  --warm:         #c46a3d;
  --warm-bg:      #f6e3d3;
  --gold:         #b78e3a;
  --ok:           #355c3a;
  --serif:        "Fraunces", "Times New Roman", Georgia, serif;
  --sans:         "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --shadow-sm:    0 1px 2px rgba(20,17,13,.05);
  --shadow:       0 4px 14px rgba(20,17,13,.08), 0 1px 3px rgba(20,17,13,.04);
  --shadow-lg:    0 24px 60px rgba(20,17,13,.16), 0 4px 12px rgba(20,17,13,.06);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;letter-spacing:-.005em}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

.zh{font-family:"Noto Sans SC","PingFang SC",-apple-system,sans-serif;letter-spacing:.02em}

/* ─── Buttons ────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-weight:600;font-size:.92rem;letter-spacing:-.005em;border-radius:999px;transition:transform .15s ease, box-shadow .2s ease, background .2s ease;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.btn-wa{background:#25d366;color:#fff;box-shadow:var(--shadow-sm)}
.btn-wa:hover{background:#1faa53;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-wa:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule-2)}
.btn-ghost:hover{background:var(--card);border-color:var(--ink)}
.btn-ghost:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px}

:focus{outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}
.btn:focus-visible{outline-offset:4px}
.fab:focus-visible{outline-color:#25d366}

/* ─── Header ─────────────────────────────────────────────────────── */
.bar{position:sticky;top:0;z-index:50;background:rgba(247,241,230,.92);backdrop-filter:saturate(1.5) blur(10px);-webkit-backdrop-filter:saturate(1.5) blur(10px);border-bottom:1px solid var(--rule)}
.bar-in{max-width:1240px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:1.4rem}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand-mark{width:38px;height:38px;display:grid;place-items:center;background:var(--accent);color:var(--paper);border-radius:8px;font-family:var(--serif);font-weight:600;font-size:1.05rem;letter-spacing:-.02em}
.brand-name{display:flex;flex-direction:column;line-height:1.1}
.brand-name strong{font-family:var(--serif);font-weight:600;font-size:1.05rem;letter-spacing:-.015em;color:var(--ink)}
.brand-name span{font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:500;margin-top:2px}

.nav{display:flex;align-items:center;gap:1.6rem;margin-left:1.2rem}
.nav a{font-size:.88rem;font-weight:500;color:var(--ink-2);transition:color .15s;position:relative;padding:6px 0}
.nav a:hover{color:var(--accent)}
.nav a.active{color:var(--accent)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--warm);border-radius:2px}
.bar-r{margin-left:auto;display:flex;align-items:center;gap:.7rem}
.bar-tel{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--muted);font-weight:500}
.bar-tel strong{color:var(--ink);font-weight:600}

/* Mobile CTA block (only shown inside open mobile menu) */
.nav-cta-mobile{display:none;flex-direction:column;gap:.7rem}

/* Hamburger toggle button (mobile only) */
.nav-toggle{display:none;width:38px;height:38px;border-radius:8px;border:1px solid var(--rule-2);background:transparent;align-items:center;justify-content:center;color:var(--ink);transition:background .15s, border-color .15s}
.nav-toggle:hover{background:var(--paper-3);border-color:var(--ink)}
.nav-toggle:active{transform:scale(.95)}
.nav-toggle svg{width:20px;height:20px}
.nav-toggle .icon-close{display:none}
body.menu-open .nav-toggle .icon-open{display:none}
body.menu-open .nav-toggle .icon-close{display:block}
body.menu-open{overflow:hidden}

@media (max-width:1080px){.bar-tel{display:none}}
@media (max-width:880px){
  .bar-in{padding:12px 20px}
  .nav-toggle{display:flex}
  .bar-r .btn-primary{display:none}

  /* Mobile menu — drop-down panel from below header */
  .nav{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;margin:0;
    background:var(--paper);border-top:1px solid var(--rule);
    padding:1.2rem 28px 2rem;overflow-y:auto;z-index:60;
    max-height:calc(100vh - 65px);
    box-shadow:0 16px 32px rgba(20,17,13,.12);
  }
  body.menu-open .nav{display:flex}
  body.menu-open{overflow:hidden}
  .nav a{
    font-size:1.4rem;font-family:var(--serif);font-weight:500;
    color:var(--ink);padding:1rem 0;border-bottom:1px solid var(--rule);
    letter-spacing:-.012em;
  }
  .nav a:last-of-type{border-bottom:0}
  .nav a.active{color:var(--accent)}
  .nav a.active::after{display:none}
  .nav a.active::before{
    content:"";display:inline-block;width:6px;height:6px;
    background:var(--warm);border-radius:50%;
    margin-right:.7rem;vertical-align:middle;margin-bottom:3px;
  }
  .nav-cta-mobile{
    margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--rule);
    display:flex;
  }
  .nav-cta-mobile a{
    font-family:var(--sans);font-size:.95rem;font-weight:600;
    padding:.85rem 1rem;border:0;text-align:center;border-radius:999px;
  }
  .nav-cta-mobile a:last-of-type{border-bottom:0}
  .nav-cta-mobile .nav-tel{background:var(--accent);color:#fff}
  .nav-cta-mobile .nav-wa{background:#25d366;color:#fff}
}

/* ─── Hero (homepage) ────────────────────────────────────────────── */
.hero{position:relative;padding:64px 0 88px;overflow:hidden}
.hero::before{content:"";position:absolute;top:0;right:-10%;width:60%;height:80%;background:radial-gradient(ellipse at center,rgba(45,79,74,.07),transparent 65%);pointer-events:none}
.hero-in{max-width:1240px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:3.6rem;align-items:center;position:relative}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-weight:500;font-size:.86rem;color:var(--accent);margin-bottom:1.4rem;letter-spacing:0}
.hero-eyebrow .dot{width:7px;height:7px;background:var(--warm);border-radius:50%;animation:pulse 2.4s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,4.6vw,3.8rem);line-height:1.05;letter-spacing:-.025em;color:var(--ink);margin-bottom:1.3rem}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:500}
.hero-lede{font-size:1.1rem;line-height:1.6;color:var(--ink-2);max-width:48ch;margin-bottom:2rem;font-weight:400}
.hero-lede strong{color:var(--ink);font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;margin-bottom:2.2rem}
.hero-link{font-size:.92rem;font-weight:500;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule-2);padding-bottom:2px;transition:color .15s, border-color .15s}
.hero-link:hover{color:var(--accent);border-bottom-color:var(--accent)}
.hero-link em{font-style:normal;color:var(--muted);font-weight:400}
.hero-trust{padding-top:1.6rem;border-top:1px solid var(--rule);font-size:.92rem;line-height:1.55;color:var(--muted);max-width:60ch}
.hero-trust strong{color:var(--ink);font-weight:600}
.hero-trust .sep{color:var(--rule-2);margin:0 .55rem;font-weight:400}

.hero-art{position:relative;max-width:560px;margin-left:auto;width:100%}
.hero-photo{position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg)}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo-tag{position:absolute;bottom:14px;left:14px;background:rgba(20,17,13,.65);color:#f0eadb;padding:.45rem .8rem;border-radius:8px;font-size:.72rem;font-weight:500;letter-spacing:.02em;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:inline-flex;align-items:center;gap:.45rem}
.hero-photo-tag::before{content:"";width:6px;height:6px;background:var(--warm);border-radius:50%;flex-shrink:0}
.hero-floater{position:absolute;background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:1rem 1.2rem;box-shadow:var(--shadow-lg);z-index:5;max-width:240px}
.hf-1{top:32%;right:-4%;animation:float 5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-floater .label{font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;margin-bottom:.35rem}
.hero-floater .price{font-family:var(--serif);font-size:1.7rem;font-weight:500;color:var(--ink);letter-spacing:-.015em;line-height:1;margin-bottom:.3rem}
.hero-floater .price small{font-size:.85rem;color:var(--muted);font-weight:400}
.hero-floater .note{font-size:.78rem;color:var(--muted);line-height:1.4}

@media (max-width:980px){
  .hero{padding:24px 0 56px}
  .hero-in{grid-template-columns:1fr;gap:1.6rem}
  .hero-in > .hero-art{order:-1;max-width:none;margin:0}
  .hero-eyebrow{font-size:.78rem;margin-bottom:.9rem}
  .hero h1{font-size:clamp(1.85rem,7vw,2.4rem);line-height:1.05;margin-bottom:1rem}
  .hero-lede{font-size:1rem;margin-bottom:1.5rem;max-width:none}
  .hero-photo{aspect-ratio:5/4;border-radius:14px}
  .hero-floater{max-width:180px;padding:.7rem .9rem}
  .hero-floater .label{font-size:.6rem;margin-bottom:.2rem}
  .hero-floater .price{font-size:1.35rem;margin-bottom:.15rem}
  .hero-floater .note{font-size:.7rem;line-height:1.35}
  .hf-1{right:.9rem;top:auto;bottom:.9rem;animation:none}
  .hero-photo-tag{font-size:.66rem;padding:.35rem .65rem;bottom:.9rem;left:.9rem}
}
@media (max-width:520px){
  .hero{padding:20px 0 44px}
  .hero h1{font-size:clamp(1.7rem,8vw,2.2rem)}
  .hero-photo{aspect-ratio:4/3}
  .hero-trust{font-size:.84rem;line-height:1.5;padding-top:1.2rem}
  .hero-trust .sep{display:block;height:.5rem;visibility:hidden}
  .hero-cta{gap:.9rem}
  .hero-cta .btn-wa{width:100%;justify-content:center}
  .hero-link{font-size:.88rem}
}

/* ─── Page hero (sub-pages) ─────────────────────────────────────── */
.phero{position:relative;padding:56px 0 48px;border-bottom:1px solid var(--rule);overflow:hidden}
.phero-in{max-width:1240px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
.phero-crumb{font-size:.78rem;color:var(--muted);margin-bottom:1.2rem;display:flex;align-items:center;gap:.5rem}
.phero-crumb a{color:var(--muted);transition:color .15s}
.phero-crumb a:hover{color:var(--ink)}
.phero-crumb .sep{color:var(--rule-2)}
.phero-crumb .here{color:var(--ink);font-weight:500}
.phero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,3.8vw,3.1rem);line-height:1.1;letter-spacing:-.022em;color:var(--ink);margin-bottom:.9rem;max-width:24ch}
.phero h1 em{font-style:italic;color:var(--accent);font-weight:500}
.phero-dek{font-size:1.05rem;line-height:1.6;color:var(--muted);max-width:56ch}
.phero-dek strong{color:var(--ink-2);font-weight:600}
.phero-meta{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid var(--rule)}
.phero-meta .pm{display:flex;flex-direction:column;font-size:.78rem;color:var(--muted)}
.phero-meta .pm strong{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);letter-spacing:-.01em;margin-bottom:1px}

.phero-photo{margin-top:2.4rem;position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:21/9}
.phero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.phero-photo-credit{position:absolute;bottom:14px;right:14px;background:rgba(20,17,13,.65);color:#f0eadb;font-size:.66rem;letter-spacing:.04em;padding:.35rem .65rem;border-radius:6px;font-weight:500;backdrop-filter:blur(4px)}
@media (max-width:680px){.phero-photo{aspect-ratio:16/9}}

/* ─── Trust strip ────────────────────────────────────────────────── */
.strip{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.strip-in{max-width:1240px;margin:0 auto;padding:18px 28px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;font-size:.82rem;color:var(--ink-2);font-weight:500}
.strip-item{display:flex;align-items:center;gap:.55rem}
.strip-item svg{width:16px;height:16px;color:var(--accent);flex-shrink:0}

/* ─── Section scaffolding ───────────────────────────────────────── */
.sec{padding:88px 0;position:relative}
.sec-in{max-width:1240px;margin:0 auto;padding:0 28px}
.sec-num{font-family:var(--sans);font-size:.82rem;letter-spacing:0;color:var(--warm);font-weight:500;margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem}
.sec-num::before{content:"";width:24px;height:1px;background:var(--warm);opacity:.6}
.sec-num span{font-style:normal;font-size:.72rem;letter-spacing:.08em;color:var(--faint);font-weight:500;font-variant-numeric:tabular-nums}
.sec h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,3.5vw,2.85rem);line-height:1.12;letter-spacing:-.022em;color:var(--ink);margin-bottom:1rem;max-width:24ch}
.sec h2 em{font-style:italic;color:var(--accent);font-weight:500}
.sec-dek{font-size:1.05rem;line-height:1.6;color:var(--muted);max-width:62ch;margin-bottom:2.6rem}

/* ─── Section cards (homepage navigation) ──────────────────────── */
.scards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.scard{background:var(--card);border:1px solid var(--rule);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease, border-color .25s}
.scard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--rule-2)}
.scard-photo{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2);position:relative}
.scard-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.scard:hover .scard-photo img{transform:scale(1.04)}
.scard-body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.scard h4{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--ink);letter-spacing:-.015em;line-height:1.2}
.scard h4 .zh{display:block;font-size:.82rem;font-weight:400;color:var(--muted);margin-top:2px;letter-spacing:.04em}
.scard p{font-size:.92rem;color:var(--muted);line-height:1.55;flex:1}
.scard .scard-cta{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--accent);font-weight:600;margin-top:.4rem}
.scard .scard-cta::after{content:"\2192";transition:transform .2s}
.scard:hover .scard-cta::after{transform:translateX(4px)}
@media (max-width:880px){.scards{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.scards{grid-template-columns:1fr}}

/* ─── BTO Packages ───────────────────────────────────────────────── */
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.8rem}
.pkg{background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:1.6rem 1.4rem;position:relative;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.pkg:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--rule-2)}
.pkg-pop{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-bg) 0%,var(--card) 35%)}
.pkg-pop::before{content:"Most popular";position:absolute;top:-10px;right:14px;background:var(--accent);color:#fff;font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;padding:.3rem .65rem;border-radius:999px}
.pkg h4{font-family:var(--serif);font-weight:500;font-size:1.4rem;color:var(--ink);letter-spacing:-.01em;margin-bottom:.25rem}
.pkg .pkg-sub{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.3rem;font-weight:500}
.pkg .pkg-price{font-family:var(--serif);font-weight:500;font-size:2.4rem;color:var(--ink);letter-spacing:-.025em;line-height:1;margin-bottom:.3rem}
.pkg .pkg-price small{font-size:.95rem;color:var(--muted);font-weight:400;letter-spacing:0}
.pkg .pkg-incl{font-size:.78rem;color:var(--muted);margin-bottom:1.2rem}
.pkg ul{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.4rem}
.pkg li{display:flex;align-items:start;gap:.5rem;font-size:.86rem;color:var(--ink-2);line-height:1.45}
.pkg li::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--accent-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path fill='none' stroke='%232d4f4a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 7l3 3 5-6'/></svg>");background-size:14px;flex-shrink:0;margin-top:2px}
.pkg .btn{width:100%;justify-content:center;font-size:.85rem;padding:.7rem 1rem}

.pkg-foot{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;background:var(--paper-3);border:1px dashed var(--rule-2);border-radius:12px;font-size:.86rem;color:var(--ink-2)}
.pkg-foot svg{width:20px;height:20px;color:var(--warm);flex-shrink:0}
.pkg-foot strong{color:var(--ink)}

@media (max-width:980px){.pkg-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.pkg-grid{grid-template-columns:1fr}}

/* ─── Per-sqft rates table ──────────────────────────────────────── */
.rates{margin-top:2.4rem;background:var(--card);border:1px solid var(--rule);border-radius:14px;overflow:hidden}
.rates-head{padding:1.4rem 1.6rem;background:var(--paper-3);border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap}
.rates-head h4{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);letter-spacing:-.012em}
.rates-head .note{font-size:.82rem;color:var(--muted)}
.rates-row{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:1.5rem;padding:1.1rem 1.6rem;border-bottom:1px solid var(--rule)}
.rates-row:last-child{border-bottom:0}
.rates-row .rkey{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.rates-row .rdesc{font-size:.86rem;color:var(--muted);line-height:1.5}
.rates-row .rprice{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--accent);letter-spacing:-.01em;font-variant-numeric:tabular-nums;white-space:nowrap}
.rates-row .rprice small{font-family:var(--sans);display:block;font-size:.7rem;color:var(--muted);font-weight:400;text-align:right;margin-top:2px;letter-spacing:.02em}
@media (max-width:680px){
  .rates-row{grid-template-columns:1fr auto;gap:.6rem 1rem}
  .rates-row .rdesc{grid-column:1 / -1;margin-top:-.2rem}
}

/* ─── Korean blinds (page hero+wedge) ─────────────────────────── */
.korean{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-3) 100%);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.kor-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:3.4rem;align-items:start}
.kor-styles{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.kstyle{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:0;overflow:hidden;transition:transform .2s, border-color .2s}
.kstyle:hover{transform:translateY(-2px);border-color:var(--accent)}
.ks-vis{height:160px;position:relative;overflow:hidden}
.ks-vis img{width:100%;height:100%;object-fit:cover;display:block}
.ks-combi{background:linear-gradient(180deg,#e9dfc3 0%,#d5c89a 100%)}
.ks-combi::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,rgba(70,55,30,.5) 0,rgba(70,55,30,.5) 5px,rgba(255,255,255,.05) 5px,rgba(255,255,255,.05) 13px)}
.ks-zebra{background:linear-gradient(180deg,#f4ecd7 0%,#e0d6b4 100%)}
.ks-zebra::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,rgba(40,30,18,.62) 0,rgba(40,30,18,.62) 9px,rgba(255,255,255,.55) 9px,rgba(255,255,255,.55) 18px)}
.ks-rainbow{background:linear-gradient(180deg,#dce6dc 0%,#b8c9c0 100%)}
.ks-rainbow::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,rgba(45,79,74,.55) 0,rgba(45,79,74,.55) 6px,rgba(255,255,255,.4) 6px,rgba(255,255,255,.4) 14px)}
.ks-body{padding:1.1rem 1.2rem 1.3rem}
.ks-body h5{font-family:var(--serif);font-size:1.12rem;font-weight:500;color:var(--ink);margin-bottom:.3rem;letter-spacing:-.008em}
.ks-body p{font-size:.85rem;color:var(--muted);line-height:1.55;margin-bottom:.7rem}
.ks-body .ks-price{font-family:var(--serif);font-weight:500;color:var(--accent);font-size:1rem;letter-spacing:-.01em}

.kor-faq h4{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:var(--ink);margin-bottom:.3rem;letter-spacing:-.012em}
.kor-faq .lab{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--warm);font-weight:400;margin-bottom:1.2rem;letter-spacing:-.005em}
.kor-qa{display:grid;grid-template-columns:1fr;gap:0;margin-top:.4rem}
.kor-qa .qa{padding:1.1rem 0;border-top:1px solid var(--rule)}
.kor-qa .qa:last-child{border-bottom:1px solid var(--rule)}
.kor-qa .q{font-weight:600;color:var(--ink);font-size:.96rem;line-height:1.4;margin-bottom:.45rem;letter-spacing:-.005em}
.kor-qa .a{color:var(--ink-2);font-size:.9rem;line-height:1.6}

@media (max-width:980px){
  .kor-grid{grid-template-columns:1fr;gap:2rem}
  .kor-styles{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:560px){.kor-styles{grid-template-columns:1fr}}

/* ─── Product editorial menu list ──────────────────────────────── */
.menu-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--rule-2)}
.mli{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:baseline;column-gap:2rem;row-gap:.4rem;padding:1.5rem 0;border-bottom:1px solid var(--rule);transition:padding-left .2s ease}
.mli:hover{padding-left:.8rem}
.mli-num{font-size:.72rem;color:var(--faint);font-weight:500;letter-spacing:.08em;font-variant-numeric:tabular-nums;align-self:start;margin-top:.55rem}
.mli-body{min-width:0}
.mli-body h4{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:var(--ink);letter-spacing:-.012em;line-height:1.25}
.mli-body h4 .zh{margin-left:.7rem;font-size:.92rem;font-weight:400;color:var(--muted);letter-spacing:.04em}
.mli-body p{font-size:.92rem;color:var(--muted);line-height:1.55;margin-top:.4rem;max-width:60ch}
.mli-price{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);letter-spacing:-.01em;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;align-self:start;margin-top:.55rem}
.mli-price small{display:block;font-family:var(--sans);font-size:.7rem;color:var(--muted);font-weight:400;letter-spacing:.04em;margin-top:3px;text-align:right;text-transform:none}
@media (max-width:680px){
  .mli{grid-template-columns:auto minmax(0,1fr);column-gap:1.2rem}
  .mli-price{grid-column:1 / -1;text-align:left;margin-top:.6rem}
  .mli-price small{text-align:left}
  .mli-body h4 .zh{display:block;margin-left:0;margin-top:2px}
}

/* ─── Photo gallery (sub-pages) ────────────────────────────────── */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:2rem}
.gphoto{aspect-ratio:1/1.1;border-radius:12px;overflow:hidden;background:var(--paper-2);position:relative}
.gphoto.tall{aspect-ratio:1/1.5}
.gphoto.wide{aspect-ratio:16/10;grid-column:span 2}
.gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gphoto:hover img{transform:scale(1.04)}
.gphoto-cap{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.1rem;background:linear-gradient(0deg,rgba(20,17,13,.7) 0%,transparent 100%);color:#fff;font-size:.86rem;font-weight:500}
@media (max-width:680px){.gallery{grid-template-columns:1fr 1fr}.gphoto.wide{grid-column:span 2}}

/* ─── Process ────────────────────────────────────────────────────── */
.proc{background:var(--accent);color:#f3ede0;position:relative;overflow:hidden}
.proc::before{content:"";position:absolute;top:0;right:-20%;width:60%;height:140%;background:radial-gradient(ellipse at center,rgba(255,255,255,.06),transparent 60%);pointer-events:none}
.proc h2{color:#fff}
.proc h2 em{color:#e6c8a8}
.proc .sec-dek{color:#cdc6b3}
.proc .sec-num{color:#e6c8a8}
.proc .sec-num::before{background:#e6c8a8}

.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:1rem;position:relative;z-index:2}
.step{position:relative;padding:1.4rem 1.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:12px}
.step-n{font-family:var(--serif);font-weight:300;font-size:2.2rem;color:#e6c8a8;line-height:1;letter-spacing:-.03em;margin-bottom:.4rem}
.step h5{font-family:var(--serif);font-weight:500;font-size:1.05rem;color:#fff;margin-bottom:.4rem;letter-spacing:-.005em}
.step p{font-size:.82rem;color:#cdc6b3;line-height:1.55}
.step .step-time{display:inline-block;margin-top:.7rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#e6c8a8;font-weight:600;padding:.25rem .6rem;background:rgba(230,200,168,.12);border-radius:999px}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}

/* ─── About Kingsley ─────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:3rem;align-items:center}
.about-card{background:var(--card);border:1px solid var(--rule);border-radius:18px;padding:2.2rem;box-shadow:var(--shadow);position:relative}
.about-quote{font-family:var(--serif);font-style:italic;font-weight:300;font-size:1.4rem;line-height:1.45;color:var(--ink);letter-spacing:-.01em;margin-bottom:1.4rem;position:relative}
.about-quote::before{content:"\201C";font-family:var(--serif);font-style:normal;font-weight:500;font-size:3.4rem;line-height:.7;color:var(--warm);display:block;margin-bottom:.2rem;letter-spacing:-.05em}
.about-quote .zh{font-style:normal;display:block;font-size:.95rem;color:var(--muted);margin-top:.6rem}
.about-sig{display:flex;align-items:center;gap:.9rem;padding-top:1.2rem;border-top:1px solid var(--rule)}
.about-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--warm) 0%,var(--gold) 100%);display:grid;place-items:center;color:#fff;font-family:var(--serif);font-weight:500;font-size:1.2rem}
.about-name{display:flex;flex-direction:column;line-height:1.2}
.about-name strong{font-weight:600;color:var(--ink)}
.about-name span{font-size:.78rem;color:var(--muted)}

.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.6rem}
.astat{padding:1.2rem 1.3rem;background:var(--paper-3);border:1px solid var(--rule);border-radius:12px}
.astat strong{font-family:var(--serif);font-size:2rem;font-weight:500;color:var(--accent);line-height:1;letter-spacing:-.02em;display:block;margin-bottom:.3rem}
.astat span{font-size:.8rem;color:var(--muted);line-height:1.4;display:block}

.about-photo{aspect-ratio:4/5;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.about-photo img{width:100%;height:100%;object-fit:cover}

@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:2rem}}

/* ─── Reviews ────────────────────────────────────────────────────── */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.rev{background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:1.6rem 1.5rem;display:flex;flex-direction:column;gap:1rem}
.rev-stars{color:var(--gold);font-size:.95rem;letter-spacing:.1em}
.rev-text{font-size:.94rem;color:var(--ink-2);line-height:1.6;flex:1}
.rev-text strong{color:var(--ink)}
.rev-by{display:flex;align-items:center;gap:.7rem;padding-top:1rem;border-top:1px solid var(--rule)}
.rev-init{width:36px;height:36px;border-radius:50%;background:var(--accent-bg);color:var(--accent);display:grid;place-items:center;font-weight:600;font-size:.82rem}
.rev-by-meta{display:flex;flex-direction:column;line-height:1.25;font-size:.78rem}
.rev-by-meta strong{color:var(--ink);font-weight:600;font-size:.84rem}
.rev-by-meta span{color:var(--muted)}
@media (max-width:880px){.rev-grid{grid-template-columns:1fr}}

.rev-bar{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;margin-top:1.8rem;padding:1.2rem 1.5rem;background:var(--paper-3);border:1px solid var(--rule);border-radius:12px;flex-wrap:wrap}
.rev-bar-l{display:flex;align-items:center;gap:1rem}
.rev-bar-score{font-family:var(--serif);font-weight:500;font-size:2.2rem;color:var(--ink);line-height:1;letter-spacing:-.02em}
.rev-bar-meta{display:flex;flex-direction:column;line-height:1.3}
.rev-bar-meta strong{color:var(--ink);font-weight:600}
.rev-bar-meta span{font-size:.78rem;color:var(--muted)}

/* ─── Bilingual block ───────────────────────────────────────────── */
.bili{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:64px 0}
.bili-in{max-width:1100px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:auto 1fr;gap:2.4rem;align-items:center}
.bili-mark{font-family:var(--serif);font-weight:400;font-size:5rem;line-height:.9;color:var(--accent);letter-spacing:-.03em}
.bili-mark .zh{display:block;font-size:1.8rem;font-weight:500;color:var(--warm);margin-top:.4rem;letter-spacing:.05em}
.bili-body p{font-size:1.05rem;line-height:1.65;color:var(--ink-2);margin-bottom:.8rem}
.bili-body p.zh{font-family:"Noto Sans SC","PingFang SC",sans-serif;font-size:1.02rem;color:var(--muted);letter-spacing:.02em}
.bili-body p:last-child{margin-bottom:0}
@media (max-width:680px){.bili-in{grid-template-columns:1fr;gap:1.4rem}.bili-mark{font-size:3.4rem}}

/* ─── Contact / map ─────────────────────────────────────────────── */
.contact{padding:88px 0 64px}
.contact-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:3rem}
.cinfo{display:flex;flex-direction:column;gap:1.4rem}
.crow{display:flex;gap:1rem;align-items:start;padding:1.1rem 0;border-bottom:1px solid var(--rule)}
.crow:last-child{border-bottom:0}
.crow-ic{width:38px;height:38px;background:var(--accent-bg);color:var(--accent);border-radius:10px;display:grid;place-items:center;flex-shrink:0}
.crow-ic svg{width:18px;height:18px}
.crow-l{font-size:.78rem;color:var(--muted);font-weight:500;margin-bottom:.3rem;letter-spacing:0}
.crow-v{font-size:1rem;color:var(--ink);font-weight:500;line-height:1.5}
.crow-v small{display:block;font-size:.82rem;color:var(--muted);font-weight:400;margin-top:.2rem}

.cmap{background:var(--card);border:1px solid var(--rule);border-radius:18px;padding:1.4rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}
.cmap-canvas{aspect-ratio:4/3;background:linear-gradient(135deg,#dde6df 0%,#c8d6cb 100%);border-radius:10px;position:relative;overflow:hidden}
.cmap-canvas::before{content:"";position:absolute;inset:0;background:
  linear-gradient(45deg,transparent 48%,rgba(255,255,255,.4) 49%,rgba(255,255,255,.4) 51%,transparent 52%) 0 0/40px 40px,
  linear-gradient(-45deg,transparent 48%,rgba(255,255,255,.25) 49%,rgba(255,255,255,.25) 51%,transparent 52%) 0 0/60px 60px,
  linear-gradient(0deg,transparent 49%,rgba(45,79,74,.18) 50%,transparent 51%) 0 0/100% 80px,
  linear-gradient(90deg,transparent 49%,rgba(45,79,74,.14) 50%,transparent 51%) 0 0/120px 100%
}
.cmap-pin{position:absolute;top:48%;left:52%;transform:translate(-50%,-100%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:0}
.pin-flag{background:var(--accent);color:#fff;padding:.45rem .8rem;border-radius:8px;font-size:.78rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow);position:relative}
.pin-flag::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--accent)}
.pin-dot{width:14px;height:14px;background:var(--accent);border-radius:50%;border:3px solid #fff;margin-top:8px;box-shadow:var(--shadow);position:relative}
.pin-dot::before{content:"";position:absolute;inset:-8px;border:2px solid var(--accent);border-radius:50%;opacity:.4;animation:ring 2s infinite}
@keyframes ring{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.cmap-foot{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--muted)}
.cmap-foot strong{color:var(--ink)}

@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:2rem}}

/* ─── Cross-page CTA banner ─────────────────────────────────────── */
.cta-band{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:60px 0}
.cta-band-in{max-width:980px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h3{font-family:var(--serif);font-size:1.7rem;font-weight:500;color:var(--ink);letter-spacing:-.018em;line-height:1.2;max-width:30ch}
.cta-band h3 em{font-style:italic;color:var(--accent);font-weight:500}
.cta-band p{font-size:.92rem;color:var(--muted);margin-top:.5rem;max-width:50ch}
.cta-band-r{display:flex;gap:.7rem;flex-wrap:wrap}

/* ─── Footer ─────────────────────────────────────────────────────── */
.foot{background:var(--ink);color:#a8a195;padding:72px 0 32px}
.foot-in{max-width:1240px;margin:0 auto;padding:0 28px}
.foot-mark{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:1.4rem;margin-bottom:2.4rem;padding-bottom:2.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-mark-l{display:flex;flex-direction:column;gap:.4rem}
.foot-brand-name{font-family:var(--serif);font-weight:500;color:#fff;font-size:1.7rem;letter-spacing:-.018em}
.foot-brand-zh{color:var(--gold);font-family:"Noto Sans SC",sans-serif;font-size:.98rem;letter-spacing:.04em}
.foot-mark-r{font-size:.92rem;color:#cfc7b9;line-height:1.5;text-align:right;max-width:38ch}
.foot-mark-r strong{color:#fff;font-weight:600}
.foot-nav{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem 1.6rem;font-size:.88rem;margin-bottom:2.4rem}
.foot-nav a{color:#cfc7b9;transition:color .15s}
.foot-nav a:hover{color:#fff}
.foot-nav .dot{color:#5a544a}
.foot-bot{padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:#7a7468}
.foot-bot a{color:#a8a195}
.foot-bot a:hover{color:#fff}
@media (max-width:680px){.foot-mark-r{text-align:left;max-width:none}.foot-mark{flex-direction:column;align-items:flex-start}}

/* ─── Floating WhatsApp ────────────────────────────────────────── */
.fab{position:fixed;bottom:22px;right:22px;z-index:60;display:flex;align-items:center;gap:.7rem;background:#25d366;color:#fff;padding:.85rem 1.1rem .85rem .9rem;border-radius:999px;box-shadow:0 12px 28px rgba(37,211,102,.4),0 4px 10px rgba(20,17,13,.18);font-weight:600;font-size:.92rem;transition:transform .15s, box-shadow .2s}
.fab:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(37,211,102,.5),0 6px 14px rgba(20,17,13,.2)}
.fab svg{width:22px;height:22px}
.fab-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;background:#fff;border-radius:50%;border:2px solid #25d366}
@media (max-width:520px){.fab span:not(.fab-dot){display:none}.fab{padding:.95rem;border-radius:50%}}

::selection{background:var(--accent);color:#fff}
