/* =========================================================
   ともだち動物病院（親しみ版）— 制作サンプル
   独自デザイン: 温かみ・丸み・オーガニック / クリーム×セージ×テラコッタ
   ========================================================= */

:root{
  --cream:#FBF6EC;
  --cream-deep:#F2E8D6;
  --paper:#FFFDF8;
  --sage:#6E8E5E;
  --sage-deep:#46603A;
  --sage-soft:#EAF0E2;
  --clay:#E0936A;
  --clay-deep:#C5744A;
  --ink:#3B362E;
  --muted:#8C8475;
  --line:#E7DDC9;
  --shadow:0 18px 40px -18px rgba(70,96,58,.30);
  --shadow-sm:0 8px 22px -12px rgba(59,54,46,.25);
  --r-lg:30px; --r-md:20px; --r-sm:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,.disp{font-family:"Zen Maru Gothic","Zen Kaku Gothic New",sans-serif;font-weight:700;line-height:1.4}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(1080px,92vw);margin-inline:auto}
.eyebrow{font-size:.8rem;letter-spacing:.22em;color:var(--sage);font-weight:700;display:inline-flex;align-items:center;gap:.5em}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--clay);border-radius:2px}

/* paw decoration */
.paw{display:inline-block;width:1em;height:1em;vertical-align:-.12em;
  background:currentColor;
  -webkit-mask:radial-gradient(circle at 50% 64%,#000 30%,transparent 31%),
    radial-gradient(circle at 26% 34%,#000 13%,transparent 14%),
    radial-gradient(circle at 50% 24%,#000 13%,transparent 14%),
    radial-gradient(circle at 74% 34%,#000 13%,transparent 14%);
  mask:radial-gradient(circle at 50% 64%,#000 30%,transparent 31%),
    radial-gradient(circle at 26% 34%,#000 13%,transparent 14%),
    radial-gradient(circle at 50% 24%,#000 13%,transparent 14%),
    radial-gradient(circle at 74% 34%,#000 13%,transparent 14%);
}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:"Zen Maru Gothic",sans-serif;
  font-weight:700;font-size:1rem;padding:.85em 1.6em;border-radius:999px;transition:.25s;cursor:pointer;border:none}
.btn-primary{background:var(--sage);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--sage-deep);transform:translateY(-2px)}
.btn-clay{background:var(--clay);color:#fff;box-shadow:var(--shadow-sm)}
.btn-clay:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--sage-deep);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--sage);transform:translateY(-2px)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,246,236,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6em;font-family:"Zen Maru Gothic",sans-serif;font-weight:700;font-size:1.18rem;color:var(--sage-deep)}
.brand .mark{width:40px;height:40px;border-radius:50%;background:var(--sage);color:#fff;display:grid;place-items:center;font-size:1.1rem}
.nav-links{display:flex;align-items:center;gap:1.6em}
.nav-links a{font-weight:500;font-size:.95rem;color:var(--ink);transition:.2s}
.nav-links a:hover{color:var(--sage)}
.nav-cta{margin-left:.4em}
.burger{display:none;background:none;border:none;font-size:1.6rem;color:var(--sage-deep);cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;padding:72px 0 90px;overflow:hidden}
.hero::before{content:"";position:absolute;width:560px;height:560px;right:-160px;top:-160px;
  background:radial-gradient(circle,var(--sage-soft),transparent 70%);border-radius:50%;z-index:0}
.hero::after{content:"";position:absolute;width:420px;height:420px;left:-150px;bottom:-180px;
  background:radial-gradient(circle,#F7E4D4,transparent 70%);border-radius:50%;z-index:0}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);letter-spacing:.01em;margin:.4em 0 .5em}
.hero h1 .hl{color:var(--sage);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.32em;background:#F4D9AE;z-index:-1;border-radius:4px}
.hero p.lead{font-size:1.06rem;color:#5a5346;max-width:30em;margin-bottom:1.8em}
.hero-cta{display:flex;gap:.9em;flex-wrap:wrap}
.hero-note{margin-top:1.4em;font-size:.86rem;color:var(--muted);display:flex;align-items:center;gap:.5em}
.hero-art{position:relative}
.hero-art img{border-radius:34px 34px 34px 70px;box-shadow:var(--shadow);aspect-ratio:3/2;object-fit:cover;width:100%}
.hero-badge{position:absolute;bottom:-22px;left:-22px;background:#fff;border-radius:20px;padding:14px 20px;box-shadow:var(--shadow-sm);font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--sage-deep);font-size:.92rem;line-height:1.5}
.hero-badge b{color:var(--clay);font-size:1.5rem;display:block}

/* ---------- animal chips ---------- */
.animals{background:var(--paper);border-block:1px solid var(--line);padding:30px 0}
.animals .wrap{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.animals .lbl{font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--muted);margin-right:.4em}
.chip{display:inline-flex;align-items:center;gap:.45em;background:var(--sage-soft);color:var(--sage-deep);
  font-weight:700;font-size:.95rem;padding:.5em 1.1em;border-radius:999px}

/* ---------- section base ---------- */
section.block{padding:84px 0}
.sec-head{text-align:center;margin-bottom:48px}
.sec-head h2{font-size:clamp(1.6rem,3.2vw,2.2rem);margin:.3em 0}
.sec-head p{color:var(--muted)}

/* ---------- care services ---------- */
.care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.care-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:30px 26px;transition:.25s}
.care-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.care-card .ic{width:52px;height:52px;border-radius:16px;background:var(--sage-soft);color:var(--sage-deep);display:grid;place-items:center;font-size:1.5rem;margin-bottom:16px}
.care-card:nth-child(3n+2) .ic{background:#F7E4D4;color:var(--clay-deep)}
.care-card h3{font-size:1.12rem;margin-bottom:.4em}
.care-card p{font-size:.92rem;color:#5f594d}

/* ---------- pricing ---------- */
.price{background:var(--sage-soft)}
.price-table{background:var(--paper);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;max-width:720px;margin-inline:auto}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:none}
.price-row .nm{font-family:"Zen Maru Gothic",sans-serif;font-weight:700}
.price-row .nm small{display:block;font-weight:400;font-size:.8rem;color:var(--muted);font-family:"Zen Kaku Gothic New",sans-serif}
.price-row .amt{font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--sage-deep);font-size:1.15rem;white-space:nowrap}
.price-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:18px}

/* ---------- doctor ---------- */
.doctor .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:center}
.doctor-img img{border-radius:28px 70px 28px 28px;box-shadow:var(--shadow);aspect-ratio:1/1;object-fit:cover;width:100%}
.doctor h2{font-size:clamp(1.5rem,3vw,2rem);margin:.3em 0 .6em}
.doctor .quote{font-size:1.05rem;color:#5a5346;border-left:4px solid var(--clay);padding-left:18px;margin:1.2em 0;font-family:"Zen Maru Gothic",sans-serif}
.doctor .sign{font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--sage-deep);margin-top:1em}
.doctor .sign small{display:block;font-weight:400;color:var(--muted);font-size:.85rem;font-family:"Zen Kaku Gothic New",sans-serif}

/* ---------- hours / emergency ---------- */
.hours .wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.hours-table{width:100%;border-collapse:collapse;background:var(--paper);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.hours-table th,.hours-table td{padding:13px 10px;text-align:center;border-bottom:1px solid var(--line);font-size:.92rem}
.hours-table thead th{background:var(--sage);color:#fff;font-family:"Zen Maru Gothic",sans-serif}
.hours-table td.am{color:var(--sage-deep);font-weight:700}
.hours-table .x{color:var(--clay-deep)}
.emergency{background:#FBEFE6;border:1px dashed var(--clay);border-radius:var(--r-md);padding:26px}
.emergency h3{color:var(--clay-deep);display:flex;align-items:center;gap:.5em;margin-bottom:.6em}
.emergency p{font-size:.92rem;color:#6a5e52}
.emergency .tel{font-family:"Zen Maru Gothic",sans-serif;font-weight:700;font-size:1.3rem;color:var(--clay-deep);margin-top:.4em}

/* ---------- access ---------- */
.access .wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.access-img img{border-radius:var(--r-lg);box-shadow:var(--shadow);aspect-ratio:3/2;object-fit:cover;width:100%}
.access dl{display:grid;grid-template-columns:auto 1fr;gap:14px 22px;margin-top:1.4em}
.access dt{font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--sage-deep)}
.access dd{color:#5a5346}

/* ---------- final CTA ---------- */
.final{background:var(--sage-deep);color:#fff;text-align:center;border-radius:var(--r-lg);padding:60px 30px;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,rgba(224,147,106,.45),transparent 55%)}
.final-inner{position:relative;z-index:1}
.final h2{color:#fff;font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:.4em}
.final p{color:#D8E3CE;margin-bottom:1.6em}
.final .hero-cta{justify-content:center}
.final-section{padding:84px 0}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:#cfc7b8;padding:46px 0 30px;font-size:.88rem}
.foot .wrap{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .brand{color:#fff}
.foot a{color:#cfc7b8}.foot a:hover{color:#fff}
.foot .disc{margin-top:22px;padding-top:18px;border-top:1px solid #4a443a;font-size:.78rem;color:#9b9384;line-height:1.7}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .nav-links{display:none}
  .burger{display:block}
  .hero .wrap,.doctor .wrap,.hours .wrap,.access .wrap{grid-template-columns:1fr;gap:34px}
  .hero{padding:48px 0 70px}
  .care-grid{grid-template-columns:1fr 1fr}
  .hero-art{order:-1}
}
@media(max-width:520px){
  .care-grid{grid-template-columns:1fr}
  .price-row{padding:16px 20px}
  .foot .wrap{flex-direction:column}
}
