
:root{
  --bg:#f2f4f2;
  --paper:#fffdf8;
  --ink:#24302c;
  --muted:#68756f;
  --line:#dfe7de;
  --forest:#243b35;
  --moss:#bfd4bf;
  --sky:#d8e8f4;
  --clay:#efd7ca;
  --amber:#c89356;
  --shadow:0 24px 58px rgba(54,72,63,.10);
  --radius:28px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  background:
    linear-gradient(180deg,rgba(255,253,248,.96),rgba(242,244,242,.98)),
    radial-gradient(circle at 0% 0%,rgba(191,212,191,.40),transparent 24%);
  color:var(--ink);
  line-height:1.82;
}
a{color:#8d633a;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{width:min(var(--max),calc(100% - 36px));margin:0 auto}
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,253,248,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  align-items:center;
}
.logo{display:flex;align-items:center;gap:13px;font-weight:900;text-transform:uppercase;letter-spacing:.025em;color:var(--ink)}
.logo-mark{
  width:54px;height:54px;border-radius:50% 50% 18px 18px;
  background:linear-gradient(135deg,var(--forest),var(--moss));
  box-shadow:var(--shadow);
  border:1px solid rgba(36,59,53,.18);
  position:relative;
}
.logo-mark:before{content:"";position:absolute;inset:13px;border:1px solid rgba(255,255,255,.65);border-radius:50% 50% 12px 12px}
.logo small{display:block;text-transform:none;color:var(--muted);font-weight:600;letter-spacing:0}
nav{display:flex;justify-content:flex-end;gap:18px;align-items:center;flex-wrap:wrap}
nav a{font-weight:800;color:var(--muted);font-size:.92rem}
nav a:hover{color:var(--ink);text-decoration:none}
.nav-cta{padding:11px 18px;border-radius:999px;background:var(--forest);color:#fff;border:1px solid rgba(36,59,53,.25)}
h1,h2,h3{font-family:Georgia,'Times New Roman',serif;line-height:1.08;margin:0 0 16px}
h1{font-size:clamp(2.75rem,5.2vw,5.1rem);max-width:12ch;text-transform:lowercase}
h2{font-size:clamp(2rem,3vw,3.05rem)}
h3{font-size:1.55rem}
p,li{color:var(--muted)}
.hero{padding:78px 0 38px}
.hero-layout{display:grid;grid-template-columns:1.22fr .78fr;gap:26px;align-items:start}
.hero-main,.index-card,.box,.guide-card,.resort-card,.footer-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-main{padding:42px;background:linear-gradient(180deg,#fffdf8,#f6f3ec)}
.index-card{padding:28px;background:linear-gradient(180deg,#f9fff9,#fffdf8)}
.kicker{font-family:Georgia,serif;font-style:italic;color:var(--amber);font-size:1.08rem;margin-bottom:14px;display:inline-block}
.lead{font-size:1.08rem;max-width:780px}
.index-list{display:grid;gap:13px;margin-top:22px}
.index-item{padding:16px;border:1px solid var(--line);border-radius:18px;background:#fbf8f0}
.index-item strong{display:block;color:var(--ink)}
.guide-card{padding:26px;margin-top:18px;background:linear-gradient(135deg,#f8f4eb,#edf7ef)}
.price{font-size:2.8rem;font-family:Georgia,serif;color:#986638;line-height:1}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:16px;padding:15px 20px;font-weight:900;color:#fff;background:var(--forest);border:1px solid rgba(36,59,53,.22)}
.btn.full{width:100%;margin-top:18px}
section{padding:34px 0}
.section-head{max-width:900px;margin:0 auto 24px;text-align:center}
.box{padding:28px}
.notice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.notice-card{padding:20px;border-radius:22px;border:1px solid var(--line);background:#fbf8ef}
.resort-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.resort-card{overflow:hidden;background:#fff}
.media{aspect-ratio:1.45/1;background:#eee;overflow:hidden}
.media img{width:100%;height:100%;object-fit:cover}
.resort-body{padding:16px}
.resort-body h3{font-size:1.22rem;margin-bottom:6px}
.tag{font-size:.84rem;color:#7e907f;margin-bottom:8px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid{display:grid;gap:12px}
input,textarea{width:100%;padding:14px 15px;border-radius:14px;border:1px solid var(--line);font:inherit;background:#fff;color:var(--ink)}
textarea{min-height:140px;resize:vertical}
.success{display:none;margin-top:12px;padding:14px;border-radius:14px;background:#edf7ef;color:#467252;border:1px solid #d2e8d6;font-weight:900}
.success.show{display:block}
.page-hero{padding:66px 0 20px}
.page-hero .box{max-width:900px;margin:auto;text-align:center}
.content{max-width:960px;margin:auto}
.footer{padding:20px 0 44px}
.footer-card{text-align:center;padding:22px}
.footer-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:10px}
.small{font-size:.92rem}
@media(max-width:1100px){.hero-layout,.two-col,.notice-grid{grid-template-columns:1fr}.resort-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){nav{display:none}.resort-grid{grid-template-columns:1fr}.hero-main,.index-card,.box{padding:24px}h1{max-width:none}.header-inner{display:flex;justify-content:space-between}}
