:root{
  --bg:#f6f2e9;
  --bg-soft:#fbf9f4;
  --panel:#fffdfa;
  --panel-soft:#f3ecdf;
  --line:#ddcfb4;
  --ink:#183b6b;
  --ink-soft:#4f5f76;
  --gold:#bb9340;
  --gold-deep:#a97f28;
  --shadow:0 18px 42px rgba(24,59,107,.08);
  --radius:28px;
  --container:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:linear-gradient(180deg,#fbf8f2 0%, #f5f0e6 48%, #f7f3eb 100%);
  font-family:"Noto Serif TC","Songti TC","PMingLiU","MingLiU",serif;
  line-height:1.8;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
input,select,textarea{width:100%;padding:14px 16px;border-radius:16px;border:1px solid rgba(24,59,107,.14);background:#fff;outline:none}
textarea{min-height:120px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 4px rgba(187,147,64,.12)}
.container{width:min(calc(100% - 40px),var(--container));margin:0 auto}
main{min-height:56vh}
.section{padding:36px 0}
.section.tight{padding-top:18px}
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card,.service-card,.article-card,.form-card,.metric,.notice-item,.side-nav,.dashboard-card,.flash,.table-wrap,.hero-card,.split-feature,.faq-main-card,.faq-side-intro,.qr-card{
  background:rgba(255,253,248,.95);
  border:1px solid rgba(187,147,64,.18);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card,.service-card,.article-card,.form-card,.notice-item,.dashboard-card,.faq-side-intro{padding:28px}
.table-wrap{padding:0;overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:16px 18px;border-bottom:1px solid rgba(24,59,107,.08);text-align:left}
th{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);background:#faf6ee}
.eyebrow{display:inline-block;margin-bottom:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:800}
.editorial-title,
.hero-copy h1,
.brand-title,
.card h3,
.service-card h3,
.article-card h3,
.dashboard-card h3,
.form-card h3,
.qr-copy h3,
.faq-side-intro h1{
  font-family:"Noto Serif TC","Songti TC","PMingLiU","MingLiU",serif;
}
.editorial-title{font-size:clamp(34px,4vw,56px);line-height:1.22;margin:0;color:var(--ink)}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px}.section-head h1,.section-head h2{margin:0}
.section-head.short{margin-bottom:14px}
.muted{color:var(--ink-soft)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;font-weight:700;transition:.2s ease;line-height:1;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--gold) 0%, var(--gold-deep) 100%);color:#fff;box-shadow:0 12px 22px rgba(169,127,40,.16)}
.btn-outline{background:#fff;color:var(--ink);border-color:rgba(24,59,107,.18)}
.btn-light{background:#fff;color:var(--ink)}
.btn.sm{padding:9px 18px;font-size:14px}
.tag,.icon-chip,.member-badge,.pill{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:rgba(187,147,64,.12);color:var(--gold-deep);border:1px solid rgba(187,147,64,.18)}
.flash{padding:14px 18px}.flash.success{background:#effaf4;color:#245f46;border-color:rgba(64,148,107,.18)}.flash.error{background:#fff6f5;color:#9b4a4a;border-color:rgba(184,94,94,.18)}

.site-header{position:sticky;top:0;z-index:20;padding:16px 0 14px;background:rgba(251,248,242,.96);backdrop-filter:blur(10px);border-bottom:1px solid rgba(187,147,64,.14)}
.header-frame{display:flex;flex-direction:column;gap:12px}
.header-row{display:grid;grid-template-columns:320px 1fr auto;align-items:center;gap:24px}
.brand-stack{display:flex;align-items:center;gap:14px;min-width:0}
.brand-stack img{width:146px;height:auto;object-fit:contain;flex-shrink:0}
.brand-text{display:flex;flex-direction:column;gap:4px;min-width:0}
.brand-title{font-size:24px;font-weight:900;letter-spacing:.06em;line-height:1.12;word-break:break-word}
.brand-caption{font-size:12px;letter-spacing:.18em;color:var(--gold);font-weight:700;text-transform:uppercase}
.main-nav{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.main-nav a{padding:11px 16px;border-radius:999px;color:var(--ink);font-weight:700}
.main-nav a.active,.main-nav a:hover{background:rgba(187,147,64,.12);color:var(--ink)}
.header-actions-wrap{display:flex;align-items:center;justify-content:flex-end;gap:12px}
.auth-links-compact{display:flex;align-items:center;gap:10px}
.mobile-trigger{display:none;background:none;border:none;color:var(--ink);font-size:28px}
.mobile-menu{display:none}

.hero-card{position:relative;overflow:hidden;padding:48px 54px;background:linear-gradient(135deg,#fffdf7 0%, #f3ecdf 100%);min-height:500px;display:grid;grid-template-columns:minmax(0,1fr) 310px;align-items:center;gap:36px}
.hero-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 38%,rgba(187,147,64,.18),transparent 34%),radial-gradient(circle at 18% 18%,rgba(24,59,107,.05),transparent 26%)}
.hero-card-clean .hero-copy{max-width:680px;position:relative;z-index:2}
.hero-brand-banner{border-color:rgba(187,147,64,.24)}
.hero-kicker{display:inline-block;margin-bottom:12px;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:800}
.hero-copy h1{font-size:clamp(42px,5.4vw,72px);line-height:1.12;margin:0 0 16px;color:var(--ink)}
.hero-copy p{margin:0 0 22px;color:var(--ink-soft);font-size:18px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-banner-image{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;min-height:360px;padding:14px}
.hero-banner-image img{width:min(100%,260px);height:auto;object-fit:contain;filter:drop-shadow(0 24px 34px rgba(24,59,107,.10))}

.compact-card h3{margin:4px 0 10px;font-size:24px}.compact-card p{margin:0;color:var(--ink-soft)}
.clean-process-card{display:grid;grid-template-columns:1.05fr .95fr;gap:0;overflow:hidden}
.clean-process-card .content{padding:36px}.clean-process-card .visual{padding:0;background:linear-gradient(180deg,#fbf7ef,#f3ecdf)}.visual-simple{display:grid;place-items:center;overflow:hidden}.visual-simple img{width:100%;height:100%;min-height:430px;object-fit:cover;opacity:.96}.visual-emblem img{filter:saturate(.96) contrast(1.02)}
.process-list{display:grid;gap:14px}.process-item{display:grid;grid-template-columns:36px 1fr;gap:14px;align-items:start}.process-item .num{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;font-weight:800}
.service-card h3,.article-card h3,.card h3{margin:10px 0 8px;font-size:24px}.service-card p,.article-card p,.card p{margin:0;color:var(--ink-soft)}.service-card ul{margin:14px 0 0;padding-left:20px;color:var(--ink-soft)}
.article-card img{height:230px;object-fit:cover;border-radius:20px;border:1px solid rgba(187,147,64,.16);background:#fbf6ec}
.hover-lift{transition:.22s ease}.hover-lift:hover{transform:translateY(-4px)}

.qr-card{display:grid;grid-template-columns:1fr 220px;gap:24px;align-items:center;padding:28px;background:linear-gradient(135deg,#fffdf8,#f3ecdf)}
.qr-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}.qr-brand img{width:112px;height:auto}.qr-copy h3{margin:0 0 6px;font-size:28px}.qr-copy p{margin:0;color:var(--ink-soft)}.qr-image{width:100%;max-width:220px;background:#fff;border-radius:18px;border:1px solid rgba(187,147,64,.22);padding:10px}

.faq-page{padding-top:28px}.faq-shell{display:grid;grid-template-columns:320px 1fr;gap:24px;align-items:start}.faq-side-intro{position:sticky;top:120px;background:linear-gradient(180deg,#fffdf8,#f6efe1)}.faq-side-intro p{margin:0 0 18px;color:var(--ink-soft)}.faq-main-card{padding:18px 22px;display:grid;gap:14px;min-height:420px}
.faq-item{padding:0;border:1px solid rgba(24,59,107,.1);background:#fff;border-radius:22px;box-shadow:none;overflow:hidden}.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 24px;font-size:22px;font-weight:700;color:var(--ink)}.faq-item summary::-webkit-details-marker{display:none}.faq-toggle{color:var(--gold);font-size:28px;line-height:1;min-width:24px;text-align:center}.faq-item[open] .faq-toggle{transform:rotate(45deg)}.faq-content{padding:0 24px 22px;color:var(--ink-soft);font-size:18px;line-height:1.9}.faq-item-wide{border-radius:24px}

.footer{padding:28px 0 40px}.footer-frame{padding:28px;border:1px solid rgba(187,147,64,.16);border-radius:32px;background:rgba(255,253,248,.92);box-shadow:var(--shadow)}.footer-grid{display:grid;grid-template-columns:1.2fr .7fr .8fr;gap:22px;align-items:start}.footer-brand-line{display:flex;align-items:center;gap:14px;margin-bottom:12px}.footer-brand img{width:140px;height:auto}.footer-brand p{margin:0;color:var(--ink-soft)}.footer-links-group h4{margin:0 0 10px;color:var(--ink);font-size:18px}.footer-links-group a{display:block;padding:6px 0;color:var(--ink-soft)}.footer-bottom{padding-top:16px;margin-top:18px;border-top:1px solid rgba(187,147,64,.14);color:var(--ink-soft);font-size:13px}

.member-shell{display:grid;grid-template-columns:260px 1fr;gap:22px}.side-nav{padding:18px;position:sticky;top:110px;height:max-content}.side-nav h3{margin:0 0 12px;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}.side-nav a{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:16px;color:var(--ink);font-weight:700;margin-bottom:6px}.side-nav a.active,.side-nav a:hover{background:#fff;color:var(--gold-deep)}.member-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}.dashboard-shell{display:grid;gap:20px}.dashboard-top{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.dashboard-card h3{margin:0 0 6px;font-size:18px}.dashboard-value{font-size:34px;font-weight:900;color:var(--ink);line-height:1}.dashboard-sub{color:var(--ink-soft);font-size:14px}.dashboard-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:18px}.dashboard-card .table-wrap{margin-top:12px;border:none;box-shadow:none;background:transparent}.notice-item{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.notice-item.unread{border-left:4px solid var(--gold)}.notice-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:8px}.notice-dot{width:10px;height:10px;border-radius:50%;background:#d95f5f}.notice-detail{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(24,59,107,.15);color:var(--ink-soft)}.notice-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:0 0 16px}.notice-filters{display:flex;gap:8px;flex-wrap:wrap}.notice-filters button,.tab-btn{border:none;border-radius:999px;padding:10px 14px;background:#f4ede0;color:var(--ink);cursor:pointer;font-weight:700}.notice-filters button.active,.tab-btn.active{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff}.form-grid{display:grid;gap:16px}.form-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.form-actions{display:flex;gap:12px;justify-content:flex-start}.compact-summary{display:grid;align-content:start}.flash-stack{display:grid;gap:12px}.page-wrap{padding-bottom:30px}

@media (max-width:1100px){
  .header-row{grid-template-columns:1fr auto;grid-template-areas:"brand actions" "nav nav"}
  .brand-stack{grid-area:brand}
  .header-actions-wrap{grid-area:actions}
  .main-nav{grid-area:nav;justify-content:flex-start;overflow:auto;padding-bottom:6px}
  .mobile-trigger{display:inline-flex}
  .mobile-menu{display:none;flex-direction:column;gap:8px;padding-top:10px}
  .mobile-menu.open{display:flex}
  .auth-links-compact{display:none}
  .hero-card{grid-template-columns:1fr 240px}
  .clean-process-card,.qr-card,.footer-grid,.faq-shell,.dashboard-grid{grid-template-columns:1fr}
  .dashboard-top,.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .faq-side-intro{position:static}
}
@media (max-width:760px){
  .container{width:min(calc(100% - 20px),var(--container))}
  .header-row{grid-template-columns:1fr auto;gap:14px}
  .main-nav{display:none}
  .mobile-menu a{padding:12px 14px;border-radius:14px;background:#fff}
  .brand-stack img{width:112px}
  .brand-title{font-size:20px}
  .editorial-title{font-size:34px}
  .hero-card{padding:26px;min-height:auto}
  .hero-card{grid-template-columns:1fr;padding:28px;min-height:auto}.hero-banner-image{min-height:auto;padding:12px 0 0}.hero-banner-image img{width:180px}
  .hero-copy p,.faq-content{font-size:16px}
  .cols-2,.cols-3,.cols-4,.form-grid.cols-2,.member-shell,.dashboard-top{grid-template-columns:1fr}
  .footer-frame{padding:20px}
  .member-head{flex-direction:column;align-items:flex-start}
  .faq-item summary{font-size:18px;padding:18px 18px}
}

/* =========================================================
   Front logo update: use compact shield logo across frontend
   ========================================================= */
.site-header{
  padding:14px 0 12px;
}
.header-row{
  grid-template-columns:minmax(300px, 380px) 1fr auto;
  gap:28px;
}
.brand-stack{
  gap:12px;
  align-items:center;
}
.brand-stack img,
.site-header .brand-stack img{
  width:68px !important;
  max-width:68px !important;
  height:76px !important;
  max-height:76px !important;
  object-fit:contain !important;
  flex:0 0 68px;
  filter:drop-shadow(0 8px 14px rgba(24,59,107,.08));
}
.brand-text{
  gap:2px;
  justify-content:center;
}
.brand-title{
  font-size:26px;
  line-height:1.05;
  letter-spacing:.08em;
  color:var(--ink);
}
.brand-caption{
  font-size:12px;
  line-height:1.2;
  letter-spacing:.2em;
  color:var(--gold);
}
.header-actions-wrap .btn.sm{
  padding:8px 16px;
  min-height:38px;
  font-size:14px;
}

.footer-brand-line img,
.footer-brand img,
.qr-brand img{
  width:66px !important;
  max-width:66px !important;
  height:76px !important;
  max-height:76px !important;
  object-fit:contain !important;
  flex:0 0 66px;
  filter:drop-shadow(0 8px 14px rgba(24,59,107,.06));
}
.footer-brand-line{
  align-items:center;
  gap:14px;
}
.footer-brand .brand-title,
.footer-brand-line .brand-title{
  font-size:24px;
  line-height:1.08;
}
.qr-brand{
  align-items:center;
  gap:14px;
}

/* In case other frontend blocks use the shared logo directly */
img[src$="/legalfront/images/logo.png"],
img[src$="legalfront/images/logo.png"]{
  object-fit:contain;
}

@media (max-width:1100px){
  .header-row{
    grid-template-columns:1fr auto;
    gap:18px;
  }
  .brand-stack img,
  .site-header .brand-stack img{
    width:60px !important;
    max-width:60px !important;
    height:68px !important;
    max-height:68px !important;
    flex-basis:60px;
  }
  .brand-title{font-size:23px;}
}
@media (max-width:760px){
  .site-header{padding:10px 0;}
  .brand-stack{gap:10px;}
  .brand-stack img,
  .site-header .brand-stack img{
    width:50px !important;
    max-width:50px !important;
    height:58px !important;
    max-height:58px !important;
    flex-basis:50px;
  }
  .brand-title{font-size:20px;letter-spacing:.04em;}
  .brand-caption{font-size:10px;letter-spacing:.16em;}
  .footer-brand-line img,
  .footer-brand img,
  .qr-brand img{
    width:54px !important;
    max-width:54px !important;
    height:62px !important;
    max-height:62px !important;
    flex-basis:54px;
  }
}

/* =========================================================
   2026-05 Final homepage restoration
   Based on current style.css, only fixes:
   1. Header/logo proportion
   2. Header-to-banner spacing
   3. Homepage hero right-side image size
   4. Homepage process-section right image layout
   Does not change member mobile menu behavior
   ========================================================= */

/* header 與首頁第一區塊保留呼吸感 */
.hero{
  padding-top: 28px !important;
}
@media (max-width: 760px){
  .hero{
    padding-top: 16px !important;
  }
}

/* Header logo 比例修正，避免擠壓標題與導覽 */
.site-header{
  padding: 12px 0 !important;
}
.header-row{
  grid-template-columns: minmax(260px, 340px) minmax(420px, 1fr) auto !important;
  gap: 22px !important;
  align-items: center !important;
}
.brand-stack{
  align-items: center !important;
  gap: 12px !important;
  max-width: 340px !important;
}
.brand-stack img,
.site-header .brand-stack img{
  width: 64px !important;
  max-width: 64px !important;
  height: 64px !important;
  max-height: 64px !important;
  flex: 0 0 64px !important;
  object-fit: contain !important;
}
.brand-text{
  gap: 2px !important;
}
.brand-title{
  font-size: 22px !important;
  line-height: 1.08 !important;
  letter-spacing: .04em !important;
}
.brand-caption{
  font-size: 10px !important;
  line-height: 1.2 !important;
  letter-spacing: .16em !important;
}
.header-actions-wrap .btn.sm{
  min-height: 36px !important;
  padding: 8px 16px !important;
  font-size: 14px !important;
}

/* footer / qr 共用 logo 也回到穩定比例 */
.footer-brand-line img,
.footer-brand img,
.qr-brand img{
  width: 62px !important;
  max-width: 62px !important;
  height: 62px !important;
  max-height: 62px !important;
  flex: 0 0 62px !important;
  object-fit: contain !important;
}

/* 首頁 hero 區塊恢復雙欄比例 */
.hero-card.hero-brand-banner{
  grid-template-columns: minmax(0, 1.06fr) minmax(280px, 360px) !important;
  gap: 34px !important;
  align-items: center !important;
  min-height: 460px !important;
  padding: 46px 54px !important;
}
.hero-card.hero-brand-banner .hero-copy{
  max-width: 680px !important;
}
.hero-card.hero-brand-banner .hero-copy h1{
  max-width: 640px !important;
}
.hero-banner-image{
  min-height: 320px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
}
.hero-banner-image img{
  width: min(100%, 300px) !important;
  max-height: 300px !important;
  height: auto !important;
  object-fit: contain !important;
  margin: 0 auto !important;
  filter: drop-shadow(0 16px 28px rgba(24,59,107,.10)) !important;
}

/* 簡化流程右側圖片恢復完整鋪滿視覺，不留大空框 */
.clean-process-card{
  grid-template-columns: 1.02fr .98fr !important;
  min-height: 420px !important;
}
.clean-process-card .content{
  padding: 36px !important;
}
.clean-process-card .visual{
  min-height: 420px !important;
  padding: 0 !important;
  background: linear-gradient(180deg,#fbf7ef,#f3ecdf) !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  overflow: hidden !important;
}
.visual-simple img,
.visual-emblem img,
.clean-process-card .visual img{
  width: 100% !important;
  height: 100% !important;
  min-height: 420px !important;
  object-fit: cover !important;
  object-position: center center !important;
  margin: 0 !important;
  opacity: 1 !important;
  filter: saturate(.98) contrast(1.02) !important;
}

/* 響應式保持穩定 */
@media (max-width: 1100px){
  .header-row{
    grid-template-columns: 1fr auto !important;
    grid-template-areas: "brand actions" "nav nav" !important;
    gap: 18px !important;
  }
  .brand-stack img,
  .site-header .brand-stack img{
    width: 56px !important;
    max-width: 56px !important;
    height: 56px !important;
    max-height: 56px !important;
    flex-basis: 56px !important;
  }
  .brand-title{
    font-size: 20px !important;
  }
  .hero-card.hero-brand-banner{
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 32px 30px !important;
  }
  .hero-banner-image{
    min-height: auto !important;
    justify-content: flex-start !important;
  }
  .hero-banner-image img{
    width: 220px !important;
    max-height: none !important;
    margin: 10px 0 0 !important;
  }
  .clean-process-card{
    grid-template-columns: 1fr !important;
  }
  .clean-process-card .visual,
  .visual-simple img,
  .visual-emblem img,
  .clean-process-card .visual img{
    min-height: 320px !important;
  }
}
@media (max-width: 760px){
  .brand-stack img,
  .site-header .brand-stack img{
    width: 48px !important;
    max-width: 48px !important;
    height: 48px !important;
    max-height: 48px !important;
    flex-basis: 48px !important;
  }
  .brand-title{
    font-size: 18px !important;
    letter-spacing: .02em !important;
  }
  .brand-caption{
    font-size: 9px !important;
    letter-spacing: .12em !important;
  }
  .hero-card.hero-brand-banner{
    padding: 26px 22px !important;
  }
  .hero-banner-image img{
    width: 180px !important;
  }
  .clean-process-card .visual,
  .visual-simple img,
  .visual-emblem img,
  .clean-process-card .visual img{
    min-height: 260px !important;
  }
}
