/* =====================================================================
   REINE — shared stylesheet (4 trang dùng chung)
   THEME mặc định = Phương án A (hồng nhạt + trắng).
   Thêm class "theme-terra" vào <body> = Phương án B (hồng + CTA terracotta).
   Đổi palette: chỉ sửa :root dưới đây.
   ---------------------------------------------------------------------
   PHƯƠNG ÁN A (mặc định) — hồng nhạt nữ tính
     --terra #C9847E  CTA / nút (hover #B56B65)
     --bg #FBF2F0 nền · --band #F8E5E3 band hồng · --soft #FCF2F0 thẻ nhạt
     --brown #5E4640 heading/logo · --bsoft #806A64 body
     --rose #BC8079 tiêu đề serif italic · --gold #CBA992 kẻ/chấm
     --price #B06A5E số giá · --line #EFDAD6 viền · --card #FFFFFF
   FONT: Parisienne(script "Reine") · Cormorant Garamond(EN italic)
         Noto Serif JP(tagline/heading) · Noto Sans JP(body/nav)
   ===================================================================== */
:root{
  --bg:#FBF2F0; --band:#F8E5E3; --card:#FFFFFF; --soft:#FCF2F0;
  --terra:#C9847E; --terra-d:#B56B65; --brown:#5E4640; --bsoft:#806A64;
  --rose:#BC8079; --gold:#CBA992; --price:#B06A5E; --line:#EFDAD6;
  --script:'Parisienne',cursive; --serif:'Cormorant Garamond',serif;
  --sjp:'Noto Serif JP',serif; --jp:'Noto Sans JP',sans-serif;
  --hero-g:radial-gradient(120% 90% at 18% 40%,#fef6f5 0%,#f9e7e5 55%,#f4dcd9 100%);
  --blob1:#f1cac6; --blob2:#ecd0c9; --foot:#f4e3e0;
  --h1:#5e4640; --bandh:#b07a70; --wm:#8a5d56;
}
/* ---- Phương án B: hồng + CTA terracotta (giữ nút nâu đỏ như mockup gốc) ---- */
body.theme-terra{--terra:#AE6E58; --terra-d:#9A5C47;}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--jp);color:var(--brown);background:var(--bg);line-height:1.9;font-weight:300;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* ---------- HEADER ---------- */
header{position:absolute;top:0;left:0;right:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;height:92px}
.logo-mini{display:flex;align-items:center;gap:12px}
.logo-mini .wm{font-family:var(--script);font-size:34px;color:var(--wm);line-height:.9}
.logo-mini .sub{font-size:8px;letter-spacing:.18em;color:var(--bsoft);border-top:1px solid var(--gold);padding-top:3px;margin-top:2px}
.menu{display:flex;align-items:center;gap:36px;list-style:none}
.menu a{font-size:14px;letter-spacing:.12em;color:var(--brown);font-weight:400;transition:color .3s}
.menu a:hover,.menu a.active{color:var(--terra)}

/* ---------- HERO (chung) — có viền hoa 2 góc trên ---------- */
.hero{position:relative;overflow:hidden;padding:92px 0 70px;
  background:
   url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='200' viewBox='0 0 260 200'%3E%3Cg fill='none' stroke='%23b7c8a0' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M20 8 q30 26 40 70'/%3E%3Cpath d='M60 78 q-22 -6 -40 4'/%3E%3Cpath d='M60 78 q-6 -24 4 -44'/%3E%3Cpath d='M95 30 q24 20 30 60'/%3E%3C/g%3E%3Cg fill='%23e7a7a8'%3E%3Cg transform='translate(18,10)'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3Ccircle cx='0' cy='0' r='3.4' fill='%23e9cf6f'/%3E%3C/g%3E%3Cg transform='translate(120,86) scale(.85)'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3Ccircle r='3.4' fill='%23e9cf6f'/%3E%3C/g%3E%3Cg transform='translate(96,30) scale(.7)' fill='%23f0c4c0'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3C/g%3E%3C/g%3E%3Cg fill='%23a9c08c'%3E%3Cellipse cx='52' cy='40' rx='5' ry='11' transform='rotate(28 52 40)'/%3E%3Cellipse cx='86' cy='70' rx='5' ry='11' transform='rotate(-18 86 70)'/%3E%3C/g%3E%3C/svg%3E") top left / 230px auto no-repeat,
   url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='200' viewBox='0 0 260 200'%3E%3Cg transform='translate(260,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23b7c8a0' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M20 8 q30 26 40 70'/%3E%3Cpath d='M60 78 q-22 -6 -40 4'/%3E%3Cpath d='M60 78 q-6 -24 4 -44'/%3E%3Cpath d='M95 30 q24 20 30 60'/%3E%3C/g%3E%3Cg fill='%23e7a7a8'%3E%3Cg transform='translate(18,10)'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3Ccircle r='3.4' fill='%23e9cf6f'/%3E%3C/g%3E%3Cg transform='translate(120,86) scale(.85)'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3Ccircle r='3.4' fill='%23e9cf6f'/%3E%3C/g%3E%3Cg transform='translate(96,30) scale(.7)' fill='%23f0c4c0'%3E%3Cellipse cx='0' cy='-9' rx='4.5' ry='9'/%3E%3Cellipse cx='0' cy='9' rx='4.5' ry='9'/%3E%3Cellipse cx='-9' cy='0' rx='9' ry='4.5'/%3E%3Cellipse cx='9' cy='0' rx='9' ry='4.5'/%3E%3C/g%3E%3C/g%3E%3Cg fill='%23a9c08c'%3E%3Cellipse cx='52' cy='40' rx='5' ry='11' transform='rotate(28 52 40)'/%3E%3Cellipse cx='86' cy='70' rx='5' ry='11' transform='rotate(-18 86 70)'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") top right / 230px auto no-repeat,
   var(--hero-g)}
.hero::before,.hero::after{content:"";position:absolute;width:340px;height:340px;opacity:.5;filter:blur(8px);pointer-events:none}
.hero::before{top:-90px;left:-80px;background:radial-gradient(circle,var(--blob1),transparent 65%)}
.hero::after{bottom:-120px;right:-60px;background:radial-gradient(circle,var(--blob2),transparent 65%)}
.hero-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:30px;min-height:430px}
/* wreath logo */
.wreath{position:relative;width:430px;max-width:100%;margin:0 auto;text-align:center}
.wreath svg,.wreath img{width:100%;height:auto;display:block}
.wreath .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.wreath .name{font-family:var(--script);font-size:92px;color:var(--wm);line-height:.8}
.wreath .jp{font-family:var(--sjp);font-size:14px;letter-spacing:.5em;color:#97726a;margin:8px 0 4px;padding-left:.5em}
.wreath .en{font-family:var(--serif);font-style:italic;font-size:14px;letter-spacing:.08em;color:#b08a82}
/* hero copy */
.hero-copy h1{font-family:var(--sjp);font-weight:500;font-size:31px;line-height:1.75;color:var(--h1);letter-spacing:.04em}
.orn{display:flex;align-items:center;gap:12px;color:var(--gold);margin:20px 0;font-size:13px}
.orn span{height:1px;width:54px;background:var(--gold)}
.hero-copy .lead{font-family:var(--sjp);font-size:15px;color:#6f5b54;letter-spacing:.04em;line-height:2}
.cta-col{margin-top:32px;display:flex;flex-direction:column;gap:14px;max-width:330px}
.btn-line-cta,.btn-fill-cta{display:flex;align-items:center;justify-content:center;gap:12px;height:56px;border-radius:40px;font-family:var(--sjp);font-size:15px;letter-spacing:.12em;transition:.3s;position:relative}
.btn-fill-cta{background:linear-gradient(180deg,var(--terra),var(--terra-d));color:#fff;box-shadow:0 12px 26px -12px rgba(150,80,75,.6)}
.btn-fill-cta:hover{filter:brightness(.94)}
.btn-fill-cta .ar{position:absolute;right:18px;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.25);display:grid;place-items:center;font-size:13px}
.btn-line-cta{background:rgba(255,255,255,.6);border:1px solid var(--terra);color:var(--terra)}
.btn-line-cta:hover{background:#fff}.btn-line-cta .ar{position:absolute;right:22px;font-size:15px}

/* ---------- BAND (tiêu đề section) ---------- */
.band{background:var(--band);text-align:center;padding:46px 0}
.band .dots{color:var(--gold);letter-spacing:.5em;font-size:12px;margin-bottom:6px}
.band h2{font-family:var(--serif);font-style:italic;font-size:40px;font-weight:500;color:var(--bandh)}
.band .jp{font-family:var(--sjp);font-size:12px;letter-spacing:.4em;color:#bb968c;margin-top:4px}
.band p{font-family:var(--sjp);font-size:14px;color:var(--bsoft);margin-top:16px;line-height:2}

/* ---------- MENU ICONS (TOP/Menu) ---------- */
.svc-band{background:var(--band);padding:0 0 56px;text-align:center}
.icon-row{display:flex;justify-content:center;gap:42px;flex-wrap:wrap;max-width:760px;margin:0 auto;background:#fff;border-radius:14px;padding:32px 26px;box-shadow:0 16px 40px -28px rgba(150,90,80,.5)}
.icon-item{display:flex;flex-direction:column;align-items:center;gap:11px;width:102px}
.icon-item .ic{width:60px;height:60px;border-radius:50%;background:var(--soft);border:1px solid var(--line);display:grid;place-items:center;font-size:25px}
.icon-item .lb{font-family:var(--sjp);font-size:12.5px;color:var(--brown)}
.icon-item .lb small{display:block;font-size:9px;color:var(--bsoft);margin-top:2px}

/* ---------- CONCEPT (TOP) ---------- */
.concept{padding:90px 0;text-align:center}
.concept .en{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--rose)}
.concept h3{font-family:var(--sjp);font-size:24px;font-weight:500;color:var(--h1);margin:14px 0 24px;letter-spacing:.06em;line-height:1.8}
.concept p{max-width:620px;margin:0 auto;font-size:15px;color:var(--bsoft);line-height:2.2}
.interior-hero{height:440px;background:#e7d2c6 center/cover;background-image:linear-gradient(rgba(94,70,64,.06),rgba(94,70,64,.06)),url('https://images.unsplash.com/photo-1633681926022-84c23e8cb2d6?auto=format&fit=crop&w=1600&q=80')}

/* ---------- MENU & PRICE ---------- */
.menu-sec{padding:70px 0 30px}
.campaign{max-width:880px;margin:0 auto 70px;border:1px solid var(--gold);border-radius:10px;background:linear-gradient(#fff,#fdf4f2);padding:30px 40px}
.campaign .ttl{text-align:center;font-family:var(--sjp);font-size:14px;letter-spacing:.2em;color:var(--terra);margin-bottom:18px}
.campaign .ttl::before,.campaign .ttl::after{content:"❀";color:var(--gold);margin:0 10px;font-size:11px}
.crow{display:flex;justify-content:space-between;align-items:baseline;padding:10px 6px;border-top:1px dotted var(--line)}
.crow .nm{font-family:var(--sjp);font-size:15px}
.crow .pr{font-family:var(--serif);font-size:22px;color:var(--price)}
.crow .pr small,.pitem .pr small,.minibox .pr small{font-family:var(--jp);font-size:10px;color:var(--bsoft);margin-left:3px}
.cat{max-width:980px;margin:0 auto 64px}
.cat-title{text-align:center;margin-bottom:34px}
.cat-title h3{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--rose);font-weight:500}
.cat-title .jp{font-family:var(--sjp);font-size:12px;letter-spacing:.4em;color:#bb968c;margin-top:2px}
.mcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px;margin-bottom:22px;box-shadow:0 14px 34px -28px rgba(150,90,80,.5)}
.mcard .top{display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:start}
.mcard .ph{width:160px;height:120px;border-radius:8px;background:#ecd9d2 center/cover}
.mcard h4{font-family:var(--sjp);font-size:18px;font-weight:500;color:var(--brown);display:flex;align-items:center;gap:10px}
.badge{font-size:10px;letter-spacing:.1em;color:#fff;background:var(--terra);border-radius:20px;padding:2px 11px;font-weight:400}
.mcard .desc{font-size:13px;color:var(--bsoft);margin-top:10px;line-height:1.95}
.plist{margin-top:18px;border-top:1px solid var(--line)}
.pitem{display:flex;align-items:baseline;justify-content:space-between;padding:11px 4px;border-bottom:1px dotted var(--line)}
.pitem .nm{font-family:var(--sjp);font-size:14px}
.pitem .pr{font-family:var(--serif);font-size:19px;color:var(--price);white-space:nowrap}
.subgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:6px}
.minibox{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:20px 24px}
.minibox h5{font-family:var(--sjp);font-size:15px;margin-bottom:6px}
.minibox .pr{font-family:var(--serif);font-size:22px;color:var(--price)}
.minibox p{font-size:12px;color:var(--bsoft)}
.flow{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:24px 28px;margin-top:18px}
.flow h5{font-family:var(--sjp);font-size:15px;color:var(--brown);margin-bottom:14px}
.flow .step{display:flex;gap:12px;padding:8px 0}
.flow .n{width:22px;height:22px;border-radius:50%;background:var(--terra);color:#fff;font-size:11px;display:grid;place-items:center;flex:none;margin-top:3px}
.flow .step .t{font-family:var(--sjp);font-size:13.5px;color:var(--brown)}
.flow .step .t span{display:block;font-size:12px;color:var(--bsoft);font-weight:300}
.worry{margin-top:14px;font-size:12.5px;color:var(--bsoft)}
.worry b{display:block;color:var(--brown);font-family:var(--sjp);font-weight:500;margin-bottom:4px}
.note{max-width:980px;margin:10px auto 0;background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:26px 34px}
.note h5{font-family:var(--sjp);font-size:14px;letter-spacing:.1em;margin-bottom:10px}
.note ul{list-style:none}
.note li{font-size:12.5px;color:var(--bsoft);padding:4px 0 4px 18px;position:relative}
.note li::before{content:"・";position:absolute;left:2px;color:var(--rose)}

/* ---------- SALON / ABOUT ---------- */
.sec{padding:88px 0}
.sec-head{text-align:center;margin-bottom:50px}
.sec-head h3{font-family:var(--serif);font-style:italic;font-size:32px;color:var(--rose);font-weight:500}
.sec-head .jp{font-family:var(--sjp);font-size:12px;letter-spacing:.4em;color:#bb968c;margin-top:4px}
.msg-card{max-width:880px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:44px 50px;display:grid;grid-template-columns:120px 1fr;gap:34px;align-items:start;box-shadow:0 18px 44px -34px rgba(150,90,80,.6)}
.avatar{width:120px;height:120px;border-radius:50%;background:var(--soft);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-size:46px;font-style:italic;color:var(--rose)}
.msg-card .nm{font-family:var(--sjp);font-size:18px;font-weight:500;color:var(--brown)}
.msg-card .role{font-size:12px;letter-spacing:.1em;color:var(--rose);margin-bottom:18px}
.msg-card p{font-size:14px;color:var(--bsoft);line-height:2.2;margin-bottom:14px}
.msg-card .sign{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--rose)}
.policy{background:var(--band)}
.policy-grid{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:30px 32px}
.pcard .ic{width:48px;height:48px;border-radius:50%;background:var(--soft);display:grid;place-items:center;font-size:22px;margin-bottom:16px}
.pcard h4{font-family:var(--sjp);font-size:17px;font-weight:500;color:var(--brown);margin-bottom:10px}
.pcard p{font-size:13px;color:var(--bsoft);line-height:1.95}
.bento{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:170px 170px;gap:14px}
.bento div{border-radius:8px;background:#ecd9d2 center/cover;position:relative;display:grid;place-items:center;text-align:center}
.bento div .cap{position:relative;z-index:2;color:#fff;text-shadow:0 1px 6px rgba(80,50,45,.6)}
.bento div .cap .jp{font-family:var(--sjp);font-size:15px;letter-spacing:.1em}
.bento div .cap .en{font-family:var(--serif);font-style:italic;font-size:12px;opacity:.9}
.bento .b1{grid-row:span 2;background-image:linear-gradient(rgba(94,70,64,.28),rgba(94,70,64,.28)),url('https://images.unsplash.com/photo-1633681926022-84c23e8cb2d6?auto=format&fit=crop&w=800&q=80')}
.bento .b2{background-image:linear-gradient(rgba(94,70,64,.28),rgba(94,70,64,.28)),url('https://images.unsplash.com/photo-1560066984-138dadb4c035?auto=format&fit=crop&w=600&q=80')}
.bento .b3{background-image:linear-gradient(rgba(94,70,64,.28),rgba(94,70,64,.28)),url('https://images.unsplash.com/photo-1571875257727-256c39da42af?auto=format&fit=crop&w=600&q=80')}
.bento .b4{background-image:linear-gradient(rgba(94,70,64,.28),rgba(94,70,64,.28)),url('https://images.unsplash.com/photo-1540555700478-4be289fbecef?auto=format&fit=crop&w=600&q=80')}
.bento .b5{background-image:linear-gradient(rgba(94,70,64,.28),rgba(94,70,64,.28)),url('https://images.unsplash.com/photo-1522337094846-8a818192de1f?auto=format&fit=crop&w=600&q=80')}
.staff{background:var(--band)}
.staff-grid{max-width:980px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.member{background:#fff;border:1px solid var(--line);border-radius:10px;padding:36px 26px;text-align:center}
.member .av{width:84px;height:84px;border-radius:50%;margin:0 auto 18px;background:var(--soft);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:34px;color:var(--rose)}
.member h4{font-family:var(--serif);font-size:22px;color:var(--brown);letter-spacing:.04em}
.member .role{font-size:11px;letter-spacing:.12em;color:var(--rose);margin:4px 0 16px}
.member p{font-size:12.5px;color:var(--bsoft);line-height:2}
.faq-list{max-width:840px;margin:0 auto}
.qa{background:#fff;border:1px solid var(--line);border-radius:10px;padding:22px 28px;margin-bottom:14px}
.qa .q{font-family:var(--sjp);font-size:15px;color:var(--brown);display:flex;gap:12px;align-items:center}
.qa .q .mark{width:24px;height:24px;border-radius:50%;background:var(--soft);color:var(--terra);font-family:var(--serif);font-style:italic;display:grid;place-items:center;flex:none}
.qa .a{font-size:13px;color:var(--bsoft);line-height:2;margin-top:12px;padding-left:36px}

/* ---------- ACCESS ---------- */
.map-sec{background:var(--band);padding:0 0 60px}
.map-bar{display:flex;justify-content:flex-end;padding:18px 0}
.map-link{font-size:12px;letter-spacing:.06em;color:var(--brown);background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;transition:.3s}
.map-link:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.map-box{height:360px;border-radius:10px;overflow:hidden;display:grid;place-items:center;text-align:center;color:var(--bsoft);background:repeating-linear-gradient(45deg,#f3e4e1,#f3e4e1 20px,#eddad6 20px,#eddad6 40px)}
.map-box .pin{font-size:34px;color:var(--terra)}
.map-box .jp{font-family:var(--sjp);font-size:15px;letter-spacing:.1em;margin-top:8px}
.map-box .note{font-size:11px;margin-top:4px;letter-spacing:.2em}
.info-sec{padding:70px 0}
.dl{max-width:920px;margin:0 auto;border-top:1px solid var(--line)}
.dl .row{display:grid;grid-template-columns:170px 1fr;gap:24px;padding:20px 8px;border-bottom:1px solid var(--line);background:#fff}
.dl dt{font-family:var(--sjp);font-size:14px;letter-spacing:.06em;color:var(--brown);display:flex;align-items:center;gap:10px}
.dl dt .i{color:var(--terra)}
.dl dd{font-size:14px;color:var(--bsoft);line-height:1.95}
.dl dd small{font-size:12px;color:#bb968c}
.steps-sec{padding:10px 0 80px}
.steps-head{text-align:center;font-family:var(--sjp);font-size:18px;letter-spacing:.2em;color:var(--brown);margin-bottom:34px}
.steps-head::before,.steps-head::after{content:"❀";color:var(--gold);margin:0 12px;font-size:12px}
.steps{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.step{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:10px;padding:22px 26px}
.step .n{width:30px;height:30px;border-radius:50%;background:var(--terra);color:#fff;font-family:var(--serif);font-size:15px;display:grid;place-items:center;flex:none}
.step .t .h{font-family:var(--sjp);font-size:15px;color:var(--brown)}
.step .t p{font-size:12.5px;color:var(--bsoft);margin-top:4px}
.parking{max-width:920px;margin:18px auto 0;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:22px 26px;display:flex;gap:16px;align-items:flex-start}
.parking .ic{font-size:24px}
.parking b{font-family:var(--sjp);font-size:14px;color:var(--brown);display:block;margin-bottom:4px}
.parking p{font-size:12.5px;color:var(--bsoft)}

/* ---------- CTA cuối trang ---------- */
.cta{padding:80px 0;text-align:center}
.cta .inner{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.cta .btn-fill-cta,.cta .btn-line-cta{height:64px;max-width:none;font-size:17px}

/* ---------- FOOTER ---------- */
footer{background:var(--foot);padding:64px 0 30px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:46px;align-items:start}
.foot-logo .wm{font-family:var(--script);font-size:46px;color:var(--wm);line-height:.8}
.foot-logo .sub{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--rose);margin-top:6px}
.foot-logo p{font-size:13px;color:var(--bsoft);margin-top:16px;line-height:2}
.foot-col h4{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--rose);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;font-size:13px;color:var(--bsoft);padding:5px 0}
.foot-col a:hover{color:var(--terra)}
.copy{text-align:center;font-family:var(--serif);font-size:12px;letter-spacing:.25em;color:#bb968c;padding-top:34px;margin-top:34px;border-top:1px solid var(--line)}

@media(max-width:980px){
  .menu{display:none}
  .hero-grid,.policy-grid,.subgrid{grid-template-columns:1fr}
  .mcard .top{grid-template-columns:1fr}.mcard .ph{width:100%;height:180px}
  .msg-card{grid-template-columns:1fr;text-align:center;justify-items:center}
  .bento{grid-template-columns:1fr 1fr}.bento .b1{grid-row:auto}
  .staff-grid{grid-template-columns:1fr}.dl .row{grid-template-columns:1fr;gap:6px}
  .foot-grid{grid-template-columns:1fr}
}
