:root{
  --rose:#ff6f91; --rose-dark:#e64f76; --orange:#ffbd6e; --violet:#7057ff;
  --ink:#2b2431; --muted:#756b7d; --bg:#fff7f9; --bg2:#fffaf0; --card:#ffffffd9;
  --line:rgba(43,36,49,.12); --shadow:0 22px 65px rgba(230,79,118,.18);
  --strong:0 32px 90px rgba(43,36,49,.18); --radius:24px;
}
*{box-sizing:border-box;margin:0;padding:0} html{scroll-behavior:smooth} body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans TC','Microsoft JhengHei',sans-serif;color:var(--ink);background:radial-gradient(circle at 8% 0%,rgba(255,111,145,.2),transparent 30%),radial-gradient(circle at 96% 4%,rgba(255,189,110,.24),transparent 32%),linear-gradient(135deg,var(--bg),var(--bg2));line-height:1.72;min-height:100vh} body.dark{--ink:#fff8fc;--muted:#d9cdd6;--bg:#17111d;--bg2:#251822;--card:rgba(37,28,44,.86);--line:rgba(255,255,255,.13);--shadow:0 22px 65px rgba(0,0,0,.35);--strong:0 32px 90px rgba(0,0,0,.42)}
a{color:inherit;text-decoration:none}.container{width:min(1180px,calc(100% - 36px));margin:auto}.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.72);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}body.dark .nav{background:rgba(23,17,29,.72)}.nav-inner{height:76px;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{display:flex;gap:12px;align-items:center;font-weight:950}.brand-mark{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--rose),var(--orange));box-shadow:var(--shadow)}.brand small{display:block;color:var(--muted);font-size:12px;font-weight:800}.nav-links{display:flex;gap:16px;align-items:center;font-weight:850;color:var(--muted);font-size:14px}.nav-links a:hover{color:var(--rose-dark)}.nav-actions{display:flex;align-items:center;gap:10px}.btn,.btn-soft,.btn-ghost,.mini-btn{border:0;border-radius:999px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;white-space:nowrap;transition:.22s ease}.btn{padding:13px 18px;color:#fff;background:linear-gradient(135deg,var(--rose),var(--orange));box-shadow:0 14px 32px rgba(255,111,145,.28)}.btn-soft{padding:12px 16px;color:var(--rose-dark);background:rgba(255,111,145,.12);border:1px solid rgba(255,111,145,.22)}.btn-ghost,.mini-btn{padding:12px 16px;color:var(--ink);background:var(--card);border:1px solid var(--line)}.mini-btn{padding:9px 12px}.btn:hover,.btn-soft:hover,.btn-ghost:hover,.mini-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.mobile-toggle{display:none}.hero{padding:68px 0 44px}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}.eyebrow{letter-spacing:.16em;color:var(--rose-dark);font-weight:950;font-size:13px;margin-bottom:12px}.hero h1{font-size:clamp(36px,5.2vw,66px);line-height:1.02;letter-spacing:-.06em;margin-bottom:18px}.gradient-text{background:linear-gradient(135deg,var(--rose),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-copy{font-size:18px;color:var(--muted);max-width:660px;margin-bottom:26px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:22px}.trust-row{display:flex;flex-wrap:wrap;gap:10px}.chip{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:8px 12px;color:var(--muted);font-size:13px;font-weight:850}.hero-card{border-radius:34px;background:linear-gradient(160deg,rgba(255,255,255,.88),rgba(255,255,255,.52));border:1px solid rgba(255,255,255,.58);box-shadow:var(--strong);padding:22px;position:relative;overflow:hidden}.hero-visual{min-height:520px;border-radius:28px;background:radial-gradient(circle at 20% 15%,rgba(255,111,145,.48),transparent 25%),radial-gradient(circle at 80% 20%,rgba(255,189,110,.52),transparent 30%),linear-gradient(135deg,#ffedf3,#fff5da);position:relative;display:grid;place-items:center;overflow:hidden}.visual-phone{width:min(320px,80%);background:#201724;border:10px solid #201724;border-radius:34px;box-shadow:0 26px 50px rgba(43,36,49,.26);overflow:hidden;transform:rotate(-3deg)}.phone-top{height:190px;background:linear-gradient(135deg,var(--rose),var(--orange));display:grid;place-items:center;color:#fff;text-align:center;padding:18px}.phone-body{background:#fff7fb;color:#2b2431;padding:18px;display:grid;gap:12px}.phone-row{display:flex;gap:10px;align-items:center;background:#fff;border-radius:18px;padding:12px;box-shadow:0 10px 22px rgba(43,36,49,.08)}.avatar-dot{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--rose),var(--violet));display:grid;place-items:center;color:#fff;font-weight:950}.float-card{position:absolute;left:22px;right:22px;bottom:22px;background:rgba(255,255,255,.9);color:#2b2431;border-radius:22px;border:1px solid rgba(255,255,255,.75);padding:16px;backdrop-filter:blur(14px);box-shadow:0 16px 40px rgba(43,36,49,.16)}section{padding:46px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:22px;margin-bottom:24px}.section-head h2{font-size:clamp(28px,3.6vw,46px);line-height:1.12;letter-spacing:-.045em}.section-head p{color:var(--muted);max-width:600px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.card h3{font-size:22px;margin-bottom:8px}.card p,.muted{color:var(--muted)}.icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(255,111,145,.14),rgba(255,189,110,.18));font-size:26px;margin-bottom:14px}.price{font-size:34px;font-weight:950;color:var(--rose-dark);margin:12px 0}.features{list-style:none;display:grid;gap:9px;margin-top:14px}.features li{display:flex;gap:8px;color:var(--muted)}.features li:before{content:'✓';font-weight:950;color:var(--rose-dark)}.flow{counter-reset:step;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.flow-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:var(--shadow)}.flow-card:before{counter-increment:step;content:counter(step);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--rose),var(--orange));color:#fff;font-weight:950;margin-bottom:10px}.profile{display:flex;gap:16px;align-items:flex-start}.profile-photo{width:82px;height:82px;border-radius:24px;background:linear-gradient(135deg,var(--rose),var(--orange));display:grid;place-items:center;color:#fff;font-size:32px;font-weight:950;flex:0 0 auto}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.tag{border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.44);padding:6px 10px;font-size:12px;font-weight:850;color:var(--muted)}body.dark .tag{background:rgba(255,255,255,.06)}.notice{border-left:5px solid var(--rose);background:linear-gradient(135deg,rgba(255,111,145,.13),rgba(255,189,110,.12));border-radius:20px;padding:18px}.form{display:grid;gap:14px}.field label{display:block;font-weight:900;margin-bottom:6px}.field input,.field select,.field textarea{width:100%;padding:13px 14px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.68);color:var(--ink);font:inherit;outline:none}body.dark .field input,body.dark .field select,body.dark .field textarea{background:rgba(255,255,255,.08)}textarea{min-height:116px;resize:vertical}.result{background:linear-gradient(135deg,rgba(255,111,145,.16),rgba(255,189,110,.16));border:1px solid var(--line);border-radius:22px;padding:20px;display:grid;gap:12px}.result-line{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed var(--line);padding-bottom:9px}.result-line:last-child{border:0}.big-number{font-size:34px;font-weight:950;color:var(--rose-dark)}.dashboard{display:grid;grid-template-columns:1.15fr .85fr;gap:20px}.stat{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:var(--shadow)}.stat strong{display:block;font-size:30px;color:var(--rose-dark);margin-top:4px}.bar{height:12px;border-radius:999px;background:rgba(255,111,145,.13);overflow:hidden}.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--rose),var(--orange));border-radius:999px}.table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:18px}.table th,.table td{text-align:left;padding:13px;border-bottom:1px solid var(--line)}.table th{color:var(--muted);font-size:13px}.status{border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;background:rgba(255,111,145,.13);color:var(--rose-dark)}.cta{margin:44px 0 54px;text-align:center;border-radius:34px;padding:44px 24px;color:#fff;background:linear-gradient(135deg,var(--rose),var(--orange));box-shadow:var(--strong)}.cta h2{font-size:clamp(30px,4vw,48px);line-height:1.14;margin-bottom:12px}.cta p{max-width:720px;margin:0 auto 22px;opacity:.92}.footer{border-top:1px solid var(--line);padding:34px 0;color:var(--muted)}.footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:20px}.footer a:hover{color:var(--rose-dark)}.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;background:rgba(20,14,24,.68);backdrop-filter:blur(12px);padding:18px}.modal.active{display:flex}.modal-box{width:min(860px,100%);max-height:90vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--strong)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--line)}.modal-body{padding:22px}.close-btn{width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,111,145,.12);color:var(--ink);font-size:22px;cursor:pointer}.toast{position:fixed;right:18px;bottom:18px;z-index:300;transform:translateY(130%);transition:.25s ease;background:#2b2431;color:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--strong)}.toast.show{transform:translateY(0)}.page-hero{padding:54px 0 22px}.page-hero h1{font-size:clamp(34px,4.8vw,56px);line-height:1.1;letter-spacing:-.05em;margin:10px 0}.breadcrumb{font-weight:850;color:var(--muted);font-size:14px}.checklist{display:grid;gap:12px}.check-item{display:flex;gap:12px;padding:14px;border-radius:18px;background:var(--card);border:1px solid var(--line)}.check-item b{color:var(--rose-dark)}.back-top{position:fixed;right:18px;bottom:82px;z-index:120;width:48px;height:48px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--orange));color:#fff;font-weight:950;box-shadow:var(--shadow);display:none}.back-top.show{display:block}.legal h2{margin:24px 0 10px}.legal h3{margin:18px 0 8px}.legal p,.legal li{color:var(--muted)}.legal ul{padding-left:22px}.print-only{display:none}
@media(max-width:980px){.hero-grid,.grid-3,.dashboard,.grid-2{grid-template-columns:1fr}.grid-4,.flow{grid-template-columns:repeat(2,1fr)}.nav-links{display:none;position:absolute;left:18px;right:18px;top:78px;flex-direction:column;align-items:flex-start;padding:18px;background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}.nav-links.open{display:flex}.mobile-toggle{display:inline-flex}.footer-grid{grid-template-columns:1fr 1fr}.hero-visual{min-height:440px}}
@media(max-width:620px){.nav-inner{height:auto;padding:12px 0}.brand small,.nav-actions .btn{display:none}.hero{padding-top:42px}.hero-actions{flex-direction:column}.grid-4,.flow,.footer-grid{grid-template-columns:1fr}.section-head{display:block}.profile{display:block}.profile-photo{margin-bottom:14px}.table{font-size:13px}.table th:nth-child(3),.table td:nth-child(3){display:none}}
@media print{.nav,.footer,.btn,.btn-soft,.btn-ghost,.mini-btn,.back-top{display:none!important}.print-only{display:block}body{background:#fff;color:#111}.card{box-shadow:none}}

/* LOGO 圖片 */
.site-logo {
  width: 200px;
  height: 100px;
  object-fit: contain;
  display: block;
}

/* 首頁推薦心伴師：從後台 companions 資料表讀取 */
.home-companion-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
  align-items: stretch;
}

.home-companion-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  overflow: hidden;
}

.home-companion-photo {
  width: 100%;
  aspect-ratio: 2 / 3;
  border-radius: 20px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--rose), var(--orange));
  color: #fff;
  font-size: 52px;
  font-weight: 950;
}

.home-companion-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.home-companion-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.home-companion-info h3 {
  font-size: 22px;
  line-height: 1.2;
  margin: 2px 0 0;
}

.home-companion-info p {
  font-size: 14px;
}

.home-companion-meta {
  display: grid;
  gap: 6px;
  margin-top: auto;
}

.home-companion-meta span {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.42);
  border-radius: 14px;
  padding: 7px 9px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

body.dark .home-companion-meta span {
  background: rgba(255,255,255,.06);
}

.home-companion-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.home-companion-actions .btn,
.home-companion-actions .btn-ghost {
  flex: 1;
  padding: 10px 12px;
  font-size: 14px;
}

@media (max-width: 1200px) {
  .home-companion-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 820px) {
  .home-companion-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 620px) {
  .site-logo {
    width: 150px;
    height: 75px;
  }

  .home-companion-list {
    grid-template-columns: 1fr;
  }

  .home-companion-photo {
    aspect-ratio: 3 / 4;
    border-radius: 18px;
  }

  .home-companion-actions {
    flex-direction: column;
  }
}


/* 首頁心伴師方案價格標籤 */
.home-companion-meta span {
  line-height: 1.35;
}
