:root{
  --bg:#fff8fb;
  --bg-2:#fce8f0;
  --surface:#ffffff;
  --surface-soft:#fff7fa;
  --ink:#4a3940;
  --muted:#7e6a73;
  --line:#f0dbe4;
  --line-strong:#e8c8d5;
  --pink:#f58ca6;
  --pink-deep:#ee7595;
  --rose:#ffb7c8;
  --mint:#8fd6d8;
  --mint-deep:#68c4c6;
  --cream:#fff6ea;
  --shadow:0 16px 38px rgba(238,117,149,.10);
  --shadow-soft:0 8px 22px rgba(94,66,78,.07);
  --radius:22px;
  --container:min(1180px, calc(100% - 2rem));
  --container-wide:min(1560px, calc(100% - 3.5rem));
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:"Noto Sans TC","PingFang TC","Microsoft JhengHei",system-ui,sans-serif;
  line-height:1.75;
  background:var(--bg);
}

h1,h2,h3,h4{font-family:'Noto Serif TC','PingFang TC',serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:var(--container);margin-inline:auto}
.container-wide{width:var(--container-wide);margin-inline:auto}

.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{
  left:1rem;top:1rem;z-index:200;
  padding:.5rem .8rem;border-radius:10px;background:#222;color:#fff;
}

.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,250,252,.78);
  backdrop-filter: blur(16px);
  border-bottom:1px solid rgba(240,219,228,.85);
  isolation:isolate;
}
.site-header::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:rgba(232,200,213,.9);
  pointer-events:none;
}
.site-header.is-scrolled{
  box-shadow:0 18px 40px rgba(94,66,78,.10);
  background:rgba(255,250,252,.90);
}

.header-inner{
  min-height:86px;
  padding:.55rem 0;
  display:flex;align-items:center;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.75rem;min-width:0}
.brand-logo{
  width:56px;height:56px;border-radius:18px;object-fit:cover;
  border:2px solid #fff;
  box-shadow:0 8px 20px rgba(245,140,166,.18);
}
.brand-text{display:grid;line-height:1.15}
.brand-text strong{
  font-size:1.06rem;letter-spacing:.02em;color:var(--ink);
}
.brand-text small{font-size:.76rem;color:var(--muted);margin-top:.22rem}

.site-nav{margin-inline:auto}
.site-nav ul{
  list-style:none;margin:0;padding:.26rem;
  display:flex;gap:.25rem;align-items:center;
  border:1px solid rgba(240,219,228,.9);
  background:rgba(255,255,255,.70);
  border-radius:999px;
  box-shadow:0 10px 26px rgba(94,66,78,.06);
}
.site-nav a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.56rem .92rem;border-radius:999px;
  color:var(--muted);font-weight:800;
  border:1px solid transparent;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.site-nav a:hover{
  background:#fff;border-color:rgba(240,219,228,.9);color:var(--ink);
  box-shadow:0 8px 18px rgba(255,183,200,.14);
  transform:translateY(-1px);
}
.site-nav a.active{
  background:var(--pink);
  color:#fff;
  box-shadow:0 14px 28px rgba(238,117,149,.22);
}

.header-right{
  display:flex;align-items:center;gap:.6rem;
}
.header-social{
  display:flex;align-items:center;gap:.35rem;
  padding:.22rem .25rem;
  border:1px solid rgba(240,219,228,.85);
  background:rgba(255,255,255,.60);
  border-radius:999px;
}
.icon-btn{
  width:40px;height:40px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  color:#6f5a64;
  font-weight:900;
  letter-spacing:.02em;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}
.icon-btn:hover{
  transform:translateY(-1px);
  background:#fff;
  border-color:rgba(240,219,228,.9);
  box-shadow:0 12px 26px rgba(94,66,78,.08);
  color:#d85f84;
}

.header-cta{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:.72rem 1.05rem;
  font-weight:900;color:#fff;
  background:var(--pink);
  box-shadow:0 14px 30px rgba(238,117,149,.22);
  transition:transform .16s ease, background .16s ease, box-shadow .16s ease;
}
.header-cta:hover{transform:translateY(-1px);background:var(--pink-deep)}

.desktop-cta{display:inline-flex}

.nav-toggle{
  display:none;
  margin-left:auto;
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--line);background:#fff;cursor:pointer;
  padding:10px;
}
.nav-toggle span{
  display:block;height:2px;background:var(--ink);border-radius:999px;
}
.nav-toggle span + span{margin-top:6px}

/* ── Hero ─────────────────────────────────── */
.hero-shell{padding:4rem 0 3rem}
.panel{
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
}

.hero-grid{
  display:grid;
  grid-template-columns:1.03fr .97fr;
  gap:2rem;
  align-items:stretch;
}
.hero-copy{padding:3rem 2.5rem 2.5rem;display:flex;flex-direction:column}
.eyebrow{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.35rem .75rem;border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--muted);
  font-size:.88rem;font-weight:700;
}
.eyebrow.pink{
  background:#fff4f8;border-color:#ffd8e4;color:#db6084;
}
.hero-copy h1{
  margin:1rem 0 .85rem;
  font-size:clamp(1.35rem, 1.3vw + 0.8rem, 1.9rem);
  line-height:1.14;
  letter-spacing:.01em;
}
.hero-copy h1 span{
  display:inline-block;
  color:#cc5d7e;
}
.hero-copy p{margin:.55rem 0;color:var(--muted)}

.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.4rem;
  border-radius:14px;padding:.8rem 1.1rem;
  border:1px solid var(--line);
  background:#fff;color:var(--ink);
  font-weight:800;cursor:pointer;
  box-shadow:0 4px 14px rgba(94,66,78,.04);
  transition:transform .15s ease, box-shadow .15s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(94,66,78,.08)}
.btn-primary{
  color:#fff;border-color:transparent;
  background:var(--pink);
  box-shadow:0 12px 24px rgba(238,117,149,.18);
}
.btn-secondary{
  background:var(--surface-soft);
}

.icon-list{
  list-style:none;padding:0;margin:1.25rem 0 0;
  flex:1;
  display:flex;flex-direction:column;justify-content:space-evenly;
  font-size:1rem;
}
.icon-list li{
  position:relative;padding-left:1.5rem;color:#715d66;font-weight:600;
}
.icon-list li::before{
  content:"";
  position:absolute;left:0;top:.52rem;
  width:.65rem;height:.65rem;border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 0 4px rgba(245,140,166,.12);
}

.hero-visual{
  position:relative;
  padding:1.5rem;
  overflow:hidden;
  background:#fff;
}
.hero-visual::before{content:"";display:none}
.hero-visual::after{content:"";display:none}
.hero-visual-main{
  position:relative;z-index:1;
  border-radius:22px;overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.hero-visual-main img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
}

.hero-floating{
  position:absolute;z-index:2;
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow-soft);
  padding:.65rem .8rem;
  max-width:240px;
}
.hero-floating span{
  display:block;font-size:.78rem;color:var(--muted);font-weight:700;
}
.hero-floating strong{
  display:block;font-size:.95rem;line-height:1.25;margin-top:.15rem;
}
.hero-floating a{color:#d95f84;font-weight:800;font-size:.85rem}
.floating-price{right:1.1rem;bottom:1.1rem}
.floating-note{left:1.1rem;top:1.1rem}

/* ── Sections ────────────────────────────── */
.section{padding:5rem 0}
main > .section:nth-child(even){background:var(--bg-2)}

.section-title{
  margin-bottom:2.5rem;
}
.section-title h2{
  margin:0 0 .55rem;
  line-height:1.14;
  font-size:clamp(1.55rem, 1.3vw + 1rem, 2.5rem);
}
.section-title p{margin:0;color:var(--muted);line-height:1.75;font-size:1.02rem}
.section-title.compact{margin-bottom:1.5rem}

.section-soft-grid{
  position:relative;
}
.section-soft-grid::before{
  content:"";
  position:absolute;left:0;right:0;top:14px;bottom:14px;
  border-radius:28px;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(240,219,228,.65);
  opacity:1;
  pointer-events:none;
}
.section-soft-grid > .container{position:relative;z-index:1}

.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.75rem}
.feature-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;
}

.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-soft);
  padding:1.75rem 2rem;
  transition:box-shadow .25s ease,transform .2s ease;
}
.card:hover{
  box-shadow:0 20px 45px rgba(238,117,149,.15);
  transform:translateY(-3px);
}
.card h2,.card h3{margin:.05rem 0 .6rem;line-height:1.22}
.card p{margin:.3rem 0;color:var(--muted)}
.card ul{margin:.4rem 0 0 1rem;padding:0}
.card li{margin:.3rem 0}

.pastel-card{background:#fff4f8}
.pastel-card.mint{
  background:#f3fcfd;
  border-color:#d8eff0;
}

.split-showcase{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:2rem;align-items:center;
}
.split-showcase.reverse{grid-template-columns:1fr 1fr}
.split-showcase.reverse .image-frame{order:1}
.split-showcase.reverse .showcase-copy{order:2}

.showcase-copy h2{
  margin:.55rem 0 .65rem;
  line-height:1.2;
  font-size:clamp(1.25rem, 1vw + .95rem, 1.85rem);
}
.showcase-copy p{margin:.4rem 0;color:var(--muted)}

.image-frame{
  margin:0;
  border-radius:24px;overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow);
}
.image-frame.large img{aspect-ratio:4/3;object-fit:cover}
.image-frame.soft{
  background:#fff;
}
.image-frame.soft img{max-width:78%;margin-inline:auto;padding:1rem}
.image-frame img{width:100%}

.poster-card{
  padding:.8rem;
  background:#fff;
}
.poster-head p{font-size:.95rem}
.poster-link{
  display:block;border-radius:16px;overflow:hidden;margin-top:.5rem;
  border:1px solid var(--line);background:#fff;
}
.poster-link img{
  width:100%;
  max-height:470px;
  object-fit:cover;
  object-position:center top;
}

/* ── Inner pages ─────────────────────────── */
.page-hero{padding:3rem 0 2rem}
.page-title-wrap{
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:2.5rem 2.5rem 2rem;
}
.page-title-wrap h1{
  margin:.45rem 0 .4rem;
  font-size:clamp(1.45rem,1.2vw + 1rem,2.2rem);
  line-height:1.18;
}
.page-title-wrap p{margin:.3rem 0 0;color:var(--muted)}
.breadcrumb{
  color:var(--muted);font-size:.9rem;
}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{text-decoration:underline}

.hero-poster{
  margin:0;
  padding:.75rem;
  border-radius:26px;
}
.hero-poster img{
  width:100%;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
}

.list-check{
  list-style:none;margin:0;padding:0;display:grid;gap:.6rem;
}
.list-check li{
  position:relative;
  padding:.72rem .85rem .72rem 2.2rem;
  border:1px solid #f4e1e8;
  border-radius:14px;
  background:#fff;
  color:#6f5d66;
  line-height:1.55;
}
.list-check li::before{
  content:"✓";
  position:absolute;left:.78rem;top:.68rem;
  color:#dd6488;font-weight:900;
}
.notice{
  margin-top:1.1rem;
  border:1px solid #f2d6e0;
  border-left:4px solid var(--pink);
  background:#fff4f8;
  border-radius:14px;
  padding:.9rem 1rem;
  color:#725f68;
}
.notice.warning{
  border-left-color:#e88181;
  background:#fff6f6;
  border-color:#f4d9dc;
}
.notice.success{
  border-left-color:var(--mint-deep);
  background:#f2fcfd;
  border-color:#d9f0f1;
}

.badge-row{
  display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem;
}
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.34rem .62rem;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  color:var(--muted);font-size:.84rem;font-weight:700;
}

.table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.table th,.table td{
  padding:.85rem .9rem;
  border-bottom:1px solid #f4e5ec;
  text-align:left;vertical-align:top;
}
.table th{
  background:#fff1f6;
  color:#805868;
}
.table tr:last-child td{border-bottom:0}

.cta-banner{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:2rem 2.5rem;
  box-shadow:var(--shadow-soft);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.cta-banner h3{
  margin:.2rem 0 .4rem;
  line-height:1.22;
  font-size:clamp(1.1rem, .8vw + .9rem, 1.4rem);
}
.cta-banner p{margin:.15rem 0}

.contact-layout{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:1.75rem;
}
.panel-mini{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:.9rem 1rem;
}
.contact-brand{
  display:grid;grid-template-columns:96px 1fr;gap:.8rem;align-items:center;
}
.contact-brand img{
  width:96px;height:96px;border-radius:18px;object-fit:cover;border:2px solid #fff;
  box-shadow:0 8px 18px rgba(245,140,166,.16);
}
.contact-brand h2{margin:0}
.contact-brand p{margin:.25rem 0 0}

.kv-list{display:grid;gap:.6rem;margin:1rem 0 0}
.kv{
  display:grid;grid-template-columns:100px 1fr;gap:.7rem;
  padding:.75rem .85rem;
  border:1px solid var(--line);
  border-radius:14px;background:#fff;
}
.kv dt{font-weight:800;color:#6c5760}
.kv dd{margin:0;color:var(--muted)}

.quick-links{
  display:grid;gap:.6rem;margin:1rem 0;
}
.quick-btn{
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;padding:.78rem .9rem;
  border:1px dashed #e8c6d3;
  background:#fff8fb;
  font-weight:800;color:#c75f81;
}
.quick-btn:hover{
  background:#fff1f6;
}

.form-grid{display:grid;gap:.85rem}
.inline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}
.timeslot-grid{display:grid;gap:.5rem;margin-top:.1rem}
.timeslot-row{
  display:grid;
  grid-template-columns:3.5rem 1fr 1fr;
  gap:.5rem;
  align-items:center;
}
.timeslot-label{font-size:.85rem;color:var(--muted);font-weight:700;white-space:nowrap}
.timeslot-date,.timeslot-time{margin:0}
.field{display:grid;gap:.4rem}
.field label{font-weight:800;color:#66535c}
.field input,.field textarea,.field select{
  width:100%;
  border-radius:12px;border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font:inherit;
  padding:.82rem .9rem;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;
  border-color:#f3a5bb;
  box-shadow:0 0 0 4px rgba(245,140,166,.12);
}
.field textarea{min-height:140px;resize:vertical}
.form-hint{font-size:.88rem;color:var(--muted);margin:0}
.form-hint code{
  background:#fff2f7;border:1px solid #ffd8e4;
  padding:.08rem .35rem;border-radius:6px;
}

/* ── Footer ──────────────────────────────── */
.footer-cta{
  margin:0 auto 2rem;
}
.footer-cta .cta-banner{
  margin-top:1.5rem;
}
.footer-cta-actions{
  display:flex;flex-wrap:wrap;gap:.6rem;
}
.footer-card{
  border-radius:26px;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(240,219,228,.9);
  box-shadow:var(--shadow-soft);
  padding:2.5rem;
}
.footer-top{
  padding:0;
  display:grid;
  grid-template-columns:1.2fr .75fr .9fr .65fr;
  gap:2rem;
}
.social-item{
  display:flex;align-items:center;gap:.55rem;
  padding:.35rem .45rem;border-radius:14px;
  border:1px solid transparent;
  transition:.16s ease;
}
.social-item:hover{
  background:#fff;border-color:rgba(240,219,228,.9);
  box-shadow:0 10px 22px rgba(94,66,78,.07);
  transform:translateY(-1px);
}
.social-badge{
  width:34px;height:34px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.78rem;
  color:#d85f84;
  background:#fff1f6;
  border:1px solid rgba(240,219,228,.9);
}

.site-footer{
  margin-top:4rem;
  border-top:1px solid rgba(240,219,228,.75);
  background:#fff6fa;
}
.footer-branding{
  display:grid;grid-template-columns:92px 1fr;gap:.8rem;align-items:start;
}
.footer-logo{
  width:92px;height:92px;object-fit:cover;border-radius:18px;border:2px solid #fff;
  box-shadow:0 10px 20px rgba(245,140,166,.12);
}
.footer-title{
  font-weight:900;color:#5f4852;margin-bottom:.35rem;
}
.footer-links{display:grid;gap:.28rem}
.footer-links a{color:#745f68}
.footer-links a:hover{text-decoration:underline}

.social-links a{
  display:inline-flex;align-items:center;justify-content:flex-start;
  gap:.45rem;
}
.footer-bottom{
  padding:1.25rem 0 1.75rem;
  border-top:1px dashed var(--line);
  color:var(--muted);font-size:.9rem;
  text-align:center;
}
.muted{color:var(--muted)}
.small{font-size:.9rem}

/* ── RWD 980px ───────────────────────────── */
@media (max-width: 980px){
  .header-social{display:none}

  .hero-grid,.feature-grid,.grid-2,.split-showcase,.contact-layout,.footer-top{
    grid-template-columns:1fr;
  }
  .split-showcase.reverse .image-frame,
  .split-showcase.reverse .showcase-copy{order:unset}
  .desktop-cta{display:none}
  .nav-toggle{display:block}
  .site-nav{
    position:absolute;top:86px;left:0;right:0;padding:.6rem 1rem 1rem;
    display:none;
  }
  .site-nav.open{display:block}
  .site-nav ul{
    flex-direction:column;align-items:stretch;
    padding:.45rem;background:rgba(255,255,255,.96);
    border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  }
  .site-nav a{justify-content:flex-start;border-radius:12px;width:100%}
  .hero-shell{padding:2.5rem 0 2rem}
  .hero-copy{padding:1.75rem 1.5rem 1.5rem}
  .hero-visual{padding:.75rem}
  .floating-note{left:.75rem;top:.75rem;max-width:210px}
  .floating-price{right:.75rem;bottom:.75rem;max-width:210px}
  .poster-link img{max-height:none}
  .cta-banner{flex-direction:column;align-items:flex-start;padding:1.5rem 1.75rem}
  .inline{grid-template-columns:1fr}
  main > .section{padding:3.5rem 0}
  .page-hero{padding:2rem 0 1.25rem}
  .page-title-wrap{padding:1.75rem 1.5rem}
  .footer-card{padding:1.75rem}
}

/* ── RWD 560px ───────────────────────────── */
@media (max-width: 560px){
  .brand-logo{width:46px;height:46px;border-radius:14px}
  .brand-text strong{font-size:.95rem}
  .brand-text small{font-size:.7rem}
  .header-inner{min-height:70px}
  .site-nav{top:70px}
  .hero-copy h1{font-size:1.35rem}
  .contact-brand{grid-template-columns:1fr}
  .contact-brand img{width:82px;height:82px}
  .kv{grid-template-columns:88px 1fr}
  .hero-floating{position:static;margin-top:.6rem;max-width:none}
  main > .section{padding:2.5rem 0}
  .card{padding:1.25rem 1.5rem}
  .page-title-wrap{padding:1.5rem 1.25rem}
  .cta-banner{padding:1.25rem 1.5rem}
  .footer-card{padding:1.5rem}
}

/* ── Icons ───────────────────────────────── */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.icon{
  width:18px;height:18px;
  display:block;
}
.icon-btn{
  width:40px;height:40px;
}
.icon-btn svg{width:18px;height:18px}
.social-item svg{width:18px;height:18px}

/* ── Floating LINE CTA ───────────────────── */
.floating-line{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
  display:flex;
  align-items:center;
  gap:.55rem;
  padding:.78rem 1rem;
  border-radius:999px;
  background:var(--pink);
  color:#fff;
  font-weight:900;
  text-decoration:none;
  box-shadow:0 16px 34px rgba(238,117,149,.28);
  border:1px solid rgba(255,255,255,.35);
}
.floating-line:hover{transform:translateY(-1px);background:var(--pink-deep)}
.floating-line .floating-icon{
  width:34px;height:34px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.25);
}
.floating-line .floating-icon svg{width:18px;height:18px}
@media (max-width: 560px){
  .floating-line{
    left:12px;right:12px;
    bottom:12px;
    justify-content:center;
  }
}

/* ── Map ─────────────────────────────────── */
.map-block{
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.map-canvas{display:none;height:320px;width:100%}
.map-embed{width:100%;height:320px;border:0;display:block}
.map-block.is-js .map-canvas{display:block}
.map-block.is-js .map-fallback{display:none}

@media (max-width: 980px){
  .map-canvas,.map-embed{height:280px}
}

/* ── Social wall ─────────────────────────── */
.social-wall{align-items:start}
.wall-head{
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
}
.wall-icons{display:flex;gap:.35rem}
.ig-embed-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.75rem;
  margin-top:.75rem;
}
.ig-embed-grid blockquote{
  margin:0!important;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  min-height:240px;
}
@media (max-width: 980px){
  .ig-embed-grid{grid-template-columns:1fr}
}

/* ── Social embeds (FB) ──────────────────── */
.social-embeds{display:flex;justify-content:center;align-items:start}
.social-embeds > .card{width:100%;max-width:560px}
.embed-shell{position:relative;margin-top:.8rem}
.embed-box{
  display:flex;
  justify-content:center;
  height:620px;
  min-height:560px;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:var(--surface);
  box-shadow:var(--shadow-soft);
}
@media (max-width: 900px){
  .embed-box{height:560px;}
}
@media (max-width: 520px){
  .embed-box{height:520px;}
}
.embed-box iframe{width:100%;max-width:500px;height:100%;border:0;display:block}
.embed-skeleton{
  border:1px dashed rgba(232,200,213,.95);
  border-radius:18px;
  padding:1rem;
  background:rgba(255,255,255,.8);
  box-shadow:var(--shadow-soft);
}
.sk-line{height:12px;border-radius:999px;background:rgba(232,200,213,.55);margin:.55rem 0}
.sk-box{height:420px;border-radius:14px;background:rgba(232,200,213,.45);margin-top:1rem}
.w-40{width:40%}
.w-50{width:50%}
.w-60{width:60%}
.w-70{width:70%}

.embed-fallback{display:none;margin-top:.85rem}
.embed-shell.is-fallback .embed-box{display:none}
.embed-shell.is-fallback .embed-fallback{display:block}
.embed-shell.is-loaded .embed-skeleton{display:none}

@media (max-width: 980px){
  .embed-box{min-height:520px}
  .sk-box{height:360px}
}

/* ── Feed placeholders ───────────────────── */
.feed-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.75rem;
  margin-top:.75rem;
}
.feed-card{
  display:flex;
  align-items:center;
  gap:.65rem;
  padding:.7rem .75rem;
  border-radius:16px;
  border:1px solid var(--line);
  background:#fff;
  text-decoration:none;
  color:inherit;
  box-shadow:var(--shadow-soft);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.feed-card:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(94,66,78,.10);
  border-color:rgba(232,200,213,.9);
}
.feed-thumb{
  width:42px;height:42px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:#fff1f6;
  border:1px solid rgba(240,219,228,.9);
  color:#d85f84;
  flex:0 0 auto;
}
.feed-thumb svg{width:18px;height:18px}
.feed-title{font-weight:900;color:#5f4852;line-height:1.2}
.feed-meta{min-width:0}
@media (max-width: 980px){
  .feed-grid{grid-template-columns:1fr}
}

/* ── Scroll animations ───────────────────── */
.anim{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.anim.visible{opacity:1;transform:translateY(0)}

/* ── Utilities ───────────────────────────── */
.mt-lg{margin-top:1.1rem}
.map-panel{margin-top:1rem}
.map-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}
.map-note{margin:.65rem 0 0}
.nav-tag{
  display:inline-block;
  margin-left:.4em;
  padding:.1em .55em;
  border-radius:100px;
  background:var(--pink);
  color:#fff;
  font-size:.8em;
  font-weight:700;
  vertical-align:middle;
  white-space:nowrap;
  transition:background .18s;
}
.nav-tag:hover{background:var(--pink-deep)}

/* ── Contract page ───────────────────────── */
.contract-doc{
  max-width:860px;
  margin-inline:auto;
}
.contract-title-block{
  text-align:center;
  margin-bottom:2rem;
  padding-bottom:1.5rem;
  border-bottom:2px solid var(--line);
}
.contract-logo-row{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  margin-bottom:1.2rem;
}
.contract-logo{
  width:60px;height:60px;border-radius:16px;object-fit:cover;
  border:2px solid #fff;
  box-shadow:0 8px 20px rgba(245,140,166,.18);
}
.contract-brand-info{text-align:left}
.contract-brand-name{font-weight:900;font-size:1.05rem;color:var(--ink)}
.contract-main-title{
  font-size:clamp(1.4rem,2vw + 1rem,2rem);
  margin:.5rem 0 .35rem;
  letter-spacing:.04em;
}

.contract-review-date{
  margin:.6rem 0 0;
  font-size:.95rem;
  color:var(--muted);
}
.contract-preamble{
  margin:1.2rem 0 1rem;
  padding:1rem 1.2rem;
  background:#fff8fb;
  border:1px solid var(--line);
  border-radius:14px;
}
.contract-preamble p{margin:.25rem 0;color:var(--ink)}

.contract-blank-inline{
  display:inline-block;
  min-width:5em;
  border-bottom:1px solid var(--ink);
  margin:0 .15em;
}
.contract-body{line-height:1.9;font-size:1.08rem}
.contract-body p{
  margin:.6rem 0;
  color:#5c4a54;
  text-indent:0;
}
.contract-blank{
  display:inline;
  color:#5c4a54;
  letter-spacing:.05em;
}
.contract-blank-wide{
  display:inline;
  color:#5c4a54;
  letter-spacing:.05em;
}

.contract-list{
  margin:.3rem 0 .55rem 1.5rem;
  padding:0;
  color:#5c4a54;
}
.contract-list li{margin:.3rem 0}

.contract-payment-block{margin:.55rem 0}
.contract-payment-table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  margin-top:.6rem;
  font-size:.92rem;
  color:#5c4a54;
}
.contract-payment-table td{
  padding:.6rem .85rem;
  border-bottom:1px solid #f4e5ec;
  vertical-align:top;
  width:50%;
}
.contract-payment-table tr:last-child td{border-bottom:none}
.contract-payment-table tr:first-child td{
  background:#fff1f6;
  font-weight:700;
}

/* 立約人簽署區 */
.contract-sign-area{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:2px solid var(--line);
}
.sign-section-title{
  margin:.1rem 0 1rem;
  font-size:1.1rem;
  text-align:center;
  letter-spacing:.08em;
}
.sign-parties-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem 3rem;
  margin-bottom:1rem;
}
.sign-party{display:flex;flex-direction:column;gap:.45rem}
.sign-field-row{
  display:flex;gap:.5rem;align-items:baseline;
  padding-bottom:.35rem;
  border-bottom:1px solid var(--line);
}
.sign-label{
  font-weight:800;color:#66535c;font-size:.88rem;
  white-space:nowrap;flex-shrink:0;
}
.sign-field-row .sign-label::after{content:'：'}
.sign-value{
  flex:1;color:var(--ink);min-width:0;word-break:break-all;font-size:.95rem;
}
.sign-date-line{
  text-align:center;
  font-size:1.05rem;
  font-weight:700;
  margin:1.2rem 0;
  letter-spacing:.06em;
}
.sign-sig-row{
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;
  margin-top:.5rem;
}
.sign-sig-row--single{
  grid-template-columns:1fr;
  max-width:420px;
  margin-inline:auto;
}
.sign-sig-box{display:flex;flex-direction:column;gap:.4rem}
.sign-sig-area{
  min-height:140px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fafafa;
  display:flex;align-items:center;padding:.5rem;
}
.sign-img{max-height:78px;max-width:100%;display:block}

/* fill-field：合約空白欄位 */
.fill-field{
  display:inline;
  font-weight:700;
  color:var(--ink);
}
/* 有值時：text-decoration 由字型 metrics 定位，瀏覽器與 html2canvas/列印完全一致 */
.fill-field.filled{
  text-decoration:underline;
  text-decoration-color:var(--ink);
  text-underline-offset:2px;
}
.fill-blank{
  color:var(--muted);
  font-weight:400;
  letter-spacing:.05em;
}
/* 空白底線：CSS border-bottom，網頁顯示用；PDF 渲染時由 JS 暫時調整位置 */
/* line-height:0 確保空元素高度為 0，border 精準落在文字基線 */
.fill-line{
  display:inline-block;
  vertical-align:baseline;
  border-bottom:1.5px solid var(--muted);
  margin:0 .08em;
  line-height:0;
}

/* 館方預填 card */
.store-fill-card{
  max-width:860px;margin-inline:auto;margin-bottom:1.25rem;
}
.form-section-badge{
  display:inline-flex;align-items:center;
  padding:.28rem .75rem;border-radius:999px;
  font-size:.82rem;font-weight:900;
  margin-bottom:.75rem;
}
.store-badge{
  background:#e8f8f9;border:1px solid var(--mint);color:#2d8b8d;
}
.customer-badge{
  background:#fff4f8;border:1px solid var(--rose);color:#c05878;
}
.store-badge-sm{
  display:inline-flex;align-items:center;
  padding:.2rem .55rem;border-radius:999px;
  font-size:.78rem;font-weight:900;
  background:#e8f8f9;border:1px solid var(--mint);color:#2d8b8d;
  margin-bottom:.6rem;
}

/* 付款兩欄 */
.payment-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
}
.payment-col{
  display:flex;flex-direction:column;gap:.7rem;
  padding:1rem 1.1rem;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fafafa;
}

/* 確認已閱讀 card */
.contract-read-card{
  max-width:860px;
  margin:1.25rem auto 0;
}
.check-label{
  display:flex;align-items:flex-start;gap:.8rem;cursor:pointer;
}
.check-label input[type="checkbox"]{
  position:absolute;opacity:0;width:0;height:0;
}
.check-box{
  flex:0 0 22px;width:22px;height:22px;
  border:2px solid var(--line-strong);
  border-radius:6px;background:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-top:.18rem;
  transition:background .15s,border-color .15s;
}
.check-label input:checked ~ .check-box,
.check-label input:checked + .check-box{
  background:var(--pink);border-color:var(--pink);
}
.check-label input:checked ~ .check-box::after,
.check-label input:checked + .check-box::after{
  content:"";
  width:12px;height:6px;
  border:2.5px solid #fff;
  border-top:none;border-right:none;
  transform:rotate(-45deg) translateY(-1px);
  display:block;
}
.check-text{font-weight:700;line-height:1.65;color:var(--ink)}

/* 簽名區 card */
.sig-section{
  max-width:860px;
  margin:1.25rem auto 0;
  opacity:.45!important;
  pointer-events:none;
  transition:opacity .3s ease;
}
.sig-section.is-enabled{
  opacity:1!important;
  pointer-events:auto;
}
.sig-section h2{margin:.05rem 0 .35rem}

.sig-form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.85rem;
  margin:1rem 0 1.5rem;
}
.required-mark{color:#e06080;font-weight:900}

.form-display{
  border-radius:12px;
  border:1px solid var(--line);
  background:#f9f5f7;
  color:var(--muted);
  padding:.82rem .9rem;
  font-size:inherit;
  line-height:1.5;
  min-height:3rem;
  display:flex;align-items:center;
}

/* 簽名畫布 */
.sig-pad-wrap{margin-top:.25rem}
.sig-pad-label{
  display:flex;align-items:baseline;gap:.6rem;
  font-weight:800;color:#66535c;
  margin-bottom:.5rem;
}
.sig-canvas-shell{
  position:relative;
  border:2px dashed var(--line-strong);
  border-radius:14px;
  background:#fafafa;
  overflow:hidden;
}
.sig-canvas{
  display:block;
  width:100%;
  height:200px;
  touch-action:none;
  cursor:crosshair;
}
.sig-section:not(.is-enabled) .sig-canvas{cursor:not-allowed}
.sig-hint{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:.95rem;
  pointer-events:none;
  transition:opacity .2s;
  user-select:none;
}

.sig-actions{
  display:flex;flex-wrap:wrap;gap:.75rem;
  margin-top:1.25rem;
}
.sig-note{margin-top:.6rem}

/* 送出成功（館方操作區） */
.success-card{
  max-width:860px;
  margin:1.25rem auto 0;
  text-align:center;
  padding:2.5rem 2rem;
}
.success-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:50%;
  background:#f2fcfd;border:2px solid var(--mint);
  color:var(--mint-deep);
  margin-bottom:1rem;
}
.success-title{
  margin:.1rem 0 .5rem;
  font-size:clamp(1.2rem,2vw + .8rem,1.6rem);
}
.success-actions{
  display:flex;flex-wrap:wrap;gap:.75rem;
  justify-content:center;
  margin-top:1.5rem;
}

/* 欄位提示文字 */
.field-hint{margin:.35rem 0 0;font-size:.82rem;line-height:1.4;color:var(--muted)}
.error-hint{color:#d9534f;font-weight:600}

/* 合約頁面：標題卡與內容卡統一寬度 860px */
[data-page="sign"] .page-title-wrap{max-width:860px;margin-inline:auto}

/* 合約 doc 卡片不做 hover 上浮 */
.contract-doc:hover{transform:none}

/* 飼主資料卡 */
.customer-info-card{max-width:860px;margin:1.25rem auto 0}

/* 確認送出卡 */
.read-submit-card{max-width:860px;margin:1.25rem auto 0}

/* 可點擊簽名區（min-height 由 .sign-sig-area 的 140px 決定） */
.sig-clickable{
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  border:2px dashed var(--line-strong);
  border-radius:10px;
  background:#fafafa;
  transition:border-color .2s,background .2s;
  position:relative;
  overflow:hidden;
}
.sig-clickable:hover{border-color:var(--pink);background:#fff8fa}
.sig-clickable:focus-visible{
  outline:2px solid var(--pink);
  outline-offset:2px;
}
.sig-clickable.signed{
  border-color:var(--mint);
  border-style:solid;
  background:#f6fcfa;
}
.sig-clickable .sign-img{
  max-width:100%;
  max-height:120px;
  object-fit:contain;
  display:block;
}

/* 點擊提示（icon + 文字）*/
.sig-tap-hint{
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
  color:var(--muted);font-size:.9rem;pointer-events:none;
  user-select:none;padding:.75rem;
}
.sig-tap-hint svg{opacity:.55}

/* ── 簽名 Modal ──────────────────────────── */
.sig-modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:200;
  display:none;
  align-items:center;justify-content:center;
  padding:1rem;
}
.sig-modal-overlay.is-open{display:flex}

.sig-modal{
  background:#fff;
  border-radius:20px;
  box-shadow:0 8px 40px rgba(60,20,40,.18);
  width:100%;
  max-width:560px;
  padding:1.5rem 1.75rem 1.75rem;
  position:relative;
}

.sig-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.1rem;
}
.sig-modal-header h3{margin:0;font-size:1.15rem}

.modal-close-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  border-radius:50%;
  border:none;background:transparent;
  color:var(--muted);cursor:pointer;
  transition:background .15s,color .15s;
  flex-shrink:0;
}
.modal-close-btn:hover{background:#f4e8ed;color:var(--pink-deep)}

.sig-modal .sig-canvas-shell{margin-top:.25rem}
.sig-modal .sig-canvas{height:200px}

.sig-modal-actions{
  display:flex;flex-wrap:wrap;gap:.75rem;
  margin-top:1.1rem;
  justify-content:flex-end;
}

/* RWD */
@media (max-width:560px){
  .sig-form-grid{grid-template-columns:1fr}
  .sign-parties-grid{grid-template-columns:1fr}
  .sign-sig-row{grid-template-columns:1fr}
  .contract-logo-row{flex-direction:column;text-align:center}
  .contract-brand-info{text-align:center}
  .sig-canvas{height:160px}
  .contract-payment-table td{display:block;width:100%;border-bottom:1px solid #f4e5ec}
  .contract-payment-table tr:last-child td:last-child{border-bottom:none}
  .payment-grid{grid-template-columns:1fr}
  .sig-modal{padding:1.25rem 1.25rem 1.5rem}
  .sig-modal .sig-canvas{height:160px}
}

/* ── 身分證上傳 ──────────────────────────── */
.id-card-section{
  margin-top:1.5rem;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
}
.id-card-header{
  display:flex;align-items:center;gap:.6rem;
  margin-bottom:.1rem;
}
.id-optional-badge{
  display:inline-block;
  padding:.15rem .55rem;
  border-radius:100px;
  background:var(--line);
  color:var(--muted);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.03em;
}
.id-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem;
  margin-top:.8rem;
}
.id-card-col{display:flex;flex-direction:column;gap:.45rem}

.id-upload-zone{
  display:flex;align-items:center;justify-content:center;
  min-height:130px;
  border:2px dashed var(--line-strong);
  border-radius:12px;
  background:#fafafa;
  cursor:pointer;
  transition:border-color .2s,background .2s;
  position:relative;
}
.id-upload-zone:hover{border-color:var(--pink);background:#fff8fa}
.id-upload-zone input[type="file"]{
  position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none;
}
.id-upload-hint{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:var(--muted);font-size:.88rem;pointer-events:none;user-select:none;
}

.id-preview-wrap{display:none;flex-direction:column;gap:.4rem}
.id-preview-img{width:100%;border-radius:10px;border:1px solid var(--line);display:block}
.id-reupload{
  display:inline-block;font-size:.82rem;color:var(--muted);
  cursor:pointer;text-align:center;padding:.25rem 0;
}
.id-reupload:hover{color:var(--pink)}

/* 有圖時：隱藏上傳區，顯示預覽 */
.id-card-col.has-img .id-upload-zone{display:none}
.id-card-col.has-img .id-preview-wrap{display:flex}

/* ── Print ───────────────────────────────── */
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}

  /* 隱藏非合約元素 */
  .no-print,
  .site-header,.site-footer,.floating-line,
  .page-hero,.skip-link{display:none!important}

  /* 重設頁面背景與間距 */
  body{background:#fff;margin:0}
  main>.section{padding:0}
  .container{width:100%;max-width:none;padding:0 1.5rem}

  /* 合約卡片移除陰影 */
  .card,.contract-doc{
    box-shadow:none!important;
    border:none!important;
    border-radius:0!important;
    transform:none!important;
    padding:1.5rem!important;
  }

  /* 合約標題線保留 */
  .contract-title-block{
    border-bottom:1.5px solid #ccc!important;
  }

  /* 簽署欄位線條保留 */
  .contract-sign-area{
    border-top:1.5px solid #ccc!important;
  }
  .sign-meta-item{border-bottom:1px solid #ddd!important}
  .sign-sig-area{
    border:1px solid #ccc!important;
    background:#fff!important;
    min-height:130px!important;
  }

  /* 分頁控制：防止重要區塊被切斷 */
  .contract-payment-block,
  .contract-payment-table,
  .sign-parties-grid,
  .sign-sig-row,
  .contract-sign-area,
  .contract-preamble,
  .contract-title-block{
    break-inside:avoid;
    page-break-inside:avoid;
  }
  /* 條文段落防止中途斷頁 */
  .contract-body>p,
  .contract-list,
  .contract-list li{
    break-inside:avoid;
    page-break-inside:avoid;
  }
  /* 確保簽名區不跨頁 */
  .contract-sign-area{
    break-before:auto;
    page-break-before:auto;
  }
}
