
/* ============ FCLV design DNA: Canela-style serif / Work Sans / #9a6b58 rosewood / #222 charcoal / flat squares ============ */
:root{
  --accent:#9a6b58; --accent-d:#7d5547; --dark:#222; --gray:#f1f2f2;
  --taupe:#eae3dc; --blush:#f6efe9; --text:#222; --muted:#6f6a66; --line:#e3ddd6;
  --serif:"Cormorant Garamond","Noto Serif TC",serif;
  --sans:"Work Sans","Noto Sans TC",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--sans);color:var(--text);background:#fff;line-height:1.85;font-size:15.5px;font-weight:400}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
h1,h2,h3,h4,.serif{font-family:var(--serif);font-weight:500}
img{max-width:100%}

/* kicker — FCLV's small uppercase eyebrow */
.kicker{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:14px}

/* placeholder block — soft taupe, museum-label style */
.ph{background:var(--taupe);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);margin:0}
.ph span{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase}
.ph em{font-style:normal;font-family:var(--serif);font-size:17px;color:var(--accent-d)}

/* topbar + header — FCLV: light gray utility bar, white slim header */
.topbar{background:var(--gray);color:var(--dark);font-size:12.5px;letter-spacing:.04em}
.topbar a{color:var(--dark);font-weight:500}
.topbar-in{display:flex;justify-content:space-between;padding-top:8px;padding-bottom:8px;flex-wrap:wrap;gap:4px}
.topbar .sep{margin:0 12px;opacity:.35}
.hd{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.hd-in{display:flex;align-items:center;gap:30px;padding-top:18px;padding-bottom:18px}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{width:52px;height:52px;object-fit:contain;flex:none;display:block}
.f-mark{width:64px;height:64px;object-fit:contain;display:block;margin-bottom:16px}
.brand-txt strong{display:block;font-family:var(--serif);font-size:21px;color:var(--dark);letter-spacing:.14em;font-weight:500}
.brand-txt small{color:var(--muted);font-size:10px;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap}
.nav{margin-left:auto}
.nav>ul{display:flex;list-style:none;gap:2px}
.nav>ul>li{position:relative}
.nav>ul>li>a{display:block;padding:10px 11px;color:var(--dark);font-weight:500;font-size:13.5px;letter-spacing:.06em;white-space:nowrap}
.nav>ul>li>a b{font-size:9px;color:var(--muted);font-weight:400}
.nav>ul>li>a:hover{color:var(--accent)}
.sub{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);list-style:none;min-width:240px;padding:10px 0;
  box-shadow:0 14px 34px rgba(34,34,34,.1);opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s}
.has-sub:hover .sub{opacity:1;visibility:visible;transform:translateY(0)}
.sub a{display:block;padding:9px 20px;color:var(--dark);font-size:13.5px;letter-spacing:.04em}
.sub a:hover{color:var(--accent);background:var(--blush)}

/* buttons — FCLV: flat, square, uppercase tracking */
.cta{background:var(--dark);color:#fff !important;padding:14px 30px;font-weight:500;font-size:12.5px;
  letter-spacing:.28em;text-transform:uppercase;display:inline-block;border:1px solid var(--dark);transition:.18s;white-space:nowrap}
.cta:hover{background:var(--accent);border-color:var(--accent)}
.cta-lg{padding:17px 40px}
.ghost{border:1px solid var(--dark);color:var(--dark);padding:13px 30px;font-size:12.5px;letter-spacing:.28em;
  text-transform:uppercase;font-weight:500;display:inline-block;transition:.18s}
.ghost:hover{border-color:var(--accent);color:var(--accent)}

/* home hero — full-bleed media block with serif overlay, FCLV "When it's a family you want..." */
.hero{position:relative}
.hero .hero-media{min-height:74vh}
.hero-overlay{position:absolute;inset:0;display:flex;align-items:center}
.hero-overlay .wrap{width:100%}
.hero-card{max-width:560px}
.hero h1{font-size:clamp(40px,5.4vw,72px);line-height:1.18;letter-spacing:.04em;color:var(--dark);font-weight:400}
.hero h1 em{font-style:italic;color:var(--accent);font-family:"Cormorant Garamond",serif}
.hero .lead{margin:22px 0 30px;color:#4a443f;font-size:16.5px;max-width:460px}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}

/* stats — quiet blush strip, serif numerals */
.stats{background:var(--blush);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;padding:44px 28px;gap:18px}
.stats b{display:block;font-family:var(--serif);font-size:44px;color:var(--accent);font-weight:400;line-height:1.1}
.stats span{font-size:11px;color:var(--muted);letter-spacing:.26em;text-transform:uppercase}

/* sections */
.section{padding:96px 0}
.section.alt{background:var(--blush)}
.section.dark{background:var(--dark);color:#fff;padding:110px 0;text-align:center}
.section.dark h2{font-size:clamp(30px,3.6vw,48px);font-weight:400;letter-spacing:.18em;color:#fff}
.section.dark p{color:#b9b0a9;margin-top:16px;letter-spacing:.1em}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-head h2{font-size:clamp(28px,3vw,40px);letter-spacing:.06em;font-weight:400}
.sec-head p{color:var(--muted);margin-top:14px}

/* cards — flat, square, image-top, hairline border */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:#fff;border:1px solid var(--line);display:block;color:var(--text);transition:border-color .18s}
.card:hover{border-color:var(--accent)}
.card .card-body{padding:26px 26px 30px}
.card .ph{min-height:200px}
.card h3{font-size:21px;margin-bottom:10px;color:var(--dark);letter-spacing:.04em}
.card p{font-size:14px;color:var(--muted)}
.card .more{display:inline-block;margin-top:16px;font-weight:500;font-size:11px;color:var(--accent);letter-spacing:.26em;text-transform:uppercase}

/* editorial split — alternating image/text, FCLV rhythm */
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.split.rev{direction:rtl}
.split.rev>*{direction:ltr}
.split h2{font-size:clamp(26px,2.8vw,38px);margin-bottom:18px;font-weight:400;letter-spacing:.05em;line-height:1.35}
.split p{color:#4a443f;margin-bottom:14px}
.split .ph{min-height:440px}
.split blockquote{border-left:2px solid var(--accent);padding:4px 0 4px 22px;color:var(--muted);font-family:var(--serif);font-size:18px;font-style:italic;margin:22px 0}

/* inner page hero — blush band, serif title */
.page-hero{background:var(--blush);border-bottom:1px solid var(--line);padding:64px 0}
.crumb{font-size:11px;color:var(--muted);letter-spacing:.28em;text-transform:uppercase;margin-bottom:14px}
.crumb a{color:var(--muted)}
.page-hero h1{font-size:clamp(30px,3.6vw,48px);font-weight:400;letter-spacing:.05em}
.page-hero .lead{color:#4a443f;margin-top:14px;max-width:740px}

/* article + sidebar */
.layout{display:grid;grid-template-columns:1fr 330px;gap:60px;padding-top:64px;padding-bottom:96px}
.art h2{font-size:27px;margin:42px 0 14px;color:var(--dark);font-weight:500;letter-spacing:.04em}
.art h2:first-child,.art .ph:first-child+h2{margin-top:0}
.art>.ph{min-height:320px;margin-bottom:32px}
.art p{margin-bottom:15px}
.art ul{margin:0 0 20px 22px}
.art li{margin-bottom:9px}
.art b{color:var(--accent-d)}
.side{position:sticky;top:104px;align-self:start;display:flex;flex-direction:column;gap:24px}
.side-card{background:var(--blush);border:1px solid var(--line);padding:28px}
.side-card h3{margin-bottom:10px;font-size:20px;font-weight:500;letter-spacing:.04em}
.side-card p{font-size:13.5px;color:var(--muted);margin-bottom:18px}
.side-tel{display:block;margin-top:16px;font-weight:600;font-size:17px;letter-spacing:.06em}
.side-links{list-style:none}
.side-links li{border-bottom:1px solid var(--line)}
.side-links li:last-child{border-bottom:0}
.side-links a{display:block;padding:10px 2px;font-size:13.5px;color:var(--dark);letter-spacing:.05em}
.side-links a:hover{color:var(--accent)}

/* faq */
.faq-item{border:1px solid var(--line);margin-bottom:16px;overflow:hidden;background:#fff}
.faq-item summary{padding:20px 24px;font-family:var(--serif);font-size:18px;font-weight:500;cursor:pointer;list-style:none;display:flex;justify-content:space-between;letter-spacing:.04em}
.faq-item summary::after{content:"+";color:var(--accent);font-weight:400;font-size:22px;line-height:1}
.faq-item[open] summary::after{content:"−"}
.faq-item div{padding:0 24px 20px;color:var(--muted)}

/* blog */
.post-meta{font-size:10.5px;color:var(--muted);letter-spacing:.26em;text-transform:uppercase;margin-bottom:10px}

/* CTA band + footer — FCLV: charcoal */
.band{background:var(--dark);color:#fff}
.band-in{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:64px 28px;flex-wrap:wrap}
.band h2{font-size:clamp(24px,2.6vw,34px);margin-bottom:8px;font-weight:400;letter-spacing:.06em}
.band p{color:#b9b0a9;font-size:14.5px}
.band .cta{background:transparent;border:1px solid #fff}
.band .cta:hover{background:#fff;color:var(--dark) !important}
.ft{background:var(--dark);color:#a99f97;font-size:13.5px;border-top:1px solid #3a3531}
.ft a{color:#d9d0c8}
.ft a:hover{color:#fff}
.ft-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:34px;padding:70px 28px 44px}
.f-brand .f-logo{font-family:var(--serif);font-size:22px;font-weight:500;color:#fff;margin-bottom:14px;letter-spacing:.14em}
.f-brand p{margin-bottom:9px;font-size:13px}
.f-col h4{color:#fff;font-size:12px;margin-bottom:14px;letter-spacing:.24em;text-transform:uppercase;font-family:var(--sans);font-weight:600}
.f-col h4 a{color:#fff}
.f-col ul{list-style:none}
.f-col li{margin-bottom:9px;font-size:13px}
.ft-legal{border-top:1px solid #3a3531;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;padding-top:20px;padding-bottom:28px;font-size:11.5px;color:#7d756e;letter-spacing:.05em}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:64px;padding-bottom:96px}
.contact-grid h2{font-weight:500;letter-spacing:.05em}
.form label{display:block;font-weight:500;margin:18px 0 7px;font-size:13px;letter-spacing:.12em}
.form input,.form select,.form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);font:inherit;background:#fff}
.form input:focus,.form select:focus,.form textarea:focus{outline:1px solid var(--accent);border-color:var(--accent)}
.form button{margin-top:26px;border:0;cursor:pointer;font:inherit}
.info-rows p{padding:14px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.info-rows b{color:var(--accent-d);margin-right:12px;letter-spacing:.1em}
.contact-grid .ph{min-height:260px;margin-top:24px}

@media(max-width:980px){
  .hero h1{font-size:38px}
  .hero .hero-media{min-height:60vh}
  .hero-in,.split,.layout,.contact-grid{grid-template-columns:1fr}
  .split.rev{direction:ltr}
  .grid3{grid-template-columns:1fr}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .side{position:static}
}
