/* ============================================================
   components.css — Component-level styles for Pho Dang website.
   Tokens come from colors_and_type.css via site.css.
   ============================================================ */

/* ---------- HEADER ---------- */
.site-header {
  position: sticky; top: 0; left: 0; right: 0;
  z-index: 50;
  background: rgba(251, 247, 239, 0.86);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: box-shadow var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out);
}
.site-header.is-scrolled {
  background: rgba(251, 247, 239, 0.95);
  box-shadow: 0 1px 0 var(--border), 0 12px 24px -16px rgba(45,26,16,0.18);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px; padding: 14px 24px;
}
.site-header__brand { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.site-header__wordmark { display: flex; flex-direction: column; line-height: 1; }
.site-header__name {
  font-family: var(--font-display); font-style: italic; font-weight: 600;
  font-size: 22px; color: var(--color-cocoa-900);
}
.site-header__sub {
  font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--color-cocoa-600); margin-top: 4px; font-weight: 600;
}
.site-header__nav { display: flex; gap: 28px; flex: 1; justify-content: center; }
.site-header__nav a {
  font-size: 14px; font-weight: 500; color: var(--color-ink-700);
  padding: 6px 0; position: relative;
  transition: color var(--dur-quick) var(--ease-out);
}
.site-header__nav a:hover { color: var(--color-cocoa-900); }
.site-header__nav a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: var(--color-saffron-600);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--dur-quick) var(--ease-out);
}
.site-header__nav a:hover::after { transform: scaleX(1); }
.site-header__actions { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.site-header__phone {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 13px; color: var(--color-cocoa-800);
  white-space: nowrap;
}
.site-header__phone i { width: 16px; height: 16px; }
.site-header__burger {
  display: none; background: none; border: none; padding: 6px; cursor: pointer;
  color: var(--color-cocoa-900);
}
.site-header__mobile {
  display: none; flex-direction: column; gap: 12px;
  padding: 16px 24px 24px; border-top: 1px solid var(--border);
}
.site-header__mobile a { padding: 10px 0; color: var(--color-cocoa-900); font-size: 16px; }

@media (max-width: 920px) {
  .site-header__nav, .site-header__phone { display: none; }
  .site-header__burger { display: block; }
  .site-header__mobile { display: flex; }
  .site-header__sub { display: none; }
}

/* ---------- HERO ---------- */
.hero {
  position: relative; overflow: hidden; padding: 88px 0 96px;
  background: var(--color-cocoa-900);
  color: var(--color-paper-50);
}
.hero__bg { position: absolute; inset: 0; }
.hero__vignette {
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 80% 20%, rgba(212,160,74,0.18), transparent 70%),
    radial-gradient(80% 70% at 20% 100%, rgba(74,42,24,0.6), transparent 60%),
    linear-gradient(180deg, var(--color-cocoa-900) 0%, var(--color-cocoa-800) 100%);
}
.hero__grid {
  position: absolute; inset: 0; opacity: 0.07;
  background-image: radial-gradient(circle, #e8be6a 1px, transparent 1.5px);
  background-size: 24px 24px;
}
.hero__inner {
  position: relative; display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px; align-items: center;
}
.hero__copy { position: relative; }
.hero__badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 14px 7px 10px; border-radius: 999px;
  background: rgba(232, 190, 106, 0.10);
  border: 1px solid var(--border-on-dark);
  font-size: 12px; letter-spacing: 0.06em;
  color: var(--color-saffron-500);
  margin-bottom: 28px;
}
.hero__dot {
  width: 8px; height: 8px; border-radius: 999px; background: var(--color-pho-500);
  box-shadow: 0 0 0 4px rgba(138,166,106,0.25);
}
.hero__dot--closed {
  background: var(--color-chili-600);
  box-shadow: 0 0 0 4px rgba(200,68,49,0.28);
}
.hero__title {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(44px, 5.5vw, 76px);
  line-height: 1.02; letter-spacing: -0.02em;
  color: var(--color-paper-50);
  margin: 0 0 22px; text-wrap: balance;
}
.hero__title em { color: var(--color-saffron-500); font-weight: 500; }
.hero__lead {
  font-size: 18px; line-height: 1.6; color: var(--color-paper-200);
  max-width: 540px; margin: 0 0 32px;
}
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }
.hero__cta i { width: 16px; height: 16px; }
.hero__meta {
  display: grid; grid-template-columns: repeat(3, max-content); gap: 24px;
  padding-top: 22px; border-top: 1px solid var(--border-on-dark);
}
.hero__meta > div,
.hero__meta > a { display: flex; flex-direction: column; gap: 4px; text-decoration: none; color: inherit; }
.hero__meta > a:hover .hero__meta-value { opacity: 0.75; }
.hero__meta-label {
  font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--color-saffron-500); font-weight: 600;
}
.hero__meta-value { font-size: 14px; color: var(--color-paper-100); white-space: nowrap; }
.hero__meta-value.mono { font-family: var(--font-mono); }
.hero__meta > div a { text-decoration: none; color: inherit; }
.hero__meta > div a:hover { opacity: 0.75; }

.hero__art {
  position: relative;
  aspect-ratio: 4 / 5;
  display: flex; align-items: center; justify-content: center;
}
.hero__photo {
  position: relative; width: 100%; height: 100%;
  border-radius: var(--radius-lg); overflow: visible;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.6), 0 0 0 6px rgba(255,255,255,0.06);
}
.hero__photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  border-radius: var(--radius-lg);
}
.hero__photo-stamp {
  position: absolute; bottom: 20px; right: -28px;
  width: 88px; height: 88px; border-radius: 999px;
  background: var(--color-cocoa-900);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px -6px rgba(0,0,0,0.55);
  border: 3px solid var(--color-saffron-400);
  padding: 10px;
}
.hero__quote {
  position: absolute; left: -40px; bottom: 96px; max-width: 260px;
  padding: 16px 20px; background: var(--color-saffron-400);
  color: var(--color-cocoa-900); border-radius: 12px;
  font-family: var(--font-display); font-style: italic; font-size: 15px;
  line-height: 1.45; box-shadow: 0 20px 40px -12px rgba(0,0,0,0.5);
  transform: rotate(-1.5deg);
}
.hero__quote-mark { font-size: 26px; margin-right: 3px; vertical-align: -4px; }

@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; gap: 48px; }
  .hero__art { aspect-ratio: 4 / 3; max-width: 480px; margin: 0 auto; width: 100%; }
  .hero__quote { left: 0; bottom: 20px; }
  .hero__meta { grid-template-columns: 1fr 1fr; }
}

/* ---------- PILLARS ---------- */
.pillars { padding: 88px 0 32px; background: var(--bg); }
.pillars__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.pillars__item {
  padding: 28px 24px;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  border-radius: var(--radius-md);
  transition: box-shadow var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.pillars__item:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-saffron-400);
}
.pillars__icon {
  width: 44px; height: 44px; border-radius: 999px;
  background: var(--color-cocoa-800); color: var(--color-saffron-500);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.pillars__icon i { width: 22px; height: 22px; }
.pillars__title {
  font-family: var(--font-display); font-size: 22px; font-weight: 600;
  margin: 0 0 8px; color: var(--color-cocoa-900);
}
.pillars__body { font-size: 14px; line-height: 1.55; color: var(--color-ink-500); margin: 0; }
@media (max-width: 900px) { .pillars__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .pillars__grid { grid-template-columns: 1fr; } }

/* ---------- ABOUT ---------- */
.about { background: var(--color-paper-100); padding: 96px 0; }
.about__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.about__art { position: relative; }
.about__art img {
  width: 100%; height: auto; border-radius: var(--radius-lg); display: block;
  box-shadow: var(--shadow-lg);
}
.about__chip {
  position: absolute; bottom: 18px; left: 18px;
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px; background: var(--color-paper-50);
  border-radius: 999px; font-size: 13px; font-weight: 600;
  color: var(--color-cocoa-800);
  box-shadow: var(--shadow-md);
}
.about__chip i { width: 16px; height: 16px; color: var(--color-saffron-700); }
.about__pills {
  display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px;
}
.about__pills span {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 999px;
  background: var(--color-paper-50); border: 1px solid var(--border);
  font-size: 13px; color: var(--color-ink-700);
}
.about__pills i { width: 16px; height: 16px; color: var(--color-pho-600); }
@media (max-width: 900px) { .about__grid { grid-template-columns: 1fr; gap: 40px; } }

/* ---------- MENU ---------- */
.menu { background: var(--bg); }
.menu__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 24px; margin-bottom: 32px;
}
.menu__chips {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 40px;
  padding-bottom: 24px; border-bottom: 1px dashed var(--border-strong);
}
.menu__chip {
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  padding: 9px 18px; border-radius: 999px;
  background: var(--color-paper-100); color: var(--color-ink-700);
  border: 1px solid transparent; cursor: pointer;
  transition: all var(--dur-quick) var(--ease-out);
}
.menu__chip:hover { background: var(--color-paper-200); }
.menu__chip.is-active {
  background: var(--color-cocoa-800); color: var(--color-saffron-400);
}
.menu__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px 32px;
}
.dish {
  padding: 22px 0; border-bottom: 1px dashed var(--border-strong);
}
.dish__head { display: flex; gap: 16px; justify-content: space-between; align-items: baseline; }
.dish__name {
  font-family: var(--font-display); font-size: 20px; font-weight: 600;
  color: var(--color-cocoa-900); line-height: 1.2;
}
.dish__vi {
  display: inline-block; margin-left: 10px;
  font-size: 13px; font-style: italic; color: var(--fg-muted); font-weight: 400;
}
.dish__price {
  font-family: var(--font-mono); font-size: 18px; font-weight: 500;
  color: var(--color-cocoa-900); white-space: nowrap;
}
.dish__desc { font-size: 14px; line-height: 1.5; color: var(--color-ink-500); margin: 6px 0 10px; }
.dish__tags { display: flex; gap: 6px; flex-wrap: wrap; }
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; padding: 3px 10px; border-radius: 999px;
}
.tag--spicy { background: rgba(200,68,49,0.10); color: var(--color-chili-700); }
.tag--veg   { background: rgba(107,138,79,0.14); color: var(--color-pho-700); }
.tag--house { background: var(--color-saffron-400); color: var(--color-cocoa-900); }
.tag--fisch { background: rgba(58,113,159,0.10); color: #2c6ca0; }
.menu__cat-section { margin-bottom: 48px; }
.menu__cat-header {
  font-family: var(--font-body); font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-saffron-600);
  padding: 14px 0 16px; margin: 0;
  border-top: 2px solid var(--color-saffron-200);
}
.menu__expand {
  margin-top: 40px; padding-top: 28px;
  border-top: 1px dashed var(--border-strong);
  display: flex; justify-content: center;
}
.menu__count { font-size: 12px; opacity: 0.55; margin-left: 6px; }
@media (max-width: 720px) { .menu__grid { grid-template-columns: 1fr; gap: 0; } }

/* PDF viewer */
.menu__pdf-actions {
  display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px;
}
.menu__pdf-viewer {
  border-radius: var(--radius-md); overflow: hidden;
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
  background: #f4f4f4;
}
.menu__pdf-viewer object {
  display: block; width: 100%; height: 900px; border: none;
}
.menu__pdf-fallback {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 280px; gap: 20px; text-align: center; padding: 32px;
  color: var(--color-ink-600); font-size: 15px;
}
@media (max-width: 700px) {
  .menu__pdf-viewer object { height: 560px; }
  .menu__pdf-fallback { height: 200px; }
}

/* ---------- REVIEWS ---------- */
@keyframes review-reveal {
  from { opacity: 0; filter: blur(16px); transform: translateY(14px); }
  to   { opacity: 1; filter: blur(0);    transform: translateY(0); }
}

.reviews { background: var(--color-paper-100); }
.reviews__head { text-align: center; margin-bottom: 48px; }
.reviews__head .section-title { margin-left: auto; margin-right: auto; }
.reviews__rating {
  display: inline-flex; align-items: baseline; gap: 10px; margin-top: 8px;
}
.reviews__stars { color: var(--color-saffron-600); font-size: 18px; letter-spacing: 2px; }
.reviews__num { font-family: var(--font-display); font-size: 22px; font-weight: 600; color: var(--color-cocoa-900); }
.reviews__count { font-size: 13px; color: var(--fg-muted); }
.reviews__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  align-items: stretch;
}
.review {
  position: relative; background: var(--bg-elevated);
  padding: 24px 24px 22px 96px; border-radius: var(--radius-md);
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
  margin: 0; overflow: hidden; display: flex; flex-direction: column;
}
.review--reveal {
  animation: review-reveal 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.review--reveal:nth-child(1) { animation-delay: 0ms; }
.review--reveal:nth-child(2) { animation-delay: 110ms; }
.review--reveal:nth-child(3) { animation-delay: 220ms; }

.review__quote {
  position: absolute; top: 6px; left: 18px;
  font-family: var(--font-display); font-size: 120px; line-height: 1;
  color: var(--color-saffron-400); font-style: italic;
  opacity: 0.7; pointer-events: none;
}
.review__stars { position: relative; color: var(--color-saffron-600); letter-spacing: 2px; margin-bottom: 12px; }
.review__text { position: relative; }
.review__by { position: relative; }
.review__text {
  font-family: var(--font-display); font-style: italic;
  font-size: 15px; line-height: 1.55; color: var(--color-cocoa-900);
  margin: 0 0 16px; text-wrap: pretty; flex: 1;
}
.review__by { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.review__avatar {
  width: 36px; height: 36px; border-radius: 999px; flex-shrink: 0;
  background: var(--color-cocoa-800); color: var(--color-saffron-400);
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px;
}
.review__name { font-size: 13px; font-weight: 600; color: var(--color-ink-900); }
.review__source { font-size: 11px; color: var(--fg-muted); }

.reviews__controls {
  display: flex; align-items: center; justify-content: center;
  gap: 20px; margin-top: 44px;
}
.reviews__arrow {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1.5px solid var(--border); background: var(--bg);
  cursor: pointer; font-size: 18px; line-height: 1;
  color: var(--color-cocoa-700); transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
  display: flex; align-items: center; justify-content: center; padding: 0;
}
.reviews__arrow:hover {
  border-color: var(--color-saffron-400);
  color: var(--color-saffron-700);
  background: var(--color-saffron-50, #fffbeb);
}
.reviews__dots { display: flex; align-items: center; gap: 8px; }
.reviews__dot {
  width: 8px; height: 8px; border-radius: 50%;
  border: none; padding: 0; cursor: pointer;
  background: var(--border-strong); transition: background 240ms ease, transform 240ms ease;
}
.reviews__dot--active {
  background: var(--color-saffron-500); transform: scale(1.5);
}

@media (max-width: 900px) {
  .reviews__grid { grid-template-columns: 1fr; }
  .review--reveal:nth-child(2) { animation-delay: 0ms; }
  .review--reveal:nth-child(3) { animation-delay: 0ms; }
}

/* ---------- HOURS ---------- */
.hours {
  background: var(--color-cocoa-900);
  color: var(--color-paper-100);
  padding: 96px 0;
  background-image:
    radial-gradient(circle at 12% 88%, rgba(212,160,74,0.10), transparent 50%),
    radial-gradient(circle at 88% 12%, rgba(107,138,79,0.10), transparent 50%);
}
.hours__grid { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 56px; }
.hours__title {
  font-family: var(--font-display); font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 600; line-height: 1.1; letter-spacing: -0.02em;
  margin: 10px 0 18px; color: var(--color-paper-50);
}
.hours__lead { font-size: 15px; line-height: 1.6; color: var(--color-paper-300); max-width: 360px; }
.hours__status {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 14px; border-radius: 999px;
  background: rgba(138,166,106,0.16); border: 1px solid rgba(138,166,106,0.32);
  font-size: 12px; letter-spacing: 0.06em; color: var(--color-pho-300);
  margin-bottom: 18px;
}
.hours__dot {
  width: 8px; height: 8px; border-radius: 999px; background: var(--color-pho-500);
  box-shadow: 0 0 0 4px rgba(138,166,106,0.25);
}
.hours__dot--closed {
  background: var(--color-chili-600);
  box-shadow: 0 0 0 4px rgba(200,68,49,0.28);
}
.hours__status--closed {
  background: rgba(200,68,49,0.12);
  border-color: rgba(200,68,49,0.28);
  color: var(--color-chili-500);
}
.hours__table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 15px; }
.hours__table th {
  text-align: left; padding: 10px 0; font-weight: 400;
  color: var(--color-paper-300); border-bottom: 1px solid var(--border-on-dark);
}
.hours__table td {
  text-align: right; padding: 10px 0; color: var(--color-saffron-500);
  border-bottom: 1px solid var(--border-on-dark);
}
.hours__contact { display: flex; flex-direction: column; gap: 20px; }
.hours__phone-group {
  display: flex; flex-direction: column; gap: 4px;
}
.hours__row { display: flex; gap: 14px; align-items: flex-start; text-decoration: none; color: inherit; border-radius: var(--radius-md); transition: opacity var(--motion-fast) ease; }
a.hours__row:hover { opacity: 0.75; }
.hours__row i {
  width: 36px; height: 36px; padding: 8px; flex: none;
  border-radius: 999px; background: rgba(212,160,74,0.14); color: var(--color-saffron-500);
}
.hours__strong { font-size: 15px; color: var(--color-paper-50); }
.hours__strong.mono { font-family: var(--font-mono); white-space: nowrap; }
.hours__muted { font-size: 12px; color: var(--color-paper-300); margin-top: 2px; }
@media (max-width: 900px) { .hours__grid { grid-template-columns: 1fr; gap: 40px; } }

/* ---------- FOOTER ---------- */
.footer {
  background: var(--color-paper-100);
  border-top: 1px solid var(--border);
  padding: 32px 0;
}
.footer__inner {
  display: grid; grid-template-columns: auto 1fr auto; gap: 32px;
  align-items: center;
}
.footer__brand { display: flex; align-items: center; gap: 12px; }
.footer__name { font-family: var(--font-display); font-style: italic; font-weight: 600; font-size: 18px; color: var(--color-cocoa-900); }
.footer__sub { font-size: 11px; color: var(--fg-muted); letter-spacing: 0.06em; }
.footer__links { display: flex; gap: 22px; flex-wrap: wrap; justify-content: center; }
.footer__links a { font-size: 13px; color: var(--color-ink-700); }
.footer__links a:hover { color: var(--color-cocoa-900); text-decoration: underline; text-decoration-color: var(--accent); }
.footer__legal { font-size: 11px; color: var(--fg-muted); text-align: right; }
@media (max-width: 900px) {
  .footer__inner { grid-template-columns: 1fr; text-align: center; }
  .footer__legal { text-align: center; }
  .footer__brand { justify-content: center; }
}

/* ---------- FLOATING CTA ---------- */
.float-reserve {
  position: fixed; right: 22px; bottom: 22px; z-index: 40;
  display: none; align-items: center; gap: 8px;
  padding: 14px 22px; border-radius: 999px; border: none;
  background: var(--color-saffron-600); color: var(--color-cocoa-900);
  font-weight: 600; font-size: 14px; cursor: pointer;
  box-shadow: 0 16px 28px -12px rgba(45,26,16,0.45);
}
.float-reserve i { width: 18px; height: 18px; }
@media (max-width: 920px) { .float-reserve { display: inline-flex; } }

/* ---------- RESERVE MODAL ---------- */
.modal__scrim {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(31, 18, 10, 0.55); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; overflow-y: auto;
  animation: scrimIn 220ms cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes scrimIn { from { opacity: 0; } to { opacity: 1; } }
.modal {
  position: relative;
  width: 100%; max-width: 520px;
  background: var(--bg);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-lg);
  animation: modalIn 280ms cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes modalIn { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.modal__close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: none; padding: 8px; cursor: pointer;
  color: var(--color-ink-500); border-radius: 999px;
  transition: background var(--dur-quick) var(--ease-out);
}
.modal__close:hover { background: var(--color-paper-200); color: var(--color-cocoa-900); }
.modal__close i { width: 20px; height: 20px; }
.modal__brand { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.modal__title { font-family: var(--font-display); font-size: 24px; font-weight: 600; color: var(--color-cocoa-900); line-height: 1.1; }
.modal__sub { font-size: 13px; color: var(--fg-muted); margin-top: 2px; }
.modal__group { margin-bottom: 22px; }
.modal__label {
  display: block; font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: var(--color-ink-700); margin-bottom: 10px;
}
.modal__pills { display: flex; gap: 8px; flex-wrap: wrap; }
.modal__pill {
  font-family: var(--font-mono); font-size: 14px; font-weight: 500;
  padding: 10px 16px; border-radius: 999px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  color: var(--color-cocoa-900); cursor: pointer;
  transition: all var(--dur-quick) var(--ease-out);
}
.modal__pill:hover { border-color: var(--color-saffron-600); }
.modal__pill.is-active {
  background: var(--color-cocoa-800); border-color: var(--color-cocoa-800);
  color: var(--color-saffron-400);
}
.modal__days { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.modal__day {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 10px 6px; border-radius: var(--radius-sm);
  background: var(--bg-elevated); border: 1px solid var(--border);
  cursor: pointer; transition: all var(--dur-quick) var(--ease-out);
}
.modal__day:hover { border-color: var(--color-saffron-600); }
.modal__day.is-active { background: var(--color-cocoa-800); border-color: var(--color-cocoa-800); color: var(--color-saffron-400); }
.modal__day-wk { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.7; }
.modal__day-n { font-family: var(--font-mono); font-size: 14px; font-weight: 500; }
.modal input {
  width: 100%; font-family: var(--font-body); font-size: 15px;
  padding: 13px 16px; border-radius: var(--radius-sm);
  background: var(--bg-elevated); border: 1px solid var(--border);
  color: var(--color-cocoa-900);
  transition: border-color var(--dur-quick) var(--ease-out),
              box-shadow var(--dur-quick) var(--ease-out);
}
.modal input:focus {
  outline: none; border-color: var(--color-saffron-600);
  box-shadow: 0 0 0 3px rgba(212,160,74,0.18);
}
.modal__summary {
  display: flex; gap: 24px; flex-wrap: wrap;
  background: var(--color-paper-100);
  padding: 14px 18px; border-radius: var(--radius-sm);
  margin-bottom: 22px;
}
.modal__summary span { font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--fg-muted); display: block; margin-bottom: 3px; }
.modal__summary strong { font-family: var(--font-mono); font-size: 14px; color: var(--color-cocoa-900); font-weight: 500; }
.modal__note {
  display: flex; gap: 10px; align-items: center;
  font-size: 13px; color: var(--color-ink-500);
  background: rgba(212,160,74,0.10);
  padding: 12px 14px; border-radius: var(--radius-sm); margin-bottom: 24px;
}
.modal__note i { color: var(--color-saffron-700); width: 18px; height: 18px; flex: none; }
.modal__note a { color: var(--color-cocoa-900); text-decoration: underline; text-decoration-color: var(--accent); }
.modal__actions { display: flex; gap: 12px; justify-content: flex-end; flex-wrap: wrap; }
.modal__actions .btn:disabled { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
.modal__done { text-align: center; padding: 12px 0; }
.modal__done-icon {
  width: 64px; height: 64px; border-radius: 999px;
  background: var(--color-pho-600); color: var(--color-paper-50);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.modal__done-icon i { width: 32px; height: 32px; }
.modal__done-title { font-family: var(--font-display); font-size: 26px; font-weight: 600; color: var(--color-cocoa-900); margin-bottom: 12px; }
.modal__done-text { font-size: 15px; line-height: 1.55; color: var(--color-ink-700); margin-bottom: 22px; }
