:root{
  --bg:#F5F9FC; --bg-2:#E5EFF5; --ink:#0F2840; --ink-soft:#3D5A75;
  --brand:#2D6FA8; --brand-dark:#1B4A7A; --brand-light:#7DB3D9;
  --accent:#D4A85A; --accent-dark:#B8893E;
  --line:rgba(45,111,168,.18);
  --shadow-sm:0 4px 12px rgba(15,40,64,.08);
  --shadow:0 12px 40px rgba(15,40,64,.12);
  --shadow-lg:0 24px 60px rgba(15,40,64,.18);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* TOPBAR */
.topbar{background:linear-gradient(90deg,#1B4A7A 0%,#2D6FA8 50%,#1B4A7A 100%);color:#F5F9FC;font-size:13px;letter-spacing:.04em;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.topbar .left{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.topbar .left span{display:inline-flex;align-items:center;gap:6px}
.topbar svg{width:14px;height:14px}
.topbar a{color:#fff;text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.4)}
.topbar a:hover{border-bottom-color:#fff}

/* HEADER */
.header{background:rgba(245,249,252,.94);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100;backdrop-filter:blur(10px)}
.header .container{display:flex;align-items:center;padding:14px 24px;gap:24px}
.logo{display:flex;align-items:center;gap:14px;margin-right:auto}
.logo img{width:48px;height:48px;border-radius:50%;box-shadow:var(--shadow-sm)}
.logo .text h1,.logo .text span.brand-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;letter-spacing:.02em;color:var(--brand-dark);line-height:1;display:block}
.logo .text p{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.32em;color:var(--brand);margin-top:4px;text-transform:uppercase}
.nav ul{display:flex;list-style:none;gap:0}
.nav li a{display:block;padding:10px 11px;font-size:13px;font-weight:500;letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase;transition:all .25s;position:relative}
.nav li a:hover{color:var(--brand-dark)}
.nav li a::after{content:'';position:absolute;bottom:4px;left:50%;width:0;height:1px;background:var(--accent);transition:all .3s;transform:translateX(-50%)}
.nav li a:hover::after{width:50%}
.nav li.active a{color:var(--brand-dark)}
.nav li.active a::after{width:50%}
.header-cta{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:11px 18px;font-size:13px;font-weight:600;letter-spacing:.06em;border-radius:3px;transition:all .25s;white-space:nowrap}
.header-cta:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;padding:16px 32px;font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:3px;transition:all .3s;border:none;cursor:pointer;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--brand-dark);padding:15px 30px;font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:1.5px solid var(--brand);border-radius:3px;transition:all .3s}
.btn-outline:hover{background:var(--brand);color:#fff}
.btn-light{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--brand-dark);padding:16px 32px;font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:3px;transition:all .3s}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

/* PAGE HEAD */
.page-head{background:linear-gradient(135deg,#E5EFF5 0%,#F5F9FC 60%);padding:60px 0 50px;border-bottom:1px solid var(--line);text-align:center;position:relative;overflow:hidden}
.page-head::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 30% 50%,rgba(125,179,217,.1) 0%,transparent 50%);pointer-events:none}
.page-head .breadcrumb{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.3em;color:var(--brand);margin-bottom:14px;text-transform:uppercase}
.page-head .breadcrumb a{color:var(--brand);border-bottom:1px dotted var(--brand-light)}
.page-head h1{font-family:'Cormorant Garamond',serif;font-size:54px;font-weight:500;line-height:1.1;color:var(--ink);letter-spacing:-.01em;max-width:960px;margin:0 auto}
.page-head h1 em{font-style:italic;color:var(--accent-dark)}
.page-head .sub{font-size:16px;color:var(--ink-soft);margin-top:20px;max-width:680px;margin-left:auto;margin-right:auto;line-height:1.7}

/* SECTION */
.section{padding:80px 0;position:relative}
.section-head{text-align:center;max-width:680px;margin:0 auto 50px}
.section-tag{display:inline-flex;align-items:center;gap:14px;font-family:'Cinzel',serif;font-size:11px;letter-spacing:.4em;color:var(--brand);text-transform:uppercase;margin-bottom:18px}
.section-tag::before,.section-tag::after{content:'';width:30px;height:1px;background:var(--brand-light)}
.section h2{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:500;line-height:1.15;color:var(--ink);letter-spacing:-.01em}
.section h2 em{font-style:italic;color:var(--accent-dark)}
.section-desc{font-size:16px;color:var(--ink-soft);margin-top:18px;line-height:1.75}

/* CONTENT */
.content{max-width:820px;margin:0 auto}
.content h2{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:600;color:var(--ink);margin:48px 0 18px;line-height:1.2}
.content h2:first-child{margin-top:0}
.content h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--ink);margin:32px 0 14px;line-height:1.3}
.content p{font-size:16px;line-height:1.85;color:var(--ink-soft);margin-bottom:18px}
.content ul{margin:14px 0 24px 22px}
.content li{font-size:16px;line-height:1.85;color:var(--ink-soft);margin-bottom:8px}
.content img{border-radius:6px;margin:32px 0;box-shadow:var(--shadow-sm)}
.content blockquote{border-left:3px solid var(--brand-light);padding:6px 22px;margin:28px 0;font-family:'Cormorant Garamond',serif;font-size:22px;font-style:italic;color:var(--brand-dark);line-height:1.5}

/* FOOTER */
.footer{background:#0A1F33;color:rgba(245,249,252,.7);padding:70px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr 1fr;gap:40px;margin-bottom:50px}
.foot-col h5{font-family:'Cinzel',serif;font-size:12px;letter-spacing:.3em;color:var(--brand-light);margin-bottom:20px;text-transform:uppercase}
.foot-col .brand-blk{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.foot-col .brand-blk img{width:54px;height:54px;border-radius:50%}
.foot-col .brand-blk h4{font-family:'Cormorant Garamond',serif;font-size:22px;color:#fff;font-weight:600}
.foot-col .brand-blk p{font-size:11px;color:var(--brand-light);letter-spacing:.2em;margin-top:2px}
.foot-col p{font-size:14px;line-height:1.8}
.foot-col ul{list-style:none}
.foot-col ul li{margin-bottom:10px;font-size:14px}
.foot-col ul a{color:rgba(245,249,252,.7);transition:color .25s}
.foot-col ul a:hover{color:var(--accent)}
.foot-contact-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:14px;font-size:14px}
.foot-contact-row svg{width:16px;height:16px;color:var(--brand-light);flex:none;margin-top:3px}
.foot-bot{border-top:1px solid rgba(125,179,217,.15);padding:20px 0;font-size:13px}
.foot-bot .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-bot a{color:rgba(245,249,252,.5)}
.foot-bot a:hover{color:var(--accent)}

/* TRUST STRIP */
.trust{background:var(--ink);color:#F5F9FC;padding:28px 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.trust-item{display:flex;flex-direction:column;gap:6px;align-items:center}
.trust-item svg{width:28px;height:28px;color:var(--brand-light);margin-bottom:8px}
.trust-item .t{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:#fff}
.trust-item .s{font-size:12px;letter-spacing:.06em;color:rgba(245,249,252,.6)}

/* FLOATING PHONE BUTTON (右下角 - 这个店没有 AI Agent，所以用电话按钮) */
.float-phone{position:fixed;bottom:24px;right:24px;z-index:99;display:flex;align-items:center;gap:10px;background:radial-gradient(circle at 30% 30%,#E8C078 0%,var(--accent) 50%,var(--accent-dark) 100%);color:#fff;padding:16px 22px;border-radius:50px;font-size:15px;font-weight:600;letter-spacing:.04em;transition:all .3s;text-decoration:none;animation:phone-glow 2s ease-out infinite}
.float-phone:hover{transform:scale(1.08);animation:none;box-shadow:0 0 0 12px rgba(212,168,90,.15),0 16px 40px rgba(212,168,90,.7)}
.float-phone svg{width:20px;height:20px;flex:none}
.float-phone .ringing{animation:phone-ring 2s ease-in-out infinite}
@media(max-width:560px){.logo img{width:38px;height:38px}.logo .text .brand-name{font-size:20px}.logo .text p{font-size:9px;letter-spacing:.24em}.float-phone{padding:14px 18px;font-size:14px;bottom:16px;right:16px}.float-phone .label{display:none}}
@keyframes phone-glow{0%,100%{box-shadow:0 0 0 0 rgba(212,168,90,.7),0 8px 24px rgba(212,168,90,.5)}50%{box-shadow:0 0 0 18px rgba(212,168,90,0),0 12px 36px rgba(212,168,90,.8)}}
@keyframes phone-ring{0%,100%{transform:rotate(0)}10%,30%{transform:rotate(-15deg)}20%,40%{transform:rotate(15deg)}50%{transform:rotate(0)}}

/* RESPONSIVE */
@media(max-width:980px){
  .nav{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr 1fr;gap:24px}
  .page-head h1{font-size:38px}
  .section h2{font-size:30px}
  .content h2{font-size:26px}
}
@media(max-width:560px){
  .foot-grid{grid-template-columns:1fr}
  .page-head h1{font-size:30px}
  .section{padding:60px 0}
}

@media(max-width:560px){
  .hero{padding:8px 0 32px !important}
  .about,.services,.pricing,.gallery,.areas,.reviews,.values,.story,.svc-list,.pricing-block,.gal-page,.areas-page,.guide-body,.legal-body,.svc-body,.area-body,.area-other,.related,.related-posts,.blog-list,.blog-body,
  .page-head{padding:36px 0 30px !important}
  .page-head h1{font-size:26px !important}
  .hero h1{font-size:30px !important;line-height:1.15 !important}
  .section h2{font-size:24px !important}
  .section-head{margin-bottom:32px !important}
  .container{padding:0 18px !important}
  .hero-grid,.about-grid,.about-intro-grid,.story-grid,.svc-list-grid,.areas-grid,.area-grid,.contact-grid,.blog-feat,.values-grid{gap:32px !important}
  .svc-grid,.gal-grid,.gal-grid,.foot-grid,.related-grid,.related-posts .related-grid,.area-other-grid,.areas-grid-full{grid-template-columns:1fr !important;gap:18px !important}
  .price-grid{gap:20px !important}
  .price-card{padding:36px 24px !important}
  .price-card .amount{font-size:54px !important}
  .reviews-card{padding:32px 22px !important}
  .reviews-card h2{font-size:24px !important}
  .trust-grid{grid-template-columns:1fr 1fr !important;gap:18px 12px !important}
  .trust-item .t{font-size:15px !important}
  .trust-item .s{font-size:11px !important}
}
@media(max-width:768px){
  .about,.services,.pricing,.gallery,.areas,.reviews,.values,.story{padding:60px 0 !important}
  .hero h1{font-size:36px !important}
  .section h2{font-size:28px !important}
  .page-head{padding:42px 0 36px}
  .page-head h1{font-size:32px !important}
}

/* HAMBURGER MENU (mobile) */
.hamburger-toggle{display:none}
.hamburger-btn{display:none;background:transparent;border:0;cursor:pointer;padding:8px;margin-left:8px;flex:none}
.hamburger-btn svg{width:26px;height:26px;color:var(--brand-dark)}
@media(max-width:980px){
  .hamburger-btn{display:flex;align-items:center;justify-content:center}
  .nav{position:fixed;top:0;right:-100%;width:80%;max-width:320px;height:100vh;background:#fff;box-shadow:-4px 0 24px rgba(15,40,64,.18);transition:right .3s ease;z-index:200;display:block !important;padding:80px 24px 24px;overflow-y:auto}
  .nav ul{display:flex !important;flex-direction:column;gap:0}
  .nav li{border-bottom:1px solid var(--line)}
  .nav li a{display:block;padding:16px 8px;font-size:15px;letter-spacing:.06em}
  .nav li a::after{display:none}
  .hamburger-toggle:checked ~ .nav{right:0}
  .hamburger-toggle:checked ~ .hamburger-btn .open-icon{display:none}
  .hamburger-btn .close-icon{display:none}
  .hamburger-toggle:checked ~ .hamburger-btn .close-icon{display:block}
  .hamburger-toggle:checked ~ .hamburger-btn .open-icon{display:none}
  .nav-overlay{position:fixed;inset:0;background:rgba(15,40,64,.5);z-index:150;opacity:0;pointer-events:none;transition:opacity .3s}
  .hamburger-toggle:checked ~ .nav-overlay{opacity:1;pointer-events:auto}
}

@media(max-width:980px){.topbar{display:none}.header-cta{display:none}}

/* === Unified responsive typography === */
/* Mobile (≤560px) */
@media(max-width:560px){
  .hero h1,.page-head h1,.svc-top h1,.blog-top h1,.area-top h1{font-family:'Cormorant Garamond',serif !important;font-size:30px !important;line-height:1.2 !important;font-weight:500 !important;letter-spacing:0 !important}
  .section h2,.about-content h2,.about-intro-text h2,.story-text h2,.reviews-card h2,.contact-info h2,.area-content h2,.blog-feat-body h2,.svc-list-body h2,.content h2{font-family:'Cormorant Garamond',serif !important;font-size:22px !important;line-height:1.25 !important;font-weight:500 !important}
  .svc-card h3,.value-card h3,.blog-card-body h3{font-family:'Cormorant Garamond',serif !important;font-size:19px !important;line-height:1.3 !important;font-weight:500 !important}
  .content h3{font-size:18px !important}
  .hero h1 .lotus{font-size:22px !important}
  .hero-tag,.section-tag{font-size:10px !important;letter-spacing:.3em !important}
  .hero h1 em,.section h2 em,h2 em,h1 em{font-size:inherit !important}
}
/* Tablet (561px–768px) */
@media(max-width:768px) and (min-width:561px){
  .hero h1{font-size:42px !important;line-height:1.15 !important}
  .svc-top h1,.area-top h1{font-size:40px !important;line-height:1.15 !important}
  .blog-top h1,.page-head h1{font-size:36px !important;line-height:1.2 !important}
  .section h2,.about-content h2,.story-text h2,.about-intro-text h2,.reviews-card h2{font-size:32px !important;line-height:1.2 !important}
}

/* === Headline em - force Cormorant italic === */
h1 em,h2 em,h3 em{font-family:'Cormorant Garamond',serif !important;font-style:italic;font-weight:500}

/* CTA mobile fix */
@media(max-width:560px){
  .hero-cta-row{display:flex;gap:12px;width:100%}
  .hero-cta-row a{flex:1 1 0;text-align:center;justify-content:center;padding:16px 12px;font-size:14px;letter-spacing:.06em}
}

/* Header mobile padding */
@media(max-width:560px){.header{padding:12px 0}}

/* Hero h1 mobile fix */
@media(max-width:560px){
  .hero h1{font-size:30px !important;line-height:1.2 !important;letter-spacing:-.01em !important;margin-bottom:20px}
  
  .hero-sub{font-size:15px !important;line-height:1.65 !important;margin-bottom:28px}
}

/* Reviews h2 mobile bulletproof */
@media(max-width:560px){.reviews-card h2{font-family:'Cormorant Garamond',serif !important;font-size:22px !important;line-height:1.25 !important;font-weight:500 !important;letter-spacing:0 !important}}

/* Section head h2 desktop */
.section-head h2{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:500;line-height:1.15;color:var(--ink);letter-spacing:-.01em;text-align:center}

/* Section head h2 mobile */
@media(max-width:560px){.section-head h2{font-family:'Cormorant Garamond',serif !important;font-size:24px !important;line-height:1.2 !important;font-weight:500 !important;letter-spacing:0 !important}}
@media(max-width:768px) and (min-width:561px){.section-head h2{font-size:34px !important;line-height:1.2 !important}}
