/* ═══════════════════════════════════════════════
   沐曦水天堂 — Global Stylesheet
   Brand: Warm Gold #F2C97B / #C8913A + Navy #243F5E
   ═══════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans TC',sans-serif;color:#1E2D3D;background:#fff;}
img{max-width:100%;display:block;}
a{color:inherit;}

:root{
  --navy:#243F5E;
  --blue:#162C40;
  --gold:#C8913A;
  --gold-lt:#F2C97B;
  --cream:#FBF6EE;
  --cream2:#F4ECD8;
  --text:#1E2D3D;
  --text-lt:#5A6A7A;
  --stone:#8A8070;
  --green:#3A9A70;
}

/* ── TOP BAR ── */
.topbar{background:var(--navy);padding:10px 40px;display:flex;align-items:center;justify-content:space-between;font-size:14px;color:rgba(255,255,255,.65);}
.topbar-phone{color:var(--gold-lt);font-size:18px;font-weight:700;font-family:'Noto Serif TC',serif;letter-spacing:1px;}

/* ── NAV ── */
.site-nav{background:#fff;border-bottom:1px solid rgba(200,145,58,.15);padding:0 40px;height:68px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 16px rgba(36,63,94,.06);}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:'Noto Serif TC',serif;font-size:20px;font-weight:700;color:var(--navy);text-decoration:none;}
.nav-logo-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold-lt));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.nav-logo-icon i{font-size:20px;color:#fff;}
.nav-links{display:flex;gap:28px;list-style:none;}
.nav-links a{text-decoration:none;color:var(--text-lt);font-size:16px;padding-bottom:4px;transition:.2s;}
.nav-links a:hover{color:var(--navy);}
.nav-links a.active{color:var(--navy);font-weight:600;border-bottom:2px solid var(--gold);}
.nav-cta{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border:none;padding:10px 24px;border-radius:30px;font-size:15px;cursor:pointer;font-family:'Noto Sans TC',sans-serif;text-decoration:none;display:inline-block;transition:.2s;}
.nav-cta:hover{opacity:.9;}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s;}

/* ── HERO DARK (Homepage) ── */
.hero-dark{background:linear-gradient(150deg,#1A3050 0%,#243F5E 60%,#1E3855 100%);min-height:88vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:80px 40px 120px;}
.hero-dark .orb1{position:absolute;top:-100px;right:-80px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(242,201,123,.08) 0%,transparent 65%);pointer-events:none;}
.hero-dark .orb2{position:absolute;bottom:0;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(200,145,58,.06) 0%,transparent 65%);pointer-events:none;}
.hero-dark .star{position:absolute;border-radius:50%;background:rgba(242,201,123,.5);}
.hero-dark .s1{width:3px;height:3px;top:18%;left:22%;}
.hero-dark .s2{width:2px;height:2px;top:32%;left:45%;}
.hero-dark .s3{width:3px;height:3px;top:14%;right:28%;}
.hero-dark .s4{width:2px;height:2px;top:55%;right:18%;}
.hero-dark .s5{width:4px;height:4px;top:72%;left:32%;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1200px;margin:0 auto;width:100%;position:relative;z-index:1;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(242,201,123,.12);border:1px solid rgba(242,201,123,.25);color:var(--gold-lt);padding:8px 20px;border-radius:30px;font-size:15px;margin-bottom:24px;}
.hero-h1{font-family:'Noto Serif TC',serif;font-size:58px;font-weight:700;line-height:1.3;color:#fff;}
.hero-h1 em{font-style:normal;color:var(--gold-lt);}
.hero-sub{font-size:17px;color:rgba(255,255,255,.65);line-height:2;margin:20px 0 32px;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.btn-primary{background:linear-gradient(135deg,var(--gold),#B07A28);color:#fff;border:none;padding:14px 32px;border-radius:34px;font-size:17px;font-family:'Noto Sans TC',sans-serif;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:.2s;}
.btn-primary:hover{opacity:.9;}
.btn-outline{background:transparent;color:rgba(255,255,255,.85);border:1.5px solid rgba(255,255,255,.3);padding:14px 30px;border-radius:34px;font-size:17px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:.2s;}
.btn-outline:hover{background:rgba(255,255,255,.08);}
.hero-stats{display:flex;gap:36px;margin-top:44px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1);}
.stat-num{font-family:'Noto Serif TC',serif;font-size:36px;font-weight:700;color:var(--gold-lt);}
.stat-label{font-size:14px;color:rgba(255,255,255,.5);margin-top:3px;}
.hero-photos{position:relative;height:480px;}
.photo-card{position:absolute;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.12);}
.photo-card img{width:100%;height:100%;object-fit:cover;display:block;}
.photo-dog{width:280px;height:360px;right:20px;top:20px;}
.photo-cat{width:220px;height:280px;left:10px;bottom:20px;border:2px solid rgba(242,201,123,.3);}
.photo-badge{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:30px;padding:8px 20px;white-space:nowrap;font-size:13px;color:rgba(255,255,255,.8);}
.hero-curve{position:absolute;bottom:0;left:0;right:0;line-height:0;}
.hero-curve svg{display:block;width:100%;}

/* ── PAGE HERO (inner pages) ── */
.page-hero{background:linear-gradient(150deg,#1A3050 0%,#243F5E 60%,#1E3855 100%);padding:120px 40px 160px;position:relative;overflow:hidden;}
.page-hero .orb{position:absolute;border-radius:50%;pointer-events:none;}
.page-hero .orb1{width:500px;height:500px;top:-80px;right:-60px;background:radial-gradient(circle,rgba(242,201,123,.08) 0%,transparent 65%);}
.page-hero .orb2{width:400px;height:400px;bottom:-60px;left:-60px;background:radial-gradient(circle,rgba(200,145,58,.06) 0%,transparent 65%);}
.ph-inner{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1;}
.ph-tag{display:inline-block;font-size:12px;letter-spacing:4px;color:var(--gold-lt);text-transform:uppercase;margin-bottom:18px;background:rgba(242,201,123,.1);border:1px solid rgba(242,201,123,.2);padding:6px 18px;border-radius:20px;}
.ph-title{font-family:'Noto Serif TC',serif;font-size:50px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:16px;}
.ph-title em{font-style:normal;color:var(--gold-lt);}
.ph-sub{font-size:17px;color:rgba(255,255,255,.6);line-height:1.9;}

/* ── SECTION COMMON ── */
.section{padding:100px 40px;position:relative;overflow:hidden;}
.sec-inner{max-width:1200px;margin:0 auto;}
.sec-tag{display:block;font-size:13px;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:12px;font-weight:500;}
.sec-title{font-family:'Noto Serif TC',serif;font-size:40px;font-weight:700;color:var(--navy);margin-bottom:14px;line-height:1.3;}
.sec-sub{font-size:17px;color:var(--text-lt);line-height:1.9;}
.sec-center{text-align:center;}
.sec-curve{position:absolute;bottom:0;left:0;right:0;line-height:0;z-index:2;}
.sec-curve svg{display:block;width:100%;}

/* ── WHY ── */
.why-sec{background:#fff;padding-top:70px;}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px;}
.why-card{background:var(--cream);border-radius:20px;padding:36px 28px;border:1px solid rgba(200,145,58,.12);position:relative;overflow:hidden;transition:.3s;}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--gold),var(--gold-lt));}
.why-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(200,145,58,.1);}
.why-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.wi-green{background:linear-gradient(135deg,#EAF5F0,#C8E8D8);}.wi-green i{color:#3A9A70;}
.wi-gold{background:linear-gradient(135deg,#FDF0DC,#F5D89A);}.wi-gold i{color:var(--gold);}
.wi-navy{background:linear-gradient(135deg,#E4EEF8,#C8D8EE);}.wi-navy i{color:var(--navy);}
.why-icon i{font-size:26px;}
.why-num{font-family:'Noto Serif TC',serif;font-size:48px;font-weight:700;color:var(--gold);line-height:1;margin-bottom:6px;}
.why-num span{font-size:20px;}
.why-card h3{font-family:'Noto Serif TC',serif;font-size:22px;color:var(--navy);margin-bottom:10px;font-weight:600;}
.why-card p{font-size:15px;color:var(--text-lt);line-height:1.9;}

/* ── COMPARE ── */
.compare-sec{background:var(--cream);padding-top:80px;}
.compare-grid{display:grid;grid-template-columns:1fr 60px 1fr;gap:0;margin-top:50px;align-items:stretch;}
.cmp-card{border-radius:22px;overflow:hidden;box-shadow:0 8px 36px rgba(36,63,94,.1);}
.cmp-fire{background:linear-gradient(160deg,#2E2E2E,#1E1E1E);}
.cmp-fire .cmp-head{background:#1E1E1E;padding:28px;text-align:center;border-bottom:1px solid rgba(255,255,255,.07);}
.cmp-fire .cmp-icon-wrap{width:60px;height:60px;border-radius:50%;background:rgba(255,100,50,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.cmp-fire .cmp-icon-wrap i{font-size:32px;color:#FF6432;}
.cmp-fire .cmp-title{font-family:'Noto Serif TC',serif;font-size:22px;color:#fff;font-weight:700;}
.cmp-fire .cmp-sub{font-size:13px;color:rgba(255,255,255,.4);margin-top:4px;}
.cmp-fire .cmp-body{padding:24px 28px;}
.cmp-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05);}
.cmp-row:last-child{border-bottom:none;}
.cmp-dot{width:28px;height:28px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;}
.fire-dot{background:rgba(255,100,50,.1);}.fire-dot i{color:#FF6432;font-size:16px;}
.cmp-row strong{display:block;font-size:15px;font-family:'Noto Serif TC',serif;color:rgba(255,255,255,.7);margin-bottom:2px;}
.cmp-row span{font-size:14px;color:rgba(255,255,255,.38);line-height:1.7;}
.vs-center{display:flex;align-items:center;justify-content:center;}
.vs-badge{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center;font-family:'Noto Serif TC',serif;font-size:16px;font-weight:700;color:#fff;box-shadow:0 6px 20px rgba(36,63,94,.3);}
.cmp-water{background:linear-gradient(160deg,#F7F3EE,#FDF6EF);}
.cmp-water .cmp-head{background:linear-gradient(135deg,var(--navy),var(--blue));padding:28px;text-align:center;border-bottom:1px solid rgba(255,255,255,.1);}
.cmp-water .cmp-icon-wrap{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.cmp-water .cmp-icon-wrap i{font-size:32px;color:#fff;}
.cmp-water .cmp-title{font-family:'Noto Serif TC',serif;font-size:22px;color:#fff;font-weight:700;}
.cmp-water .cmp-sub{font-size:13px;color:rgba(255,255,255,.7);margin-top:4px;}
.cmp-water .cmp-body{padding:24px 28px;}
.cmp-water .cmp-row{border-bottom:1px solid rgba(36,63,94,.07);}
.water-dot{background:rgba(58,154,112,.1);}.water-dot i{color:#3A9A70;font-size:16px;}
.cmp-water .cmp-row strong{color:var(--navy);}
.cmp-water .cmp-row span{color:var(--stone);font-size:14px;line-height:1.7;}

/* ── PROCESS ── */
.process-sec{background:linear-gradient(160deg,#243F5E 0%,#162C40 100%);padding-top:80px;}
.process-sec .orb{position:absolute;border-radius:50%;pointer-events:none;}
.process-sec .orb1{width:500px;height:500px;top:-100px;right:-100px;background:radial-gradient(circle,rgba(242,201,123,.07) 0%,transparent 65%);}
.process-sec .orb2{width:400px;height:400px;bottom:-80px;left:-80px;background:radial-gradient(circle,rgba(200,145,58,.06) 0%,transparent 65%);}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px;position:relative;z-index:1;}
.proc-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:32px 24px;position:relative;overflow:hidden;transition:.3s;}
.proc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--gold),var(--gold-lt));}
.proc-card:hover{background:rgba(255,255,255,.08);transform:translateY(-4px);}
.proc-step{font-family:'Noto Serif TC',serif;font-size:48px;font-weight:700;color:rgba(242,201,123,.15);line-height:1;margin-bottom:16px;}
.proc-icon{width:48px;height:48px;border-radius:12px;background:rgba(242,201,123,.1);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.proc-icon i{font-size:24px;color:var(--gold-lt);}
.proc-card h3{font-family:'Noto Serif TC',serif;font-size:19px;color:#fff;margin-bottom:8px;font-weight:600;}
.proc-card p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.8;}

/* ── TESTIMONIALS ── */
.test-sec{background:#fff;padding-top:80px;}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.test-card{background:var(--cream);border-radius:20px;padding:32px;border:1px solid rgba(200,145,58,.1);}
.test-stars{display:flex;gap:4px;margin-bottom:16px;}
.test-stars i{color:var(--gold-lt);font-size:18px;}
.test-card p{font-size:15px;color:var(--text-lt);line-height:2;font-style:italic;margin-bottom:20px;}
.test-author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid rgba(200,145,58,.12);}
.test-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-lt));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.test-avatar i{font-size:20px;color:#fff;}
.test-name{font-weight:600;font-size:15px;color:var(--navy);}
.test-pet{font-size:13px;color:var(--stone);}

/* ── BRAND STATEMENT ── */
.brand-sec{background:linear-gradient(160deg,#243F5E 0%,#162C40 100%);padding:100px 40px;position:relative;overflow:hidden;}
.brand-sec .orb1{position:absolute;width:500px;height:500px;top:-100px;right:-80px;border-radius:50%;background:radial-gradient(circle,rgba(242,201,123,.1) 0%,transparent 65%);pointer-events:none;}
.brand-sec .orb2{position:absolute;width:400px;height:400px;bottom:-80px;left:-60px;border-radius:50%;background:radial-gradient(circle,rgba(200,145,58,.08) 0%,transparent 65%);pointer-events:none;}
.brand-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.brand-tag2{display:inline-block;font-size:12px;letter-spacing:4px;color:var(--gold-lt);margin-bottom:16px;text-transform:uppercase;}
.brand-title{font-family:'Noto Serif TC',serif;font-size:44px;font-weight:700;color:#fff;line-height:1.4;margin-bottom:24px;}
.brand-title em{font-style:normal;color:var(--gold-lt);}
.brand-poem{font-family:'Noto Serif TC',serif;font-size:17px;color:rgba(255,255,255,.7);line-height:2.4;border-left:3px solid var(--gold);padding-left:22px;}
.brand-poem p{margin-bottom:8px;}
.brand-right{background:rgba(255,255,255,.04);border-radius:24px;padding:38px;border:1px solid rgba(255,255,255,.07);}
.brand-desc{font-size:17px;color:rgba(255,255,255,.6);line-height:2.2;margin-bottom:18px;}
.brand-hl{background:rgba(200,145,58,.1);border:1px solid rgba(200,145,58,.22);border-radius:14px;padding:18px 22px;margin-top:20px;}
.brand-hl p{font-family:'Noto Serif TC',serif;font-size:17px;color:var(--gold-lt);line-height:2;}

/* ── ABOUT ── */
.about-sec{background:var(--cream);padding:100px 40px;position:relative;overflow:hidden;}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;max-width:1200px;margin:0 auto;}
.about-sec p{color:var(--text-lt);font-size:17px;line-height:2.1;margin-bottom:14px;}
.about-feats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px;}
.about-feat{background:#fff;border-radius:14px;padding:18px;border:1px solid rgba(200,145,58,.12);transition:.3s;}
.about-feat:hover{box-shadow:0 6px 24px rgba(200,145,58,.1);}
.about-feat-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;}
.af-green{background:linear-gradient(135deg,#EAF5F0,#C8E8D8);}.af-green i{color:#3A9A70;}
.af-gold{background:linear-gradient(135deg,#FDF0DC,#F5D89A);}.af-gold i{color:var(--gold);}
.af-navy{background:linear-gradient(135deg,#E4EEF8,#C8D8EE);}.af-navy i{color:var(--navy);}
.af-stone{background:linear-gradient(135deg,#EEE9E3,#DDD4C8);}.af-stone i{color:var(--stone);}
.about-feat-icon i{font-size:17px;}
.about-feat h4{font-family:'Noto Serif TC',serif;font-size:17px;color:var(--navy);margin-bottom:4px;font-weight:600;}
.about-feat p{font-size:14px;color:var(--stone);line-height:1.7;margin:0;}
.about-photos{display:grid;gap:12px;}
.about-main-photo{border-radius:18px;overflow:hidden;height:280px;}
.about-main-photo img{width:100%;height:100%;object-fit:cover;}
.about-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;}
.asc{background:#fff;border-radius:14px;padding:18px;border:1px solid rgba(200,145,58,.12);position:relative;overflow:hidden;}
.asc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--gold),var(--gold-lt));}
.asc-num{font-family:'Noto Serif TC',serif;font-size:32px;font-weight:700;color:var(--gold);}
.asc-label{font-size:13px;color:var(--stone);margin-top:4px;}

/* ── SERVICE PACKAGES ── */
.service-sec{background:#fff;padding:100px 40px;position:relative;overflow:hidden;}
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
.pkg-card{border-radius:22px;overflow:hidden;border:2px solid transparent;box-shadow:0 4px 24px rgba(36,63,94,.07);transition:.35s;}
.pkg-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(36,63,94,.12);}
.pkg-card.featured{border-color:var(--gold);}
.pkg-head{padding:28px 24px;text-align:center;background:linear-gradient(160deg,#F7F3EE,var(--cream));}
.pkg-card.featured .pkg-head{background:linear-gradient(135deg,var(--navy),var(--blue));}
.pkg-badge{display:inline-block;font-size:11px;letter-spacing:2px;background:rgba(200,145,58,.12);color:var(--gold);border:1px solid rgba(200,145,58,.2);padding:4px 12px;border-radius:20px;margin-bottom:12px;}
.pkg-card.featured .pkg-badge{background:rgba(242,201,123,.15);color:var(--gold-lt);border-color:rgba(242,201,123,.3);}
.pkg-name{font-family:'Noto Serif TC',serif;font-size:22px;font-weight:700;color:var(--navy);}
.pkg-card.featured .pkg-name{color:#fff;}
.pkg-price{font-family:'Noto Serif TC',serif;font-size:36px;font-weight:700;color:var(--gold);margin:10px 0 4px;}
.pkg-card.featured .pkg-price{color:var(--gold-lt);}
.pkg-price small{font-size:16px;color:var(--stone);}
.pkg-card.featured .pkg-price small,.pkg-card.featured .pkg-head small{color:rgba(255,255,255,.7);}
.pkg-body{padding:24px;}
.pkg-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(200,145,58,.08);font-size:14px;color:var(--text-lt);}
.pkg-item:last-child{border-bottom:none;}
.pkg-item i{font-size:17px;color:var(--green);flex-shrink:0;}
.pkg-btn{display:block;text-align:center;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;padding:13px;border-radius:12px;font-size:15px;text-decoration:none;margin:6px 24px 24px;transition:.2s;}
.pkg-btn:hover{opacity:.85;}
.pkg-card.featured .pkg-btn{background:linear-gradient(135deg,var(--gold),#B07A28);}

/* ── ADD-ONS ── */
.addon-sec{background:var(--cream);padding:100px 40px;position:relative;overflow:hidden;}
.addon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
.addon-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 18px rgba(36,63,94,.06);transition:.3s;}
.addon-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(36,63,94,.1);}
.addon-photo{height:160px;position:relative;overflow:hidden;}
.addon-photo img{width:100%;height:100%;object-fit:cover;}
.addon-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(36,63,94,.6),transparent);}
.addon-body{padding:20px;}
.addon-name{font-family:'Noto Serif TC',serif;font-size:18px;color:var(--navy);font-weight:600;margin-bottom:6px;}
.addon-desc{font-size:13px;color:var(--stone);line-height:1.7;margin-bottom:12px;}
.addon-price{font-family:'Noto Serif TC',serif;font-size:22px;font-weight:700;color:var(--gold);}
.addon-price small{font-size:13px;color:var(--stone);}

/* ── URNS ── */
.urn-sec{background:#fff;padding:100px 40px;position:relative;overflow:hidden;}
.urn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.urn-card{border-radius:20px;overflow:hidden;box-shadow:0 4px 18px rgba(36,63,94,.07);transition:.3s;}
.urn-card:hover{transform:translateY(-4px);}
.urn-photo{height:220px;overflow:hidden;}
.urn-photo img{width:100%;height:100%;object-fit:cover;}
.urn-body{padding:22px;background:var(--cream);}
.urn-name{font-family:'Noto Serif TC',serif;font-size:19px;color:var(--navy);font-weight:600;margin-bottom:6px;}
.urn-desc{font-size:14px;color:var(--stone);line-height:1.7;margin-bottom:12px;}
.urn-price{font-family:'Noto Serif TC',serif;font-size:24px;font-weight:700;color:var(--gold);}

/* ── CHARITY ── */
.charity-sec{background:var(--cream);padding:100px 40px;position:relative;overflow:hidden;}
.charity-inner{max-width:1200px;margin:0 auto;}
.charity-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:50px;}
.cp-card{background:#fff;border-radius:20px;padding:36px 28px;border:1px solid rgba(200,145,58,.1);position:relative;overflow:hidden;}
.cp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--gold),var(--gold-lt));}
.cp-icon2{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.cpi-green{background:linear-gradient(135deg,#EAF5F0,#C8E8D8);}.cpi-green i{color:#3A9A70;}
.cpi-gold{background:linear-gradient(135deg,#FDF0DC,#F5D89A);}.cpi-gold i{color:var(--gold);}
.cpi-navy{background:linear-gradient(135deg,#E4EEF8,#C8D8EE);}.cpi-navy i{color:var(--navy);}
.cp-icon2 i{font-size:28px;}
.cp-card h3{font-family:'Noto Serif TC',serif;font-size:22px;color:var(--navy);margin-bottom:10px;font-weight:600;}
.cp-card p{font-size:15px;color:var(--text-lt);line-height:1.9;}
.charity-cta{background:linear-gradient(135deg,var(--navy),var(--blue));border-radius:24px;padding:56px;text-align:center;margin-top:60px;position:relative;overflow:hidden;}
.charity-cta .orb{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(242,201,123,.1) 0%,transparent 65%);top:-60px;right:-60px;pointer-events:none;}
.charity-cta h2{font-family:'Noto Serif TC',serif;font-size:32px;font-weight:700;color:#fff;margin-bottom:10px;position:relative;z-index:1;}
.charity-cta p{font-size:16px;color:rgba(255,255,255,.65);margin-bottom:28px;position:relative;z-index:1;}
.charity-cta-phone{font-family:'Noto Serif TC',serif;font-size:36px;font-weight:700;color:var(--gold-lt);position:relative;z-index:1;}
.charity-cta-btns{margin-top:24px;position:relative;z-index:1;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── FAQ ── */
.faq-sec{background:#fff;padding:100px 40px;position:relative;overflow:hidden;}
.faq-layout{display:grid;grid-template-columns:1fr 320px;gap:50px;max-width:1200px;margin:60px auto 0;}
.faq-list{display:flex;flex-direction:column;gap:12px;}
.faq-item{background:var(--cream);border-radius:16px;border:1px solid rgba(200,145,58,.1);overflow:hidden;}
.faq-item summary{padding:20px 24px;font-family:'Noto Serif TC',serif;font-size:17px;color:var(--navy);cursor:pointer;display:flex;align-items:center;gap:14px;font-weight:600;list-style:none;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-num{font-size:13px;color:var(--gold);font-weight:700;width:24px;flex-shrink:0;}
.faq-item p{padding:0 24px 20px 62px;font-size:15px;color:var(--text-lt);line-height:2;}
.faq-sidebar-card{background:linear-gradient(135deg,var(--navy),var(--blue));border-radius:20px;padding:32px;color:#fff;position:sticky;top:90px;}
.faq-sidebar-card h3{font-family:'Noto Serif TC',serif;font-size:20px;font-weight:700;margin-bottom:20px;color:var(--gold-lt);}
.faq-contact-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);}
.faq-contact-item:last-child{border-bottom:none;}
.fci-icon{width:36px;height:36px;border-radius:9px;background:rgba(242,201,123,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.fci-icon i{font-size:18px;color:var(--gold-lt);}
.fci-label{font-size:12px;color:rgba(255,255,255,.5);margin-bottom:2px;}
.fci-val{font-size:15px;color:#fff;font-weight:500;}
.faq-sidebar-btn{width:100%;background:linear-gradient(135deg,var(--gold),#B07A28);color:#fff;border:none;padding:13px;border-radius:12px;font-size:16px;font-family:'Noto Serif TC',serif;cursor:pointer;margin-top:24px;display:block;text-align:center;text-decoration:none;}

/* ── CONTACT ── */
.contact-sec{background:var(--cream);padding:100px 40px;position:relative;overflow:hidden;}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:1200px;margin:0 auto;}
.contact-info h2{font-family:'Noto Serif TC',serif;font-size:32px;font-weight:700;color:var(--navy);margin-bottom:28px;}
.contact-items{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;}
.contact-item{display:flex;align-items:flex-start;gap:16px;background:#fff;padding:18px 22px;border-radius:16px;border:1px solid rgba(200,145,58,.1);}
.ci-icon{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ci-icon i{font-size:22px;color:var(--gold-lt);}
.ci-label{font-size:13px;color:var(--stone);margin-bottom:3px;}
.ci-val{font-size:16px;color:var(--navy);font-weight:600;}
.contact-social-title{font-family:'Noto Serif TC',serif;font-size:20px;color:var(--navy);margin-bottom:16px;font-weight:600;}
.contact-social{display:flex;gap:10px;flex-wrap:wrap;}
.social-link{display:flex;align-items:center;gap:8px;background:#fff;padding:10px 16px;border-radius:30px;border:1px solid rgba(200,145,58,.15);font-size:14px;color:var(--navy);text-decoration:none;transition:.2s;}
.social-link:hover{background:var(--cream);border-color:var(--gold);}
.social-link i{font-size:18px;color:var(--gold);}
.social-link svg{width:18px;height:18px;fill:var(--gold);flex-shrink:0;}
.contact-form{background:#fff;border-radius:24px;padding:40px;border:1px solid rgba(200,145,58,.12);}
.contact-form h3{font-family:'Noto Serif TC',serif;font-size:24px;color:var(--navy);margin-bottom:24px;font-weight:600;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:14px;color:var(--text-lt);margin-bottom:6px;font-weight:500;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid rgba(200,145,58,.2);border-radius:10px;font-size:15px;font-family:'Noto Sans TC',sans-serif;color:var(--text);background:var(--cream);outline:none;transition:.2s;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);}
.form-group textarea{height:110px;resize:vertical;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-submit{width:100%;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border:none;padding:15px;border-radius:12px;font-size:17px;font-family:'Noto Serif TC',serif;cursor:pointer;margin-top:8px;transition:.2s;}
.form-submit:hover{opacity:.9;}

/* ── EMERGENCY BAR ── */
.emergency{background:linear-gradient(135deg,#1A3050,#243F5E);padding:24px 40px;text-align:center;}
.emergency p{font-size:15px;color:rgba(255,255,255,.7);margin-bottom:6px;}
.emergency .phone{font-family:'Noto Serif TC',serif;font-size:42px;font-weight:700;color:var(--gold-lt);}

/* ── FOOTER ── */
.site-footer{background:linear-gradient(160deg,#243F5E,#162C40);padding:60px 40px 30px;position:relative;}
.site-footer .orb{position:absolute;width:400px;height:400px;top:-100px;right:-80px;border-radius:50%;background:radial-gradient(circle,rgba(242,201,123,.06) 0%,transparent 65%);pointer-events:none;}
.footer-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand .logo{display:flex;align-items:center;gap:10px;font-family:'Noto Serif TC',serif;font-size:20px;font-weight:700;color:#fff;margin-bottom:16px;text-decoration:none;}
.footer-brand .logo-icon{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--gold),var(--gold-lt));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.footer-brand .logo-icon i{font-size:18px;color:#fff;}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.9;margin-bottom:20px;}
.footer-social{display:flex;gap:10px;flex-wrap:wrap;}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(200,145,58,.1);border:1px solid rgba(200,145,58,.2);display:flex;align-items:center;justify-content:center;color:var(--gold-lt);font-size:18px;text-decoration:none;transition:.2s;flex-shrink:0;}
.footer-social a:hover{background:rgba(200,145,58,.2);}
.footer-social a svg{width:18px;height:18px;fill:var(--gold-lt);}
.footer-col h4{font-family:'Noto Serif TC',serif;font-size:16px;font-weight:600;color:#fff;margin-bottom:18px;}
.footer-col ul{list-style:none;}
.footer-col li{padding:6px 0;}
.footer-col a{text-decoration:none;font-size:14px;color:rgba(255,255,255,.5);transition:.2s;}
.footer-col a:hover{color:var(--gold-lt);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:10px;}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,.3);}

/* ── LINE FLOAT BUTTON ── */
.line-float{position:fixed;bottom:28px;right:24px;z-index:999;width:56px;height:56px;background:#06C755;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(6,199,85,.4);text-decoration:none;transition:.2s;}
.line-float:hover{transform:scale(1.08);}
.line-float svg{width:30px;height:30px;fill:#fff;}

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media(max-width:1024px){
  .why-grid,.process-grid,.test-grid{grid-template-columns:repeat(2,1fr);}
  .pkg-grid{grid-template-columns:repeat(2,1fr);}
  .addon-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-photos{display:none;}
  .hero-h1{font-size:44px;}
  .brand-inner,.about-inner,.contact-layout{grid-template-columns:1fr;gap:40px;}
  .compare-grid{grid-template-columns:1fr;}.vs-center{padding:14px 0;}
  .faq-layout{grid-template-columns:1fr;}
  .ph-title{font-size:38px;}
  .faq-sidebar-card{position:static;}
}
@media(max-width:768px){
  .topbar{padding:8px 20px;font-size:12px;}.topbar-phone{font-size:15px;}
  .site-nav{padding:0 20px;}
  .nav-links,.nav-cta{display:none;}
  .nav-hamburger{display:flex;}
  .site-nav.open .nav-links{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:#fff;padding:20px;gap:0;border-bottom:1px solid rgba(200,145,58,.15);box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:99;}
  .site-nav.open .nav-links a{padding:14px 0;border-bottom:1px solid rgba(200,145,58,.08);display:block;}
  .site-nav.open .nav-cta{display:block;margin:16px;text-align:center;}
  .hero-dark{padding:80px 20px 100px;}
  .hero-h1{font-size:36px;}
  .hero-stats{flex-wrap:wrap;gap:20px;}
  .section,.brand-sec,.about-sec,.contact-sec,.faq-sec,.service-sec,.addon-sec,.urn-sec,.charity-sec{padding:70px 20px;}
  .page-hero{padding:90px 20px 120px;}
  .emergency{padding:20px;}.emergency .phone{font-size:32px;}
  .why-grid,.test-grid{grid-template-columns:1fr;}
  .pkg-grid,.addon-grid,.urn-grid,.charity-pillars{grid-template-columns:1fr;}
  .process-grid{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr;gap:24px;}
  .about-feats{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .charity-cta{padding:36px 24px;}
  .charity-cta-btns{flex-direction:column;align-items:center;}
  .site-footer{padding:50px 20px 24px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .contact-form{padding:24px 20px;}
}
@media(max-width:480px){
  .hero-h1{font-size:30px;}
  .hero-badge{font-size:13px;}
  .ph-title{font-size:30px;}
  .sec-title{font-size:28px;}
  .brand-title{font-size:32px;}
  .hero-btns{flex-direction:column;}
  .process-grid{grid-template-columns:1fr;}
  .btn-primary,.btn-outline{width:100%;justify-content:center;}
}

/* ── Scroll Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease;}
.reveal.visible{opacity:1;transform:none;}
