/* ===========================================
   atelier hanaroman  |  Brand Site Stylesheet
   Flower Artist Chie Wakashiro
   Light / airy / pressed-flower aesthetic.
   Re-skin via the :root tokens below.
   =========================================== */

/* ---------- Design tokens ---------- */
:root {
  /* Palette */
  --color-accent:      #d98a82;   /* dusty rose */
  --color-accent-deep: #c56f66;
  --color-pink:        #ecaca6;   /* soft button pink */
  --color-pink-deep:   #e2948c;
  --color-bg:          #ffffff;
  --color-cream:       #faf5ef;   /* soft section bg */
  --color-cream-deep:  #f4ebe0;   /* form bg */
  --color-text:        #6a615a;   /* warm gray body */
  --color-heading:     #4c453f;
  --color-line:        #e8e0d6;

  /* Typography */
  --font-jp:    'Zen Kaku Gothic New', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', sans-serif;
  --font-mincho:'Shippori Mincho', 'Hiragino Mincho ProN', serif;
  --font-en:    'Cormorant Garamond', 'Times New Roman', serif;
  --font-hand:  'Caveat', cursive;

  /* Layout */
  --max-w:        1080px;
  --max-w-wide:   1280px;
  --max-w-narrow: 720px;
  --gutter:       clamp(22px, 5vw, 64px);
  --header-h:     72px;
  --ls-wide:      .26em;   /* airy letter-spacing for headings */
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-jp);
  font-weight: 400;
  color: var(--color-text);
  line-height: 2.1;
  letter-spacing: .06em;
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-wrap: anywhere;
}
body.nav-open { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; transition: color .25s ease, opacity .25s ease; }
ul  { list-style: none; padding: 0; margin: 0; }
button { background: none; border: 0; cursor: pointer; font: inherit; color: inherit; }
h1,h2,h3,h4 { font-weight: 500; line-height: 1.7; margin: 0; color: var(--color-heading); }

/* ---------- Layout helpers ---------- */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--gutter); }
.container--wide   { max-width: var(--max-w-wide); }
.container--narrow { max-width: var(--max-w-narrow); }

.section { padding: clamp(60px, 12vw, 130px) 0; }
.section--cream { background: var(--color-cream); }

/* En script labels above titles */
.en-label {
  font-family: var(--font-en);
  font-style: italic;
  font-size: clamp(15px, 2.4vw, 20px);
  letter-spacing: .12em;
  color: var(--color-accent);
  margin: 0 0 14px;
}
.section-title {
  font-family: var(--font-jp);
  font-weight: 500;
  font-size: clamp(19px, 3.4vw, 26px);
  letter-spacing: var(--ls-wide);
  color: var(--color-heading);
  margin: 0;
}
.section-title--accent { color: var(--color-accent); }
.lead {
  font-size: clamp(13px, 1.6vw, 15px);
  line-height: 2.4;
  letter-spacing: .12em;
  color: var(--color-text);
}
.section__empty { text-align: center; color: var(--color-text); opacity: .7; }

/* ---------- Circle arrow button ---------- */
.btn-circle {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-jp);
  font-size: 13px;
  letter-spacing: .18em;
  color: var(--color-heading);
}
.btn-circle__icon {
  width: 46px; height: 46px;
  border: 1px solid var(--color-accent);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  flex-shrink: 0;
  transition: background .35s ease, color .35s ease, transform .35s ease;
}
.btn-circle__icon svg { width: 16px; height: 16px; }
.btn-circle:hover .btn-circle__icon { background: var(--color-accent); color: #fff; }
.btn-circle:hover .btn-circle__icon svg { transform: translateX(2px); }
.btn-circle--center { justify-content: center; }

/* ---------- Pink pill button ---------- */
.btn-pink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 220px;
  padding: 16px 40px;
  border-radius: 999px;
  background: var(--color-pink);
  color: #fff;
  font-size: 15px;
  letter-spacing: .16em;
  box-shadow: 0 8px 20px rgba(217,138,130,.28);
  transition: background .3s ease, transform .3s ease, box-shadow .3s ease;
}
.btn-pink:hover { background: var(--color-pink-deep); transform: translateY(-2px); box-shadow: 0 12px 26px rgba(217,138,130,.36); }

/* ===========================================
   Header
   =========================================== */
.header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  min-height: var(--header-h);
  padding: 34px var(--gutter) 14px;
  transition: background .4s ease, box-shadow .4s ease, padding .4s ease;
}
.header.is-scrolled {
  align-items: center;
  padding-top: 14px;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(140%) blur(8px);
  box-shadow: 0 1px 16px rgba(0,0,0,.05);
}
@media (max-width: 600px){
  .header { padding-top: 26px; }
}
.header__inner { text-align: center; }

.logo { display: inline-block; line-height: 1.3; color: var(--color-heading); }
.logo__pre {
  display: block;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: .18em;
  color: var(--color-accent);
  margin-bottom: 2px;
}
.logo__en {
  display: block;
  font-family: var(--font-en);
  font-size: clamp(20px, 3vw, 26px);
  letter-spacing: .22em;
  font-weight: 500;
}
.logo__ja { display: none; }
.logo--svg { line-height: 0; }
.logo__img { height: 44px; width: auto; max-width: 220px; margin: 0 auto; }

/* Header turns white text when over a dark hero — kept light by default since hero is light */

/* Hamburger (all breakpoints) */
.hamburger {
  position: fixed;
  top: 18px; right: clamp(16px, 4vw, 40px);
  width: 46px; height: 46px;
  z-index: 1100;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 7px;
}
.hamburger span {
  display: block;
  width: 26px; height: 1.4px;
  background: var(--color-heading);
  transition: transform .35s ease, opacity .3s ease;
}
.hamburger.is-open span:nth-child(1) { transform: translateY(8.4px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-8.4px) rotate(-45deg); }

/* Full-screen overlay nav */
.nav {
  position: fixed;
  inset: 0;
  z-index: 1080;
  background: rgba(250,245,239,.98);
  backdrop-filter: blur(6px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s ease, visibility .45s ease;
}
.nav.is-open { opacity: 1; visibility: visible; }
.nav__mobile-logo { display: none; }
.nav__brand {
  text-align: center;
  margin-bottom: clamp(28px, 5vw, 44px);
}
.nav__brand .logo__pre { margin-bottom: 4px; }
.nav__list {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(18px, 3.4vw, 30px);
  text-align: center;
}
.nav__list a {
  font-family: var(--font-jp);
  font-size: clamp(16px, 2.4vw, 19px);
  letter-spacing: var(--ls-wide);
  color: var(--color-heading);
  position: relative;
  padding-bottom: 6px;
}
.nav__list a::after {
  content: '';
  position: absolute; left: 50%; bottom: 0;
  width: 0; height: 1px; background: var(--color-accent);
  transition: width .35s ease, left .35s ease;
}
.nav__list a:hover { color: var(--color-accent); }
.nav__list a:hover::after { width: 100%; left: 0; }

/* ===========================================
   Hero (front page)
   =========================================== */
.hero {
  position: relative;
  height: clamp(420px, 88vh, 820px);
  overflow: hidden;
  background: var(--color-cream);
}
.hero__bg {
  position: absolute; inset: 0;
  background: var(--color-cream) center/cover no-repeat;
  transform: scale(1.04);
  animation: hero-zoom 12s ease-out forwards;
}
@keyframes hero-zoom { to { transform: scale(1); } }
@media (prefers-reduced-motion: reduce){ .hero__bg{ animation:none; transform:none; } }

/* ===========================================
   Intro (front)
   =========================================== */
.intro { text-align: center; }
.intro__en {
  font-family: var(--font-en);
  font-style: italic;
  font-size: clamp(14px, 2.2vw, 18px);
  letter-spacing: .14em;
  color: var(--color-accent);
}
.intro__catch {
  font-family: var(--font-mincho);
  font-size: clamp(26px, 5.5vw, 42px);
  font-weight: 500;
  letter-spacing: .2em;
  line-height: 1.5;
  color: var(--color-heading);
  margin: 16px 0 36px;
}
.intro__logo {
  font-family: var(--font-en);
  font-size: clamp(28px, 6vw, 46px);
  letter-spacing: .22em;
  font-weight: 500;
  color: var(--color-heading);
  margin: 8px 0 36px;
}
.intro__tagline {
  font-size: clamp(15px, 2.6vw, 20px);
  font-weight: 500;
  line-height: 2.4;
  letter-spacing: .2em;
  color: var(--color-heading);
  margin: 0 0 30px;
}
.intro__message { max-width: 30em; margin: 0 auto 34px; }

/* ===========================================
   Gallery strip (3 images)
   =========================================== */
.gallery-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(8px, 1.5vw, 16px);
}
.gallery-strip__item { overflow: hidden; }
.gallery-strip__item img {
  width: 100%; height: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  transition: transform .8s ease;
}
.gallery-strip__item:hover img { transform: scale(1.05); }
.gallery-strip__item:nth-child(2) img { aspect-ratio: 3/4.4; }
@media (max-width: 600px){
  .gallery-strip { grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .gallery-strip__item img { aspect-ratio: 3/4; }
}

/* ===========================================
   Services header (two-column)
   =========================================== */
.svc-head {
  max-width: 860px;
  margin: 0 auto clamp(40px, 7vw, 70px);
  text-align: center;
}
.svc-head .lead { margin-top: 18px; }

/* Service item (alternating) */
.service {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
  margin-bottom: clamp(48px, 9vw, 96px);
}
.service:last-child { margin-bottom: 0; }
.service__img img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.service__body { }
.service__title {
  font-size: clamp(18px, 3vw, 24px);
  letter-spacing: var(--ls-wide);
  margin: 0 0 18px;
}
.service__desc { margin: 0 0 28px; }
@media (min-width: 820px){
  .service { grid-template-columns: 1.1fr 1fr; }
  .service--reverse .service__img { order: 2; }
}

/* ===========================================
   Simple two-column block (image + text)
   =========================================== */
.media-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
  margin-bottom: clamp(40px, 8vw, 84px);
}
.media-block:last-child { margin-bottom: 0; }
.media-block__img img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.media-block__title { font-size: clamp(17px, 2.6vw, 22px); letter-spacing: var(--ls-wide); margin: 0 0 16px; }
@media (min-width: 820px){
  .media-block { grid-template-columns: 1fr 1fr; }
  .media-block--reverse .media-block__img { order: 2; }
}

/* ===========================================
   CTA band
   =========================================== */
.cta { text-align: center; }
.cta__title {
  font-size: clamp(18px, 3.2vw, 26px);
  letter-spacing: var(--ls-wide);
  margin: 0 0 30px;
}

/* ===========================================
   Page hero (sub pages)
   =========================================== */
.page-hero {
  position: relative;
  height: clamp(320px, 70vh, 640px);
  overflow: hidden;
  background: var(--color-cream);
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-hero__bg {
  position: absolute; inset: 0;
  background: var(--color-cream) center/cover no-repeat;
}
.page-hero__title {
  position: relative;
  z-index: 1;
  font-family: var(--font-en);
  font-size: clamp(30px, 7vw, 60px);
  letter-spacing: .12em;
  color: var(--color-accent);
  text-shadow: 0 2px 20px rgba(255,255,255,.5);
}
.page-hero__title--jp { font-family: var(--font-jp); letter-spacing: var(--ls-wide); }
.page-hero__title-ja {
  display: block;
  font-family: var(--font-jp);
  font-size: clamp(15px, 2.6vw, 20px);
  letter-spacing: var(--ls-wide);
  color: var(--color-heading);
  margin-top: 12px;
}

/* Page intro (centered text under hero) */
.page-intro { text-align: center; }
.page-intro__title {
  font-size: clamp(18px, 3.2vw, 26px);
  letter-spacing: var(--ls-wide);
  line-height: 1.9;
  margin: 0 0 26px;
}
.spec-line {
  font-size: 13px;
  letter-spacing: .1em;
  color: var(--color-text);
  margin: 22px 0 0;
}
.spec-line span { white-space: nowrap; margin: 0 .4em; }

/* ===========================================
   Plan page — color swatches
   =========================================== */
.block-head { text-align: center; margin-bottom: clamp(28px, 5vw, 48px); }
.block-head__title {
  font-size: clamp(16px, 2.8vw, 22px);
  letter-spacing: var(--ls-wide);
  margin: 0 0 14px;
}
.block-head__note { font-size: 13px; letter-spacing: .08em; max-width: 38em; margin: 0 auto; }

.swatch-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(18px, 3vw, 36px) clamp(14px, 2vw, 28px);
}
@media (min-width: 700px){ .swatch-grid { grid-template-columns: repeat(3, 1fr); } }
.swatch { text-align: center; }
.swatch__img {
  aspect-ratio: 1/1;
  background: var(--color-cream);
  overflow: hidden;
  border-radius: 4px;
}
.swatch__img img { width: 100%; height: 100%; object-fit: cover; }
.swatch__label { font-size: 13px; letter-spacing: .1em; margin-top: 12px; }

/* Frame color pair */
.frame-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 3vw, 40px);
  max-width: 720px;
  margin: 0 auto;
}
.frame-pair .swatch__img { aspect-ratio: 4/3; }

/* Name art */
.name-art { text-align: center; }
.name-art__img { max-width: 760px; margin: 0 auto; }

/* Detail grid */
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(14px, 2.4vw, 28px);
}
.detail-grid figure { margin: 0; }
.detail-grid img { width: 100%; aspect-ratio: 4/3; object-fit: cover; background: var(--color-cream); border-radius: 4px; }
.detail-grid figcaption { font-size: 12px; letter-spacing: .08em; text-align: center; margin-top: 8px; color: var(--color-text); }

/* Spec card */
.spec-card {
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: 6px;
  padding: clamp(26px, 5vw, 44px);
  text-align: center;
}
/* When the spec card sits on a cream section, lift it to white so the frame reads. */
.section--cream .spec-card { background: #fff; }
.spec-card__price {
  font-family: var(--font-en);
  font-size: clamp(26px, 5vw, 40px);
  letter-spacing: .04em;
  color: var(--color-accent);
}
.spec-card__rows { font-size: 14px; letter-spacing: .08em; margin-top: 12px; }
.spec-card__rows span { display: inline-block; margin: 0 .6em; white-space: nowrap; }

/* Button row */
.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 22px 40px;
  justify-content: center;
  align-items: center;
}

/* ===========================================
   Flow steps
   =========================================== */
.flow-step {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 3vw, 44px);
  align-items: center;
}
.flow-step__num {
  font-family: var(--font-en);
  font-size: 15px;
  letter-spacing: .2em;
  color: var(--color-accent);
  margin: 0 0 10px;
}
.flow-step__title { font-size: clamp(16px, 2.6vw, 21px); letter-spacing: var(--ls-wide); margin: 0 0 14px; }
.flow-step__img img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 4px; }
@media (min-width: 760px){
  .flow-step { grid-template-columns: 1fr 0.9fr; }
}
.flow-arrow { text-align: center; color: var(--color-accent); font-size: 22px; margin: clamp(18px,3vw,30px) 0; }

/* ===========================================
   Profile card (mentor)
   =========================================== */
.profile {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
  background: var(--color-cream);
  border-radius: 6px;
  padding: clamp(24px, 4vw, 44px);
}
@media (min-width: 700px){ .profile { grid-template-columns: 200px 1fr; } }
.profile__img img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 4px; }
.profile__name { font-size: 18px; letter-spacing: var(--ls-wide); margin: 0 0 6px; }
.profile__name small { font-family: var(--font-en); font-style: italic; font-size: 13px; color: var(--color-accent); margin-left: 10px; letter-spacing: .1em; }
.profile__text { font-size: 13px; line-height: 2.2; margin: 8px 0 0; }

/* ===========================================
   Artist profile (about page)
   =========================================== */
.prof-list { max-width: 700px; margin: 0 auto; }
.prof-list__row {
  padding: 16px 4px;
  border-bottom: 1px solid var(--color-line);
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
}
.prof-list__row:first-child { border-top: 1px solid var(--color-line); }
@media (min-width: 600px){
  .prof-list__row { grid-template-columns: 116px 1fr; gap: 28px; align-items: baseline; }
}
.prof-list__year {
  font-family: var(--font-en);
  font-size: 16px;
  letter-spacing: .1em;
  color: var(--color-accent);
}
.prof-list__text { font-size: 15px; line-height: 1.9; }

.qual-list {
  max-width: 660px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px 32px;
}
@media (min-width: 600px){ .qual-list { grid-template-columns: 1fr 1fr; } }
.qual-list li { position: relative; padding-left: 20px; font-size: 14.5px; line-height: 1.8; }
.qual-list li::before {
  content: '';
  position: absolute;
  left: 2px; top: 11px;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--color-accent);
}

.text-link {
  font-size: 14px;
  letter-spacing: .08em;
  color: var(--color-accent);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: opacity .25s ease;
}
.text-link:hover { opacity: .6; }

.artist-name { text-align: center; }
.artist-name__en {
  font-family: var(--font-en);
  font-size: clamp(16px, 2.6vw, 20px);
  letter-spacing: .2em;
  color: var(--color-text-sub, #b6a99c);
  margin: 10px 0 0;
}

/* ===========================================
   Book gallery
   =========================================== */
.book-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 2vw, 20px);
}
.book-grid img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 4px; }
.book-grid__wide { grid-column: 1 / -1; }
.book-grid__wide img { aspect-ratio: 16/7; }

/* ===========================================
   Reservation / Contact form
   =========================================== */
.reservation__head { text-align: center; margin-bottom: clamp(30px, 5vw, 50px); }
.reservation__script {
  font-family: var(--font-hand);
  font-size: clamp(36px, 8vw, 64px);
  color: var(--color-heading);
  line-height: 1;
}
.reservation__sub { font-size: 13px; letter-spacing: var(--ls-wide); color: var(--color-accent); margin-top: 6px; }
.reservation__note { text-align: center; font-size: 13px; margin: 0 0 30px; }

/* ===========================================
   Sample matrix table
   =========================================== */
.matrix-wrap { overflow-x: auto; }
.matrix {
  border-collapse: collapse;
  width: 100%;
  min-width: 620px;
  font-size: 12px;
  letter-spacing: .06em;
  text-align: center;
}
.matrix th, .matrix td { border: 1px solid var(--color-line); padding: 10px; vertical-align: middle; }
.matrix thead th { background: var(--color-cream); font-weight: 500; }
.matrix td img { width: 100%; max-width: 120px; margin: 0 auto 6px; border-radius: 3px; }
.matrix .matrix__corner { background: var(--color-cream-deep); }

/* ===========================================
   Footer
   =========================================== */
.footer { background: var(--color-cream); padding: clamp(54px, 9vw, 88px) 0 30px; text-align: center; }
.footer__logo {
  font-family: var(--font-en);
  font-size: clamp(22px, 4vw, 30px);
  letter-spacing: .22em;
  color: var(--color-heading);
  display: inline-block;
}
.footer__logo .logo__pre { font-size: 11px; }
.footer__logo .logo__ja { display: none; }
.footer__tagline { font-size: 12px; letter-spacing: .1em; margin: 16px 0 0; opacity: .85; }
.footer__info { font-size: 12px; line-height: 2; letter-spacing: .08em; margin-top: 18px; opacity: .85; }
.footer__menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 28px;
  margin: 30px 0 0;
}
.footer__menu a { font-size: 13px; letter-spacing: .14em; }
.footer__menu a:hover { color: var(--color-accent); }
.footer__sns { display: flex; justify-content: center; gap: 16px; margin-top: 26px; }
.footer__sns-link {
  width: 40px; height: 40px;
  border: 1px solid var(--color-line);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-accent);
}
.footer__sns-link svg { width: 18px; height: 18px; }
.footer__sns-link:hover { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.footer__copy {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: .12em;
  margin: clamp(36px, 6vw, 56px) 0 0;
  color: var(--color-text);
  opacity: .7;
}

/* ===========================================
   Breadcrumbs
   =========================================== */
.hr-breadcrumbs { padding: 14px 0 0; }
.hr-breadcrumbs__list { display: flex; flex-wrap: wrap; gap: 8px; font-size: 11px; letter-spacing: .08em; color: var(--color-text); opacity: .8; }
.hr-breadcrumbs__item:not(:last-child)::after { content: '／'; margin-left: 8px; opacity: .5; }
.hr-breadcrumbs__item a:hover { color: var(--color-accent); }

/* ===========================================
   Entry content (generic pages / posts)
   =========================================== */
.page-body { padding: clamp(48px, 8vw, 90px) 0; }
.entry-content { font-size: 15px; line-height: 2.2; }
.entry-content > * + * { margin-top: 1.5em; }
.entry-content h2 { font-size: clamp(19px,3.4vw,24px); letter-spacing: var(--ls-wide); margin-top: 2em; padding-bottom: .5em; border-bottom: 1px solid var(--color-line); }
.entry-content h3 { font-size: clamp(17px,3vw,20px); margin-top: 1.8em; color: var(--color-accent); letter-spacing: .12em; }
.entry-content a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.entry-content img { border-radius: 4px; }
.entry-content ul li { list-style: disc; margin-left: 1.4em; }
.entry-content ol li { list-style: decimal; margin-left: 1.4em; }
.entry-content blockquote { margin: 1.6em 0; padding: 14px 22px; border-left: 2px solid var(--color-accent); background: var(--color-cream); }
.single-meta { margin-bottom: 16px; font-family: var(--font-en); letter-spacing: .1em; color: var(--color-accent); }
.single-thumb { margin: 0 0 30px; border-radius: 4px; overflow: hidden; }

/* News list */
.news-list { max-width: var(--max-w-narrow); margin: 0 auto; border-top: 1px solid var(--color-line); }
.news-list__item { border-bottom: 1px solid var(--color-line); }
.news-list__link { display: flex; flex-direction: column; gap: 4px; padding: 20px 4px; }
.news-list__link:hover { color: var(--color-accent); }
.news-list__date { font-family: var(--font-en); letter-spacing: .1em; color: var(--color-accent); }
@media (min-width: 600px){
  .news-list__link { flex-direction: row; align-items: baseline; gap: 28px; }
  .news-list__date { flex-shrink: 0; width: 110px; }
}

/* Pagination */
.pagination, .page-links { display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; margin-top: 48px; }
.pagination .page-numbers, .page-links a, .page-links > span {
  min-width: 42px; height: 42px; padding: 0 12px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-line); border-radius: 4px;
  font-family: var(--font-en); letter-spacing: .05em;
}
.pagination .page-numbers.current { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.pagination a.page-numbers:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* Search form */
.search-box { margin: 0 auto 36px; max-width: 460px; }
.search-form { display: flex; gap: 8px; }
.search-form .search-field { flex: 1; padding: 12px 16px; border: 1px solid var(--color-line); border-radius: 4px; font: inherit; }
.search-form .search-submit { padding: 0 22px; background: var(--color-accent); color: #fff; border-radius: 4px; }

/* ===========================================
   Reveal on scroll
   =========================================== */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 1s ease, transform 1s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1; transform: none; transition: none; } }

/* ===========================================
   Responsive
   =========================================== */
@media (max-width: 600px){
  body { line-height: 2; }
  .swatch-grid { grid-template-columns: repeat(2, 1fr); }
  .detail-grid { grid-template-columns: 1fr; }
  .book-grid { grid-template-columns: 1fr; }
}

/* Front page (home): center everything on mobile */
@media (max-width: 820px){
  .home .service__body,
  .home .media-block__body { text-align: center; }
  .home .service__body .btn-circle,
  .home .media-block__body .btn-circle { justify-content: center; }
}

/* Front hero: nudge the photo up ~25px on desktop */
@media (min-width: 768px){
  .hero__bg { background-position: center calc(50% - 25px); }
}
