:root {
  --ink: #2d2926;
  --muted: #75695f;
  --paper: #fff8ef;
  --paper-strong: #fffdf8;
  --coral: #ee7f6c;
  --persimmon: #d95f42;
  --honey: #f7bf57;
  --matcha: #5d8a72;
  --sea: #4f95a5;
  --sky: #9ccfd8;
  --line: rgba(94, 70, 51, 0.16);
  --shadow: 0 22px 80px rgba(132, 73, 32, 0.18);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family:
    "Noto Sans TC",
    "Microsoft JhengHei",
    system-ui,
    sans-serif;
  background:
    radial-gradient(circle at 12% 12%, rgba(92, 141, 167, 0.16), transparent 28rem),
    radial-gradient(circle at 86% 18%, rgba(214, 95, 66, 0.1), transparent 24rem),
    linear-gradient(135deg, #f6f2e9 0%, #eef5f1 48%, #edf1f8 100%);
}

button,
select {
  font: inherit;
}

.shell {
  width: min(1440px, 100%);
  margin: 0 auto;
  padding: 24px;
}

.hero {
  position: relative;
  min-height: clamp(360px, 48vh, 560px);
  overflow: hidden;
  border-radius: 8px;
  box-shadow: var(--shadow);
  isolation: isolate;
}

.hero__image,
.hero__shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero__image {
  object-fit: cover;
  opacity: 1;
  filter: none;
}

.hero__shade {
  background:
    linear-gradient(90deg, rgba(52, 37, 28, 0.68), rgba(80, 49, 28, 0.24) 48%, rgba(255, 244, 224, 0.02)),
    linear-gradient(0deg, rgba(36, 28, 23, 0.3), transparent 56%);
  z-index: 2;
}

.hero-scene {
  display: none;
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  background:
    radial-gradient(circle at 76% 18%, rgba(255, 248, 210, 0.92) 0 4.4rem, transparent 4.5rem),
    linear-gradient(180deg, rgba(255, 213, 139, 0.98) 0%, rgba(238, 127, 108, 0.6) 58%, rgba(105, 164, 150, 0.92) 100%);
}

.hero-scene::before {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  bottom: -21%;
  height: 46%;
  border-radius: 50% 50% 0 0;
  background:
    linear-gradient(180deg, rgba(96, 140, 109, 0.96), rgba(62, 111, 103, 0.96));
}

.hero-scene::after {
  content: "";
  position: absolute;
  left: 28%;
  right: 10%;
  bottom: 12%;
  height: 16%;
  border-radius: 999px;
  background: rgba(255, 248, 239, 0.42);
  box-shadow: 0 28px 0 rgba(255, 248, 239, 0.24);
}

.hero-scene .sun {
  top: 44px;
  right: min(14vw, 190px);
  width: clamp(84px, 9vw, 140px);
  height: clamp(84px, 9vw, 140px);
  background: rgba(255, 252, 226, 0.88);
  box-shadow:
    0 0 0 clamp(24px, 4vw, 56px) rgba(255, 236, 173, 0.22),
    0 18px 70px rgba(186, 90, 42, 0.22);
}

.hero-scene .cloud {
  height: clamp(18px, 2vw, 28px);
  background: rgba(255, 253, 248, 0.78);
}

.hero-scene .cloud.one {
  top: 21%;
  left: 43%;
  width: clamp(82px, 11vw, 170px);
}

.hero-scene .cloud.two {
  top: 34%;
  right: 21%;
  width: clamp(70px, 8vw, 130px);
}

.hero-scene .cloud.three {
  top: 15%;
  left: 61%;
  width: clamp(52px, 7vw, 104px);
}

.hero-scene .landmark {
  bottom: 16%;
  left: 70%;
  transform: translateX(-50%) scale(1.65);
  transform-origin: bottom center;
}

.hero-scene .landmark.side {
  left: 52%;
  transform: translateX(-50%) scale(1.45);
}

.hero-scene.artwork-hakodate .landmark.main,
.hero-scene.artwork-sapporo .landmark.main,
.hero-scene.artwork-furano .landmark.main {
  width: clamp(300px, 30vw, 520px);
  height: clamp(150px, 16vw, 250px);
  transform: translateX(-50%);
  background: linear-gradient(180deg, #fff9ea 0 20%, #8eb6bf 20% 100%);
  clip-path: polygon(4% 82%, 18% 60%, 28% 34%, 40% 54%, 52% 12%, 64% 52%, 78% 30%, 96% 82%, 96% 100%, 4% 100%);
}

.hero-scene.artwork-hakodate .landmark.side {
  width: clamp(180px, 18vw, 300px);
  height: 64px;
  bottom: 13%;
  left: 75%;
  border-radius: 999px 999px 0 0;
  transform: translateX(-50%);
  background: linear-gradient(90deg, #f8d79a, #e36d55, #4f95a5);
  clip-path: none;
}

.hero-scene.artwork-tokyo .landmark.main {
  transform: translateX(-50%) scale(2);
}

.hero-scene.artwork-yokohama .landmark.main {
  transform: translateX(-50%) scale(1.78);
}

.hero-scene.artwork-fuji .landmark.main,
.hero-scene.artwork-aso .landmark.main,
.hero-scene.artwork-kagoshima .landmark.main {
  left: 69%;
  transform: translateX(-50%) scale(1.55);
}

.hero-scene.artwork-okinawa,
.hero-scene.artwork-ishigaki {
  background:
    radial-gradient(circle at 76% 18%, rgba(255, 248, 210, 0.92) 0 4.4rem, transparent 4.5rem),
    linear-gradient(180deg, rgba(255, 216, 138, 0.98) 0%, rgba(238, 127, 108, 0.5) 46%, rgba(71, 157, 165, 0.95) 100%);
}

.hero-scene.artwork-okinawa::before,
.hero-scene.artwork-ishigaki::before {
  background: linear-gradient(180deg, rgba(245, 217, 147, 0.96), rgba(94, 151, 128, 0.96));
}

.hero__content {
  position: relative;
  z-index: 3;
  width: min(680px, 100%);
  min-height: inherit;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(32px, 7vw, 96px);
  color: #fffaf3;
}

.eyebrow {
  margin: 0 0 12px;
  color: #ffe0aa;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
p {
  margin-top: 0;
}

h1 {
  max-width: 8em;
  margin-bottom: 16px;
  font-size: clamp(2.45rem, 6vw, 5.8rem);
  line-height: 1.02;
  letter-spacing: 0;
}

html[lang="zh-Hant"] .hero h1,
html[lang="ja"] .hero h1 {
  max-width: 7.2em;
  font-size: clamp(3rem, 7.2vw, 6.7rem);
}

.hero__copy {
  width: min(30rem, 100%);
  margin-bottom: 18px;
  color: rgba(255, 250, 243, 0.9);
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.8;
}

.hero__destination {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 10px 14px;
  border: 1px solid rgba(255, 250, 243, 0.34);
  border-radius: 999px;
  color: #fff8ea;
  background: rgba(77, 49, 34, 0.28);
  backdrop-filter: blur(10px);
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.4;
}

.windbell {
  position: absolute;
  z-index: 4;
  top: 34px;
  right: clamp(28px, 7vw, 96px);
  width: 72px;
  height: 128px;
  border-top: 3px solid rgba(255, 250, 243, 0.78);
}

.windbell::before {
  content: "";
  position: absolute;
  left: 50%;
  width: 2px;
  height: 28px;
  background: rgba(255, 250, 243, 0.76);
}

.windbell span {
  position: absolute;
  top: 24px;
  left: 14px;
  width: 44px;
  height: 40px;
  border: 2px solid rgba(255, 250, 243, 0.86);
  border-bottom-width: 6px;
  border-radius: 22px 22px 12px 12px;
  background: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(8px);
}

.windbell i {
  position: absolute;
  top: 62px;
  left: 34px;
  width: 2px;
  height: 64px;
  background: rgba(255, 250, 243, 0.76);
}

.windbell i::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: -13px;
  width: 28px;
  height: 38px;
  border-radius: 4px;
  background: linear-gradient(180deg, #f8c56b, #ec7d62);
  box-shadow: 0 10px 20px rgba(78, 42, 24, 0.18);
}

.planner {
  display: grid;
  grid-template-columns: minmax(260px, 330px) 1fr;
  gap: 20px;
  margin-top: 20px;
  align-items: start;
}

.selector-panel,
.forecast-view {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 253, 248, 0.82);
  box-shadow: 0 18px 50px rgba(132, 73, 32, 0.1);
  backdrop-filter: blur(16px);
}

.selector-panel {
  position: sticky;
  top: 20px;
  padding: 20px;
}

.panel-title,
.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.panel-title {
  margin-bottom: 22px;
}

.language-switch {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(94, 70, 51, 0.12);
}

.language-switch > span {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
}

.language-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.language-button {
  min-height: 38px;
  border: 1px solid rgba(94, 70, 51, 0.16);
  border-radius: 999px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.7);
  font-size: 0.88rem;
  font-weight: 900;
  cursor: pointer;
}

.language-button.is-active {
  color: #fffaf3;
  border-color: transparent;
  background: linear-gradient(135deg, var(--persimmon), #e58d55);
  box-shadow: 0 10px 20px rgba(199, 76, 60, 0.18);
}

.panel-title span,
.toolbar p,
.place-summary p {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
}

.panel-title strong {
  color: var(--persimmon);
  font-size: 1.35rem;
}

.field {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

label {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 800;
}

select {
  width: 100%;
  min-height: 48px;
  padding: 0 42px 0 14px;
  border: 1px solid rgba(94, 70, 51, 0.2);
  border-radius: 8px;
  color: var(--ink);
  background:
    linear-gradient(45deg, transparent 50%, var(--persimmon) 50%) calc(100% - 20px) 20px / 8px 8px no-repeat,
    linear-gradient(135deg, var(--persimmon) 50%, transparent 50%) calc(100% - 14px) 20px / 8px 8px no-repeat,
    #fffaf3;
  appearance: none;
}

.quick-regions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.region-button {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(94, 70, 51, 0.16);
  border-radius: 999px;
  color: var(--muted);
  background: #fff7ed;
  cursor: pointer;
}

.region-button.is-active {
  color: #fffaf3;
  border-color: transparent;
  background: linear-gradient(135deg, var(--persimmon), #e58d55);
}

.forecast-view {
  overflow: hidden;
}

.place-banner {
  display: grid;
  grid-template-columns: minmax(260px, 42%) 1fr auto;
  gap: 24px;
  align-items: stretch;
  padding: 20px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(110deg, rgba(255, 245, 231, 0.94), rgba(229, 244, 240, 0.66)),
    #fffaf3;
}

.artwork {
  position: relative;
  min-height: 260px;
  overflow: hidden;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 224, 170, 0.9), rgba(246, 150, 104, 0.48) 58%, rgba(109, 162, 156, 0.72)),
    #f5c171;
}

.place-thumbnail {
  display: block;
  width: 100%;
  min-height: 260px;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 16px 34px rgba(45, 41, 38, 0.12);
}

.artwork::before {
  content: "";
  position: absolute;
  inset: auto -6% -14% -6%;
  height: 40%;
  border-radius: 50% 50% 0 0;
  background: rgba(93, 138, 114, 0.72);
}

.artwork::after {
  content: "";
  position: absolute;
  inset: auto 8% 11% 8%;
  height: 14%;
  border-radius: 999px;
  background: rgba(255, 248, 239, 0.48);
}

.sun {
  position: absolute;
  top: 22px;
  right: 32px;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 251, 224, 0.86);
  box-shadow: 0 0 0 18px rgba(255, 236, 173, 0.22);
}

.cloud {
  position: absolute;
  height: 18px;
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.72);
}

.cloud.one {
  top: 56px;
  left: 36px;
  width: 82px;
}

.cloud.two {
  top: 92px;
  right: 86px;
  width: 54px;
}

.landmark {
  position: absolute;
  z-index: 1;
  bottom: 48px;
  left: 50%;
  transform: translateX(-50%);
}

.landmark.main {
  width: 72px;
  height: 142px;
  background: linear-gradient(180deg, #fff4db 0 24%, #d95f42 24% 33%, #fff4db 33% 58%, #d95f42 58% 68%, #fff4db 68%);
  clip-path: polygon(47% 0, 53% 0, 60% 32%, 78% 100%, 22% 100%, 40% 32%);
  box-shadow: 0 10px 0 rgba(45, 41, 38, 0.08);
}

.landmark.side {
  width: 122px;
  height: 62px;
  left: 26%;
  bottom: 48px;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(180deg, #f7e0ba 0 24%, #6d8f83 24% 34%, #fff3d5 34%);
}

.artwork-yokohama .landmark.main {
  width: 138px;
  height: 102px;
  border-radius: 50% 50% 10px 10px;
  background: conic-gradient(from 0deg, #fff2d3, #ee7f6c, #fff2d3, #5d8a72, #fff2d3);
  clip-path: none;
}

.artwork-yokohama .landmark.side {
  width: 58px;
  height: 130px;
  left: 34%;
  background: #4f95a5;
  border-radius: 6px 6px 0 0;
}

.artwork-nikko .landmark.main,
.artwork-kyoto .landmark.main,
.artwork-miyajima .landmark.main {
  width: 180px;
  height: 108px;
  background: linear-gradient(180deg, #cf4d37 0 26%, transparent 26% 46%, #cf4d37 46% 58%, #cf4d37 58%);
  clip-path: polygon(0 0, 100% 0, 88% 20%, 58% 20%, 58% 100%, 42% 100%, 42% 20%, 12% 20%);
}

.artwork-fuji .landmark.main {
  width: 260px;
  height: 138px;
  background: linear-gradient(180deg, #fffaf3 0 22%, #77a2a4 22% 100%);
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.artwork-kanazawa .landmark.main,
.artwork-kurashiki .landmark.main {
  width: 220px;
  height: 88px;
  border-radius: 0;
  background: linear-gradient(90deg, #f7e2bd 0 22%, #2f5d59 22% 26%, #f7e2bd 26% 52%, #2f5d59 52% 56%, #f7e2bd 56%);
  clip-path: polygon(0 20%, 12% 0, 88% 0, 100% 20%, 100% 100%, 0 100%);
}

.artwork-takayama .landmark.main,
.artwork-matsuyama .landmark.main,
.artwork-osaka .landmark.main {
  width: 166px;
  height: 128px;
  background: linear-gradient(180deg, #446b67 0 18%, #fff1d0 18% 38%, #446b67 38% 46%, #fff1d0 46%);
  clip-path: polygon(50% 0, 88% 20%, 78% 24%, 82% 100%, 18% 100%, 22% 24%, 12% 20%);
}

.artwork-nara .landmark.main {
  width: 178px;
  height: 92px;
  border-radius: 50% 50% 18px 18px;
  background: linear-gradient(180deg, #b67355, #7a8f6f);
  clip-path: polygon(0 48%, 24% 42%, 32% 16%, 44% 40%, 100% 48%, 88% 100%, 8% 100%);
}

.artwork-sapporo .landmark.main,
.artwork-furano .landmark.main,
.artwork-hakodate .landmark.main {
  width: 240px;
  height: 122px;
  background: linear-gradient(180deg, #fff9ea 0 28%, #8eb6bf 28% 100%);
  clip-path: polygon(12% 44%, 32% 8%, 48% 44%, 62% 16%, 92% 82%, 8% 82%);
}

.artwork-aso .landmark.main,
.artwork-kagoshima .landmark.main {
  width: 250px;
  height: 130px;
  border-radius: 50% 50% 0 0;
  background: linear-gradient(180deg, #7b7860 0 34%, #6f9a6e 34%);
  clip-path: polygon(0 100%, 20% 32%, 43% 24%, 58% 4%, 72% 30%, 100% 100%);
}

.artwork-aso .landmark.main::after,
.artwork-kagoshima .landmark.main::after {
  content: "";
  position: absolute;
  top: -28px;
  left: 52%;
  width: 72px;
  height: 36px;
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.72);
}

.artwork-sendai .landmark.main,
.artwork-aomori .landmark.main,
.artwork-akita .landmark.main {
  width: 220px;
  height: 102px;
  border-radius: 50% 50% 0 0;
  background: linear-gradient(180deg, #f6b25e, #6b9a7b);
  clip-path: polygon(0 100%, 18% 42%, 34% 58%, 52% 16%, 72% 52%, 100% 100%);
}

.artwork-hiroshima .landmark.main {
  width: 140px;
  height: 128px;
  background: linear-gradient(180deg, #fff0d2 0 38%, #5d8a72 38%);
  clip-path: polygon(50% 0, 68% 38%, 94% 38%, 74% 56%, 82% 100%, 18% 100%, 26% 56%, 6% 38%, 32% 38%);
}

.artwork-fukuoka .landmark.main,
.artwork-nagasaki .landmark.main {
  width: 230px;
  height: 112px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(180deg, #fff1d0 0 34%, #4f95a5 34%);
  clip-path: polygon(4% 100%, 18% 56%, 38% 30%, 54% 48%, 72% 18%, 96% 100%);
}

.artwork-okinawa .landmark.main,
.artwork-ishigaki .landmark.main {
  width: 220px;
  height: 96px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(180deg, #fff5d9 0 36%, #4f95a5 36% 70%, #d95f42 70%);
  clip-path: polygon(0 100%, 10% 56%, 30% 58%, 46% 18%, 62% 58%, 86% 50%, 100% 100%);
}

.motif {
  display: none;
  position: absolute;
  z-index: 2;
}

.artwork::before,
.artwork::after,
.hero-scene::before,
.hero-scene::after,
.landmark,
.motif {
  transition: background 260ms ease, box-shadow 260ms ease, transform 260ms ease;
}

.artwork-tokyo,
.hero-scene.artwork-tokyo {
  background:
    linear-gradient(180deg, #71b9d8 0%, #f0d86f 50%, #da5543 100%);
}

.artwork-tokyo::before,
.hero-scene.artwork-tokyo::before {
  background: linear-gradient(180deg, rgba(52, 83, 113, 0.92), rgba(39, 58, 84, 0.98));
}

.artwork-yokohama,
.hero-scene.artwork-yokohama {
  background: linear-gradient(180deg, #69c2d0 0%, #f4d56f 54%, #1f7795 100%);
}

.artwork-yokohama::before,
.hero-scene.artwork-yokohama::before {
  background: linear-gradient(180deg, rgba(37, 133, 156, 0.86), rgba(20, 86, 115, 0.96));
}

.artwork-fuji,
.hero-scene.artwork-fuji {
  background:
    linear-gradient(180deg, #7ec8e8 0%, #eaf7ff 42%, #2e8bc5 100%);
}

.artwork-fuji::before,
.hero-scene.artwork-fuji::before {
  background:
    linear-gradient(180deg, rgba(61, 146, 196, 0.9), rgba(24, 93, 146, 0.96));
}

.artwork-fuji::after,
.hero-scene.artwork-fuji::after {
  background:
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.44) 0 4px, rgba(255, 255, 255, 0.1) 4px 16px);
  box-shadow: none;
}

.artwork-fuji .landmark.main,
.hero-scene.artwork-fuji .landmark.main {
  background:
    linear-gradient(180deg, #ffffff 0 20%, #dbeeff 20% 31%, #496f99 31% 100%);
}

.artwork-fuji .motif,
.hero-scene.artwork-fuji .motif {
  display: block;
  left: 10%;
  bottom: 18%;
  width: 28%;
  height: 12%;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.46);
  box-shadow:
    42px 18px 0 rgba(255, 255, 255, 0.28),
    96px 4px 0 rgba(255, 255, 255, 0.22);
}

.artwork-kyoto,
.hero-scene.artwork-kyoto,
.artwork-nikko,
.hero-scene.artwork-nikko {
  background: linear-gradient(180deg, #f0c35a 0%, #d8523c 52%, #345f4f 100%);
}

.artwork-kyoto::before,
.hero-scene.artwork-kyoto::before,
.artwork-nikko::before,
.hero-scene.artwork-nikko::before {
  background: linear-gradient(180deg, rgba(75, 107, 69, 0.94), rgba(32, 75, 64, 0.98));
}

.artwork-nara,
.hero-scene.artwork-nara {
  background: linear-gradient(180deg, #a9d7b2 0%, #f4d186 48%, #427957 100%);
}

.artwork-nara::before,
.hero-scene.artwork-nara::before {
  background: linear-gradient(180deg, rgba(66, 137, 78, 0.92), rgba(48, 100, 64, 0.98));
}

.artwork-nara .landmark.main,
.hero-scene.artwork-nara .landmark.main {
  width: 210px;
  height: 102px;
  border-radius: 0;
  background: linear-gradient(180deg, #5f3425 0 28%, #b27a4e 28% 48%, #fff1cc 48%);
  clip-path: polygon(0 26%, 14% 0, 86% 0, 100% 26%, 88% 34%, 88% 100%, 12% 100%, 12% 34%);
}

.artwork-nara .motif,
.hero-scene.artwork-nara .motif {
  display: block;
  left: 17%;
  bottom: 24%;
  width: 70px;
  height: 44px;
  border-radius: 54% 46% 44% 50%;
  background: #9a5a35;
  box-shadow: 0 12px 0 rgba(58, 75, 52, 0.18);
}

.artwork-nara .motif::before,
.hero-scene.artwork-nara .motif::before {
  content: "";
  position: absolute;
  right: -24px;
  top: -13px;
  width: 34px;
  height: 30px;
  border-radius: 50%;
  background: #9a5a35;
  box-shadow:
    -48px 42px 0 -12px #704027,
    -16px 42px 0 -12px #704027,
    6px 40px 0 -12px #704027;
}

.artwork-nara .motif::after,
.hero-scene.artwork-nara .motif::after {
  content: "";
  position: absolute;
  right: -20px;
  top: -31px;
  width: 36px;
  height: 22px;
  border-left: 4px solid #5a3324;
  border-right: 4px solid #5a3324;
  border-radius: 50% 50% 0 0;
}

.hero-scene.artwork-nara .motif {
  left: 58%;
  bottom: 18%;
  transform: scale(1.85);
}

.artwork-hakodate,
.hero-scene.artwork-hakodate {
  background:
    radial-gradient(circle at 72% 22%, rgba(246, 239, 183, 0.9) 0 7%, transparent 7.5%),
    linear-gradient(180deg, #142447 0%, #235d7a 54%, #0b314b 100%);
}

.artwork-hakodate::before,
.hero-scene.artwork-hakodate::before {
  background: linear-gradient(180deg, rgba(31, 74, 80, 0.96), rgba(6, 45, 52, 0.98));
}

.artwork-hakodate::after,
.hero-scene.artwork-hakodate::after {
  background:
    radial-gradient(circle, #ffd86b 0 2px, transparent 3px) 0 0 / 26px 18px,
    rgba(255, 255, 255, 0.18);
  box-shadow: 0 18px 0 rgba(255, 216, 107, 0.16);
}

.artwork-hakodate .landmark.main,
.hero-scene.artwork-hakodate .landmark.main {
  background: linear-gradient(180deg, #d7ecf6 0 18%, #4d8ca6 18% 100%);
}

.artwork-sapporo,
.hero-scene.artwork-sapporo {
  background: linear-gradient(180deg, #d8f0ff 0%, #eff8ff 46%, #7aa8bc 100%);
}

.artwork-furano,
.hero-scene.artwork-furano {
  background:
    repeating-linear-gradient(90deg, rgba(126, 88, 161, 0.44) 0 18px, rgba(237, 133, 169, 0.42) 18px 36px, rgba(246, 213, 88, 0.38) 36px 54px),
    linear-gradient(180deg, #a6d6f3 0%, #f7ed8b 52%, #6ea36b 100%);
}

.artwork-aso,
.hero-scene.artwork-aso,
.artwork-kagoshima,
.hero-scene.artwork-kagoshima {
  background:
    radial-gradient(circle at 64% 12%, rgba(255, 102, 38, 0.64) 0 5%, transparent 8%),
    linear-gradient(180deg, #4b4b47 0%, #e46b35 44%, #335c43 100%);
}

.artwork-aso::before,
.hero-scene.artwork-aso::before,
.artwork-kagoshima::before,
.hero-scene.artwork-kagoshima::before {
  background: linear-gradient(180deg, rgba(43, 44, 41, 0.98), rgba(52, 91, 61, 0.98));
}

.artwork-aso .landmark.main,
.hero-scene.artwork-aso .landmark.main,
.artwork-kagoshima .landmark.main,
.hero-scene.artwork-kagoshima .landmark.main {
  background: linear-gradient(180deg, #2e2d2b 0 26%, #e96b35 26% 34%, #6f9a6e 34%);
}

.artwork-aso .landmark.main::after,
.hero-scene.artwork-aso .landmark.main::after,
.artwork-kagoshima .landmark.main::after,
.hero-scene.artwork-kagoshima .landmark.main::after {
  background: rgba(54, 52, 51, 0.7);
  box-shadow: 28px -14px 0 rgba(54, 52, 51, 0.32), 62px 4px 0 rgba(54, 52, 51, 0.22);
}

.artwork-okinawa,
.hero-scene.artwork-okinawa,
.artwork-ishigaki,
.hero-scene.artwork-ishigaki {
  background:
    linear-gradient(180deg, #40c7d4 0%, #7ce3db 46%, #f3d178 100%);
}

.artwork-okinawa::before,
.hero-scene.artwork-okinawa::before,
.artwork-ishigaki::before,
.hero-scene.artwork-ishigaki::before {
  background: linear-gradient(180deg, rgba(255, 237, 165, 0.94), rgba(32, 151, 143, 0.96));
}

.artwork-okinawa::after,
.hero-scene.artwork-okinawa::after,
.artwork-ishigaki::after,
.hero-scene.artwork-ishigaki::after {
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.32) 0 16px, rgba(255, 255, 255, 0.08) 16px 36px);
  box-shadow: 0 18px 0 rgba(255, 255, 255, 0.2);
}

.artwork-okinawa .landmark.main,
.hero-scene.artwork-okinawa .landmark.main,
.artwork-ishigaki .landmark.main,
.hero-scene.artwork-ishigaki .landmark.main {
  background: linear-gradient(180deg, #fff5d9 0 32%, #12aeb9 32% 68%, #d74232 68%);
}

.hero-scene.artwork-fuji .landmark.main,
.hero-scene.artwork-aso .landmark.main,
.hero-scene.artwork-kagoshima .landmark.main,
.hero-scene.artwork-okinawa .landmark.main,
.hero-scene.artwork-ishigaki .landmark.main {
  transform: translateX(-50%) scale(1.9);
}

.place-summary {
  align-self: center;
}

.place-summary h2 {
  margin: 8px 0 8px;
  font-size: clamp(2rem, 5vw, 4.5rem);
  line-height: 1;
  letter-spacing: 0;
}

.place-summary span {
  display: inline-flex;
  max-width: 100%;
  color: var(--persimmon);
  font-weight: 800;
}

.current-chip {
  align-self: start;
  display: grid;
  gap: 6px;
  min-width: 136px;
  padding: 16px;
  border-radius: 8px;
  color: #fffaf3;
  background: linear-gradient(135deg, var(--matcha), var(--sea));
}

.current-chip span {
  font-size: 0.86rem;
  font-weight: 800;
}

.current-chip strong {
  font-size: 2rem;
  line-height: 1;
}

.current-chip small {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
}

.live-cameras {
  display: grid;
  gap: 16px;
  padding: 20px;
  border-bottom: 1px solid var(--line);
  background: rgba(255, 253, 248, 0.92);
}

.live-cameras__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}

.live-cameras__head p {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 900;
}

.live-cameras__head h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.35rem, 2.5vw, 2rem);
  line-height: 1.15;
}

.live-cameras__head > span {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  color: #fffaf3;
  background: #c74c3c;
  font-size: 0.78rem;
  font-weight: 900;
}

.live-cameras__grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.live-camera-link {
  display: grid;
  gap: 8px;
  min-height: 86px;
  padding: 14px;
  border: 1px solid rgba(94, 70, 51, 0.14);
  border-radius: 8px;
  color: var(--ink);
  background: linear-gradient(180deg, #fffdf8, #f7efe4);
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(45, 41, 38, 0.06);
}

.live-camera-link:hover {
  border-color: rgba(199, 76, 60, 0.38);
  transform: translateY(-1px);
}

.live-camera-link span {
  font-weight: 900;
  line-height: 1.35;
}

.live-camera-link strong {
  color: #c74c3c;
  font-size: 0.78rem;
}

.local-specialties {
  display: grid;
  gap: 16px;
  padding: 20px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(255, 246, 232, 0.88)),
    #fffdf8;
}

.local-specialties__head p {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 900;
}

.local-specialties__head h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.35rem, 2.5vw, 2rem);
  line-height: 1.15;
}

.specialty-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.specialty-card {
  display: grid;
  gap: 8px;
  min-height: 150px;
  padding: 16px;
  border: 1px solid rgba(94, 70, 51, 0.14);
  border-radius: 8px;
  background: #fffaf1;
  box-shadow: 0 12px 26px rgba(45, 41, 38, 0.06);
}

.specialty-card span {
  width: fit-content;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  color: #fffaf3;
  background: var(--matcha);
  font-size: 0.78rem;
  font-weight: 900;
}

.specialty-card strong {
  color: var(--ink);
  font-size: 1.15rem;
  line-height: 1.3;
}

.specialty-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.65;
}

.outfit-summary {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(360px, 1.1fr);
  gap: 24px;
  align-items: center;
  padding: 24px 20px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.92), rgba(230, 241, 245, 0.82)),
    #fffdf8;
}

.outfit-copy {
  display: grid;
  gap: 12px;
}

.outfit-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 900;
}

.outfit-copy h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.8rem, 4vw, 3.2rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.outfit-copy span {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.75;
}

.outfit-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.outfit-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  color: #fffaf3;
  background: linear-gradient(135deg, var(--matcha), var(--sea));
  font-size: 0.86rem;
  font-weight: 900;
}

.outfit-visual {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 84%, rgba(79, 149, 165, 0.18) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #f2fbff 0%, #fff5df 100%);
}

.outfit-visual::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 28px;
  height: 18px;
  border-radius: 999px;
  background: rgba(45, 41, 38, 0.08);
}

.character {
  position: absolute;
  bottom: 46px;
  width: 86px;
  height: 184px;
}

.character-girl {
  left: 36%;
  transform: translateX(-50%);
}

.character-boy {
  left: 56%;
  transform: translateX(-50%);
}

.character span {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.character .head {
  z-index: 3;
  top: 8px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #f2c69b;
  box-shadow:
    inset -8px -8px 0 rgba(158, 88, 56, 0.12),
    0 12px 24px rgba(45, 41, 38, 0.08);
}

.character .head::before {
  content: "";
  position: absolute;
  top: 24px;
  left: 14px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #5a3324;
  box-shadow: 18px 0 0 #5a3324;
}

.character .head::after {
  content: "";
  position: absolute;
  left: 19px;
  bottom: 11px;
  width: 14px;
  height: 7px;
  border-bottom: 3px solid #b75d54;
  border-radius: 50%;
}

.character .hair {
  z-index: 2;
  top: 0;
  width: 58px;
  height: 42px;
  border-radius: 34px 34px 16px 16px;
  background: #50352a;
}

.character-girl .hair {
  width: 66px;
  height: 64px;
  border-radius: 38px 38px 24px 24px;
}

.character .body {
  z-index: 1;
  top: 68px;
  width: 70px;
  height: 80px;
  border-radius: 22px 22px 12px 12px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.26) 0 24%, transparent 24% 76%, rgba(255, 255, 255, 0.2) 76%),
    var(--outfit-body, #4f95a5);
  box-shadow:
    -32px 10px 0 -23px #f2c69b,
    32px 10px 0 -23px #f2c69b;
}

.character-girl .body {
  --outfit-body: #e36d7d;
  clip-path: polygon(18% 0, 82% 0, 100% 100%, 0 100%);
}

.character-boy .body {
  --outfit-body: #4f95a5;
}

.outfit-visual.is-cold {
  background:
    radial-gradient(circle at 50% 84%, rgba(81, 118, 160, 0.18) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #eaf6ff 0%, #f9fbff 100%);
}

.outfit-visual.is-cold .character-girl .body {
  --outfit-body: #7b89b9;
}

.outfit-visual.is-cold .character-boy .body {
  --outfit-body: #426f8f;
}

.outfit-visual.is-mild {
  background:
    radial-gradient(circle at 50% 84%, rgba(93, 138, 114, 0.16) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #eff8ed 0%, #fff8e8 100%);
}

.outfit-visual.is-mild .character-girl .body {
  --outfit-body: #d96d78;
}

.outfit-visual.is-mild .character-boy .body {
  --outfit-body: #5d8a72;
}

.outfit-visual.is-hot {
  background:
    radial-gradient(circle at 50% 84%, rgba(18, 174, 185, 0.16) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #e5fbff 0%, #fff0c8 100%);
}

.outfit-visual.is-hot .character-girl .body {
  --outfit-body: #ef7c5d;
}

.outfit-visual.is-hot .character-boy .body {
  --outfit-body: #12aeb9;
}

.character .legs {
  top: 148px;
  width: 70px;
  height: 34px;
  background:
    linear-gradient(90deg, #344c66 0 42%, transparent 42% 58%, #344c66 58% 100%);
}

.character-girl .legs {
  background:
    linear-gradient(90deg, #5b4d6d 0 42%, transparent 42% 58%, #5b4d6d 58% 100%);
}

.outfit-piece {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 42px;
  padding: 8px 12px;
  border: 2px solid rgba(45, 41, 38, 0.16);
  border-radius: 999px;
  color: var(--ink);
  background: rgba(255, 253, 248, 0.94);
  box-shadow: 0 14px 30px rgba(45, 41, 38, 0.1);
  font-size: 0.9rem;
  font-weight: 900;
  line-height: 1.25;
  text-align: center;
}

.outfit-piece::after {
  content: "";
  position: absolute;
  width: 46px;
  height: 2px;
  background: rgba(45, 41, 38, 0.18);
}

.piece-outer {
  top: 32px;
  left: 8%;
  background: #eaf4ff;
}

.piece-outer::after {
  right: -40px;
  top: 28px;
  transform: rotate(18deg);
}

.piece-top {
  top: 74px;
  right: 8%;
  background: #fff0c9;
}

.piece-top::after {
  left: -42px;
  top: 28px;
  transform: rotate(-16deg);
}

.piece-bottom {
  left: 11%;
  bottom: 82px;
  background: #e8f1df;
}

.piece-bottom::after {
  right: -42px;
  top: 20px;
  transform: rotate(-10deg);
}

.piece-shoes {
  right: 12%;
  bottom: 58px;
  background: #f4e5ff;
}

.piece-shoes::after {
  left: -44px;
  top: 18px;
  transform: rotate(8deg);
}

.piece-accessory {
  top: 28px;
  left: 50%;
  transform: translateX(-50%);
  background: #ffe3df;
}

.piece-accessory::after {
  left: 50%;
  top: 40px;
  width: 2px;
  height: 42px;
}

.outfit-visual {
  min-height: 420px;
  border: 1px solid rgba(45, 41, 38, 0.1);
  background:
    radial-gradient(circle at 18px 18px, rgba(45, 41, 38, 0.055) 0 2px, transparent 2.5px) 0 0 / 28px 28px,
    linear-gradient(180deg, #f8fbff 0%, #fff4df 100%);
}

.outfit-visual.is-cold {
  background:
    radial-gradient(circle at 18px 18px, rgba(44, 85, 132, 0.07) 0 2px, transparent 2.5px) 0 0 / 28px 28px,
    linear-gradient(180deg, #eaf6ff 0%, #f9fbff 100%);
}

.outfit-visual.is-mild {
  background:
    radial-gradient(circle at 18px 18px, rgba(74, 116, 83, 0.065) 0 2px, transparent 2.5px) 0 0 / 28px 28px,
    linear-gradient(180deg, #eff8ed 0%, #fff8e8 100%);
}

.outfit-visual.is-hot {
  background:
    radial-gradient(circle at 18px 18px, rgba(18, 130, 150, 0.065) 0 2px, transparent 2.5px) 0 0 / 28px 28px,
    linear-gradient(180deg, #e5fbff 0%, #fff0c8 100%);
}

.outfit-visual::before {
  left: 18%;
  right: 18%;
  bottom: 34px;
  height: 20px;
  z-index: 1;
}

.outfit-characters {
  position: absolute;
  z-index: 2;
  left: 50%;
  bottom: 22px;
  width: min(56%, 430px);
  max-height: 86%;
  object-fit: contain;
  transform: translateX(-50%);
  pointer-events: none;
  filter: drop-shadow(0 18px 18px rgba(45, 41, 38, 0.16));
}

.outfit-visual .character {
  display: none;
}

.character {
  bottom: 58px;
  width: 112px;
  height: 230px;
  filter: drop-shadow(0 12px 10px rgba(45, 41, 38, 0.12));
}

.character-girl {
  left: 41%;
}

.character-boy {
  left: 58%;
}

.character .head {
  z-index: 4;
  top: 22px;
  width: 66px;
  height: 68px;
  border: 3px solid #4a3028;
  background: #ffd7b2;
}

.character .head::before {
  top: 29px;
  left: 17px;
  width: 9px;
  height: 14px;
  border-radius: 50%;
  background: #35231f;
  box-shadow:
    22px 0 0 #35231f,
    3px 3px 0 -2px #ffffff,
    25px 3px 0 -2px #ffffff;
}

.character .head::after {
  left: 24px;
  bottom: 14px;
  width: 18px;
  height: 9px;
  border-bottom: 3px solid #c86f6b;
}

.character .hair {
  z-index: 5;
  top: 8px;
  width: 72px;
  height: 48px;
  border: 3px solid #4a3028;
  border-bottom: 0;
  background: #473024;
  clip-path: polygon(6% 14%, 24% 0, 52% 8%, 76% 0, 96% 24%, 88% 74%, 64% 56%, 50% 82%, 34% 56%, 12% 76%);
}

.character-girl .hair {
  z-index: 3;
  width: 84px;
  height: 82px;
  border-radius: 46px 46px 28px 28px;
  clip-path: polygon(8% 20%, 24% 4%, 50% 0, 78% 8%, 94% 28%, 88% 96%, 70% 88%, 70% 42%, 58% 22%, 50% 36%, 42% 22%, 30% 42%, 30% 88%, 12% 96%);
}

.character .body {
  z-index: 2;
  top: 96px;
  width: 82px;
  height: 98px;
  border: 3px solid #4a3028;
  border-radius: 24px 24px 16px 16px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.32) 0 22%, transparent 22% 78%, rgba(255, 255, 255, 0.2) 78%),
    var(--outfit-body, #4f95a5);
  box-shadow:
    -42px 20px 0 -31px #ffd7b2,
    42px 20px 0 -31px #ffd7b2;
}

.character .body::before {
  content: "";
  position: absolute;
  top: -2px;
  left: 50%;
  width: 42px;
  height: 34px;
  transform: translateX(-50%);
  background: #fff8ef;
  clip-path: polygon(0 0, 50% 62%, 100% 0, 100% 38%, 50% 100%, 0 38%);
}

.character .body::after {
  content: "";
  position: absolute;
  right: -17px;
  top: 42px;
  width: 24px;
  height: 34px;
  border: 3px solid #4a3028;
  border-radius: 7px;
  background: #f1c66a;
}

.character-girl .body {
  border-radius: 22px 22px 12px 12px;
  clip-path: polygon(16% 0, 84% 0, 100% 100%, 0 100%);
}

.character .legs {
  z-index: 1;
  top: 191px;
  width: 82px;
  height: 42px;
  border-bottom: 6px solid #4a3028;
  background:
    linear-gradient(90deg, #344c66 0 42%, transparent 42% 58%, #344c66 58% 100%);
}

.outfit-piece {
  z-index: 4;
  display: grid;
  grid-template-columns: 78px minmax(56px, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 150px;
  min-height: 92px;
  padding: 8px 12px 8px 8px;
  border: 3px solid #594238;
  border-radius: 8px;
  background: rgba(255, 253, 248, 0.96);
  box-shadow: 0 16px 28px rgba(45, 41, 38, 0.12);
}

.outfit-piece b {
  font-size: 0.9rem;
  line-height: 1.35;
}

.piece-art {
  position: relative;
  display: block;
  width: 74px;
  height: 74px;
}

.piece-art::before,
.piece-art::after {
  content: "";
  position: absolute;
}

.piece-outer .piece-art::before {
  left: 16px;
  top: 6px;
  width: 40px;
  height: 64px;
  border: 3px solid #594238;
  border-radius: 10px 10px 6px 6px;
  background: #f0cf72;
  clip-path: polygon(18% 0, 40% 10%, 50% 24%, 60% 10%, 82% 0, 100% 100%, 0 100%);
}

.piece-outer .piece-art::after {
  left: 18px;
  top: 9px;
  width: 36px;
  height: 24px;
  border-left: 3px solid #594238;
  border-right: 3px solid #594238;
  clip-path: polygon(0 0, 50% 76%, 100% 0, 100% 28%, 50% 100%, 0 28%);
}

.piece-top .piece-art::before {
  left: 8px;
  top: 14px;
  width: 58px;
  height: 52px;
  border: 3px solid #594238;
  border-radius: 12px 12px 7px 7px;
  background:
    linear-gradient(90deg, #d9f4f7 0 18%, #b99b78 18% 82%, #d9f4f7 82%);
  clip-path: polygon(22% 0, 39% 12%, 50% 32%, 61% 12%, 78% 0, 100% 22%, 88% 100%, 12% 100%, 0 22%);
}

.piece-top .piece-art::after {
  left: 28px;
  top: 15px;
  width: 16px;
  height: 18px;
  border-bottom: 3px solid #594238;
  border-radius: 0 0 16px 16px;
}

.piece-bottom .piece-art::before {
  left: 12px;
  top: 12px;
  width: 50px;
  height: 58px;
  border: 3px solid #594238;
  border-radius: 12px 12px 8px 8px;
  background: #b985c8;
  clip-path: polygon(30% 0, 70% 0, 100% 100%, 0 100%);
}

.piece-bottom .piece-art::after {
  left: 26px;
  top: 16px;
  width: 22px;
  height: 16px;
  border-top: 8px solid #d9444a;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
}

.piece-shoes .piece-art::before {
  left: 6px;
  bottom: 14px;
  width: 30px;
  height: 18px;
  border: 3px solid #594238;
  border-radius: 12px 12px 8px 8px;
  background: #6e8eb1;
  box-shadow: 33px 0 0 -3px #6e8eb1, 33px 0 0 0 #594238;
}

.piece-shoes .piece-art::after {
  left: 10px;
  bottom: 7px;
  width: 60px;
  height: 8px;
  border-radius: 999px;
  background: #594238;
}

.piece-accessory .piece-art::before {
  left: 12px;
  top: 12px;
  width: 50px;
  height: 42px;
  border: 3px solid #594238;
  border-radius: 50% 50% 8px 8px;
  background: #f2e0df;
  clip-path: polygon(50% 0, 100% 28%, 86% 100%, 14% 100%, 0 28%);
}

.piece-accessory .piece-art::after {
  left: 24px;
  top: 36px;
  width: 28px;
  height: 26px;
  border: 3px solid #594238;
  border-radius: 6px;
  background: #8ab5ba;
}

.piece-outer {
  top: 24px;
  left: 4%;
}

.piece-top {
  top: 34px;
  right: 4%;
}

.piece-bottom {
  left: 4%;
  bottom: 88px;
}

.piece-shoes {
  right: 5%;
  bottom: 78px;
}

.piece-accessory {
  top: 12px;
}

.piece-outer::after {
  right: -42px;
  top: 48px;
}

.piece-top::after {
  left: -42px;
  top: 48px;
}

.piece-bottom::after {
  right: -42px;
  top: 44px;
}

.piece-shoes::after {
  left: -42px;
  top: 44px;
}

.piece-accessory::after {
  top: 88px;
  height: 36px;
}

.toolbar {
  padding: 18px 20px;
}

.toolbar strong {
  color: var(--muted);
  font-size: 0.96rem;
}

.refresh-button {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  color: #fffaf3;
  background: var(--persimmon);
  cursor: pointer;
}

.refresh-button span {
  font-size: 1.45rem;
  line-height: 1;
}

.forecast-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(142px, 1fr));
  gap: 1px;
  background: var(--line);
}

.day-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 12px;
  min-height: 238px;
  padding: 18px;
  background: rgba(255, 253, 248, 0.94);
}

.day-card.is-today {
  background: #fff4e4;
}

.day-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 800;
}

.weather-icon {
  font-size: 2.25rem;
  line-height: 1;
}

.temp {
  display: flex;
  align-items: end;
  gap: 8px;
}

.temp strong {
  font-size: 2rem;
  line-height: 1;
}

.temp span {
  color: var(--muted);
  font-weight: 800;
}

.condition {
  color: var(--ink);
  font-weight: 900;
}

.metrics {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.45;
}

.loading,
.error {
  grid-column: 1 / -1;
  min-height: 220px;
  display: grid;
  place-items: center;
  padding: 32px;
  color: var(--muted);
  background: rgba(255, 253, 248, 0.94);
  text-align: center;
  line-height: 1.8;
}

.error {
  color: #9b3f30;
}

@media (max-width: 1040px) {
  .planner {
    grid-template-columns: 1fr;
  }

  .selector-panel {
    position: static;
  }

  .place-banner {
    grid-template-columns: 1fr;
  }

  .current-chip {
    width: 100%;
    grid-template-columns: 1fr auto;
    align-items: center;
  }

  .live-cameras__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .outfit-summary {
    grid-template-columns: 1fr;
  }

  .specialty-grid {
    grid-template-columns: 1fr;
  }

  .forecast-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .shell {
    padding: 12px;
  }

  .hero {
    min-height: 430px;
  }

  .hero__content {
    padding: 28px;
    justify-content: end;
  }

  .windbell {
    top: 20px;
    right: 24px;
    transform: scale(0.82);
    transform-origin: top right;
  }

  .place-banner,
  .selector-panel,
  .toolbar,
  .live-cameras,
  .local-specialties,
  .outfit-summary {
    padding: 16px;
  }

  .live-cameras__head {
    align-items: start;
    flex-direction: column;
  }

  .live-cameras__grid {
    grid-template-columns: 1fr;
  }

  .outfit-visual {
    min-height: 500px;
  }

  .outfit-characters {
    bottom: 28px;
    width: min(76%, 390px);
    max-height: 74%;
  }

  .character-girl {
    left: 39%;
  }

  .character-boy {
    left: 61%;
  }

  .outfit-piece {
    grid-template-columns: 62px minmax(46px, 1fr);
    gap: 6px;
    min-width: 136px;
    max-width: 156px;
    min-height: 84px;
    padding: 6px 9px 6px 6px;
  }

  .piece-art {
    width: 62px;
    height: 62px;
    transform: scale(0.84);
    transform-origin: center;
  }

  .outfit-piece b {
    font-size: 0.76rem;
  }

  .piece-outer {
    left: 4%;
    top: 18px;
  }

  .piece-top {
    right: 4%;
    top: 78px;
  }

  .piece-bottom {
    left: 4%;
    bottom: 118px;
  }

  .piece-shoes {
    right: 4%;
    bottom: 94px;
  }

  .piece-accessory {
    top: 12px;
    left: 54%;
  }

  .artwork {
    min-height: 220px;
  }

  .place-thumbnail {
    min-height: 220px;
  }

  .forecast-grid {
    grid-template-columns: 1fr;
  }

  .day-card {
    min-height: auto;
  }
}

/* Floating hand-drawn outfit items, kept separate from the character art. */
.outfit-piece {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 108px;
  min-height: 116px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.outfit-piece::after {
  height: 2px;
  border-radius: 999px;
  background: rgba(89, 66, 56, 0.2);
}

.outfit-piece b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 9.5em;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  color: #4c3a31;
  background: rgba(255, 240, 201, 0.78);
  box-shadow: 0 8px 18px rgba(45, 41, 38, 0.08);
  font-size: 0.84rem;
  font-weight: 900;
  line-height: 1.35;
  text-align: center;
}

.piece-art {
  width: 96px;
  height: 96px;
  filter: drop-shadow(0 12px 12px rgba(45, 41, 38, 0.14));
}

.piece-outer .piece-art::before,
.piece-top .piece-art::before,
.piece-bottom .piece-art::before,
.piece-shoes .piece-art::before,
.piece-accessory .piece-art::before,
.piece-outer .piece-art::after,
.piece-top .piece-art::after,
.piece-bottom .piece-art::after,
.piece-shoes .piece-art::after,
.piece-accessory .piece-art::after {
  border-color: #7a6258;
}

.piece-outer .piece-art::before {
  left: 24px;
  top: 8px;
  width: 50px;
  height: 78px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), transparent 42%),
    #eecf6f;
}

.piece-outer .piece-art::after {
  left: 28px;
  top: 13px;
  width: 42px;
  height: 28px;
  border-color: rgba(122, 98, 88, 0.82);
}

.piece-top .piece-art::before {
  left: 8px;
  top: 20px;
  width: 76px;
  height: 62px;
  background:
    linear-gradient(90deg, #cdeff2 0 18%, #b99a78 18% 82%, #cdeff2 82%);
}

.piece-top .piece-art::after {
  left: 37px;
  top: 21px;
  width: 20px;
  height: 20px;
}

.piece-bottom .piece-art::before {
  left: 18px;
  top: 12px;
  width: 62px;
  height: 76px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16), transparent 36%),
    #b985c8;
}

.piece-bottom .piece-art::after {
  left: 32px;
  top: 17px;
  border-top-color: #d94f5f;
}

.piece-shoes .piece-art::before {
  left: 6px;
  bottom: 22px;
  width: 38px;
  height: 23px;
  background: #6e8eb1;
  box-shadow: 43px 0 0 -3px #6e8eb1, 43px 0 0 0 #7a6258;
}

.piece-shoes .piece-art::after {
  left: 10px;
  bottom: 14px;
  width: 78px;
  height: 9px;
  background: #7a6258;
}

.piece-accessory .piece-art::before {
  left: 14px;
  top: 12px;
  width: 62px;
  height: 52px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.32), transparent 42%),
    #f1d9df;
}

.piece-accessory .piece-art::after {
  left: 31px;
  top: 48px;
  width: 34px;
  height: 30px;
  background: #8ab5ba;
}

.piece-outer {
  top: 28px;
  left: 6%;
}

.piece-top {
  top: 36px;
  right: 6%;
}

.piece-accessory {
  top: 16px;
}

.piece-bottom {
  left: 7%;
  bottom: 74px;
}

.piece-shoes {
  right: 7%;
  bottom: 68px;
}

.piece-outer::after {
  right: -38px;
  top: 56px;
}

.piece-top::after {
  left: -38px;
  top: 58px;
}

.piece-accessory::after {
  top: 100px;
}

.piece-bottom::after {
  right: -36px;
  top: 48px;
}

.piece-shoes::after {
  left: -36px;
  top: 48px;
}

.piece-outer b {
  background: rgba(252, 225, 129, 0.82);
}

.piece-top b {
  background: rgba(200, 237, 240, 0.86);
}

.piece-bottom b {
  background: rgba(226, 202, 238, 0.86);
}

.piece-shoes b {
  background: rgba(202, 220, 239, 0.9);
}

.piece-accessory b {
  background: rgba(249, 218, 224, 0.9);
}

@media (max-width: 620px) {
  .outfit-piece {
    min-width: 92px;
    min-height: 104px;
  }

  .piece-art {
    width: 76px;
    height: 76px;
    transform: none;
  }

  .outfit-piece b {
    max-width: 7.6em;
    min-height: 28px;
    padding: 4px 8px;
    font-size: 0.74rem;
  }

  .piece-outer {
    left: 3%;
    top: 18px;
  }

  .piece-top {
    right: 3%;
    top: 78px;
  }

  .piece-accessory {
    top: 10px;
    left: 55%;
  }

  .piece-bottom {
    left: 3%;
    bottom: 106px;
  }

  .piece-shoes {
    right: 3%;
    bottom: 84px;
  }
}

/* Fashion notebook style outfit board inspired by hand-drawn travel notes. */
.outfit-visual {
  min-height: 560px;
  border: 1px solid rgba(112, 88, 64, 0.18);
  background:
    linear-gradient(rgba(116, 88, 58, 0.04) 1px, transparent 1px) 0 0 / 100% 34px,
    radial-gradient(circle at 16% 22%, rgba(196, 150, 87, 0.1), transparent 18rem),
    radial-gradient(circle at 82% 74%, rgba(150, 107, 65, 0.08), transparent 18rem),
    #f7edcf;
}

.outfit-visual.is-cold,
.outfit-visual.is-mild,
.outfit-visual.is-hot {
  background:
    linear-gradient(rgba(116, 88, 58, 0.04) 1px, transparent 1px) 0 0 / 100% 34px,
    radial-gradient(circle at 16% 22%, rgba(196, 150, 87, 0.1), transparent 18rem),
    radial-gradient(circle at 82% 74%, rgba(150, 107, 65, 0.08), transparent 18rem),
    #f7edcf;
}

.outfit-visual::before {
  left: 29%;
  right: 29%;
  bottom: 28px;
  height: 16px;
  background: rgba(91, 67, 45, 0.12);
  filter: blur(2px);
}

.outfit-characters {
  width: min(48%, 380px);
  max-height: 78%;
  bottom: 24px;
  filter:
    drop-shadow(0 18px 16px rgba(75, 55, 38, 0.16))
    saturate(0.96);
}

.outfit-piece {
  position: absolute;
  min-width: 132px;
  min-height: 174px;
  gap: 0;
  color: #4c3528;
  font-family: "Segoe Print", "Yu Gothic", "Microsoft JhengHei", cursive, sans-serif;
}

.outfit-piece::before {
  content: attr(data-note);
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  width: 124px;
  max-width: 11em;
  margin-top: -2px;
  color: #4d3528;
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1.12;
  text-align: center;
  transform: translateX(-50%) rotate(-2deg);
}

.outfit-piece::after {
  width: 78px;
  height: 2px;
  background: #4d3528;
  opacity: 0.55;
  transform-origin: center;
}

.outfit-piece b {
  position: absolute;
  left: 50%;
  bottom: 0;
  display: block;
  width: 124px;
  max-width: 9.5em;
  min-width: 104px;
  min-height: 0;
  margin-top: 2px;
  padding: 0;
  color: #5d3f2f;
  background: transparent;
  box-shadow: none;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.2;
  text-align: center;
  transform: translateX(-50%);
}

.piece-art {
  position: absolute;
  top: 34px;
  left: 50%;
  width: 118px;
  height: 118px;
  margin: 2px 0 4px;
  transform: translateX(-50%);
  filter:
    drop-shadow(3px 8px 6px rgba(76, 54, 36, 0.14))
    saturate(0.92);
}

.piece-art::before,
.piece-art::after {
  filter: none;
}

.piece-outer {
  top: 24px;
  left: 7%;
}

.piece-outer::after {
  right: -54px;
  top: 88px;
  transform: rotate(20deg);
}

.piece-top {
  top: 18px;
  right: 12%;
}

.piece-top::after {
  left: -58px;
  top: 88px;
  transform: rotate(-19deg);
}

.piece-accessory {
  top: 29%;
  right: 8%;
  left: auto;
}

.piece-accessory::after {
  left: -66px;
  top: 62px;
  width: 88px;
  height: 2px;
  transform: rotate(-11deg);
}

.piece-bottom {
  left: 7%;
  bottom: 92px;
}

.piece-bottom::after {
  right: -62px;
  top: 66px;
  transform: rotate(-12deg);
}

.piece-shoes {
  right: 12%;
  bottom: 28px;
}

.piece-shoes::after {
  left: -64px;
  top: 58px;
  width: 86px;
  transform: rotate(10deg);
}

.piece-outer .piece-art::before {
  left: 26px;
  top: 8px;
  width: 62px;
  height: 94px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 16px 16px 9px 9px;
  background:
    repeating-linear-gradient(90deg, rgba(124, 97, 64, 0.2) 0 2px, transparent 2px 8px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.28), transparent 42%),
    #ead171;
}

.piece-outer .piece-art::after {
  left: 36px;
  top: 16px;
  width: 42px;
  height: 22px;
  border: 2px solid rgba(89, 66, 56, 0.72);
  border-top: 0;
  border-radius: 0 0 18px 18px;
  background: transparent;
}

.piece-top .piece-art::before {
  left: 9px;
  top: 30px;
  width: 92px;
  height: 76px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 18px 18px 10px 10px;
  background:
    linear-gradient(90deg, #dceff0 0 20%, #bd9a75 20% 80%, #dceff0 80%),
    #bd9a75;
}

.piece-top .piece-art::after {
  left: 43px;
  top: 31px;
  width: 26px;
  height: 23px;
  border: 2px solid rgba(89, 66, 56, 0.72);
  border-top: 0;
  border-radius: 0 0 20px 20px;
  background: #f6e8d1;
}

.piece-bottom .piece-art::before {
  left: 23px;
  top: 14px;
  width: 72px;
  height: 96px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 12px 12px 9px 9px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), transparent 38%),
    #b486c6;
}

.piece-bottom .piece-art::after {
  left: 42px;
  top: 22px;
  width: 30px;
  height: 22px;
  border-top: 10px solid #c9485a;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
}

.piece-shoes .piece-art::before {
  left: 12px;
  bottom: 32px;
  width: 43px;
  height: 25px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 18px 18px 10px 10px;
  background: #8ea4bc;
  box-shadow:
    52px 0 0 -2px #8ea4bc,
    52px 0 0 0 rgba(89, 66, 56, 0.82);
}

.piece-shoes .piece-art::after {
  left: 12px;
  bottom: 23px;
  width: 100px;
  height: 9px;
  border: 0;
  border-radius: 999px;
  background: rgba(89, 66, 56, 0.82);
}

.piece-accessory .piece-art::before {
  left: 18px;
  top: 11px;
  width: 74px;
  height: 62px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 50% 50% 10px 10px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.34), transparent 42%),
    #efd9df;
}

.piece-accessory .piece-art::after {
  left: 36px;
  top: 60px;
  width: 42px;
  height: 35px;
  border: 2px solid rgba(89, 66, 56, 0.82);
  border-radius: 7px;
  background: #91b7ba;
}

@media (max-width: 620px) {
  .outfit-visual {
    min-height: 560px;
  }

  .outfit-characters {
    width: min(68%, 360px);
    max-height: 66%;
    bottom: 24px;
  }

  .outfit-piece {
    min-width: 94px;
    min-height: 126px;
  }

  .piece-art {
    width: 86px;
    height: 86px;
  }

  .outfit-piece::before {
    font-size: 0.68rem;
  }

  .outfit-piece b {
    font-size: 0.67rem;
  }

  .piece-outer {
    top: 12px;
    left: 3%;
  }

  .piece-top {
    top: 60px;
    right: 2%;
  }

  .piece-accessory {
    top: 218px;
    right: 1%;
    left: auto;
  }

  .piece-bottom {
    left: 2%;
    bottom: 116px;
  }

  .piece-shoes {
    right: 2%;
    bottom: 86px;
  }
}

/* Integrated outfit mode: assets are worn by the avatars, no side notes. */
.outfit-visual {
  min-height: 430px;
  border: 0;
  background:
    radial-gradient(circle at 50% 88%, rgba(79, 149, 165, 0.18) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #eef8fb 0%, #fff7e8 100%);
}

.outfit-visual.is-cold,
.outfit-visual.is-mild,
.outfit-visual.is-hot {
  background:
    radial-gradient(circle at 50% 88%, rgba(79, 149, 165, 0.18) 0 18%, transparent 18.5%),
    linear-gradient(180deg, #eef8fb 0%, #fff7e8 100%);
}

.outfit-visual::before {
  left: 18%;
  right: 18%;
  bottom: 34px;
  height: 20px;
  border-radius: 999px;
  background: rgba(45, 41, 38, 0.1);
  filter: blur(1px);
}

.outfit-piece,
.outfit-characters,
.outfit-visual .character {
  display: none;
}

.dressed-pair {
  position: absolute;
  inset: 24px 18px 30px;
  display: flex;
  align-items: end;
  justify-content: center;
  gap: clamp(22px, 7vw, 72px);
}

.dressed-avatar {
  position: relative;
  width: clamp(132px, 22vw, 190px);
  height: clamp(300px, 46vw, 370px);
  isolation: isolate;
}

.dressed-avatar::before {
  content: "";
  position: absolute;
  z-index: 1;
  left: 50%;
  top: 170px;
  width: 76px;
  height: 132px;
  transform: translateX(-50%);
  background:
    linear-gradient(90deg, #41566f 0 42%, transparent 42% 58%, #41566f 58% 100%);
  clip-path: polygon(8% 0, 92% 0, 86% 100%, 58% 100%, 50% 34%, 42% 100%, 14% 100%);
}

.dressed-avatar::after {
  content: "";
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 102px;
  width: 128px;
  height: 86px;
  transform: translateX(-50%);
  background:
    linear-gradient(90deg, #f1c8a1 0 16%, transparent 16% 84%, #f1c8a1 84% 100%);
  border-radius: 28px;
}

.dressed-avatar-women::before {
  background:
    linear-gradient(90deg, #5b4d6d 0 42%, transparent 42% 58%, #5b4d6d 58% 100%);
}

.avatar-shadow {
  position: absolute;
  z-index: 0;
  left: 8%;
  right: 8%;
  bottom: 0;
  height: 18px;
  border-radius: 999px;
  background: rgba(45, 41, 38, 0.12);
  filter: blur(2px);
}

.avatar-head,
.avatar-hair,
.avatar-neck {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.avatar-head {
  z-index: 7;
  top: 8px;
  width: 68px;
  height: 72px;
  border: 2.5px solid rgba(91, 71, 61, 0.92);
  border-radius: 48% 48% 46% 46%;
  background: #f7d2aa;
  box-shadow: inset -8px -8px 0 rgba(155, 94, 59, 0.12);
}

.avatar-head::before {
  content: "";
  position: absolute;
  top: 32px;
  left: 17px;
  width: 7px;
  height: 12px;
  border-radius: 999px;
  background: #4b332b;
  box-shadow: 24px 0 0 #4b332b;
}

.avatar-head::after {
  content: "";
  position: absolute;
  left: 26px;
  bottom: 14px;
  width: 16px;
  height: 8px;
  border-bottom: 2.5px solid #b7665d;
  border-radius: 50%;
}

.avatar-hair {
  z-index: 8;
  top: 0;
  width: 82px;
  height: 62px;
  border-radius: 42px 42px 24px 24px;
  background: #473126;
  clip-path: polygon(8% 22%, 25% 4%, 50% 0, 77% 6%, 94% 28%, 88% 68%, 64% 50%, 50% 76%, 36% 50%, 12% 70%);
}

.dressed-avatar-women .avatar-hair {
  width: 92px;
  height: 90px;
  clip-path: polygon(8% 20%, 24% 4%, 50% 0, 78% 8%, 94% 28%, 88% 100%, 70% 84%, 70% 42%, 58% 22%, 50% 36%, 42% 22%, 30% 42%, 30% 84%, 12% 100%);
}

.avatar-neck {
  z-index: 3;
  top: 72px;
  width: 24px;
  height: 26px;
  border-radius: 8px;
  background: #edc399;
}

.wearable {
  position: absolute;
  left: 50%;
  width: 120px;
  height: 120px;
  transform: translateX(-50%);
  overflow: visible;
  filter: drop-shadow(0 8px 9px rgba(45, 41, 38, 0.12));
}

.wearable-top {
  z-index: 4;
  top: 80px;
  width: 132px;
  height: 132px;
}

.wearable-outer {
  z-index: 5;
  top: 76px;
  width: 144px;
  height: 144px;
}

.wearable-bottom {
  z-index: 2;
  top: 162px;
  width: 130px;
  height: 130px;
}

.wearable-shoes {
  z-index: 3;
  bottom: 6px;
  width: 118px;
  height: 118px;
}

.dressed-avatar-women .wearable-top {
  top: 78px;
  width: 140px;
  height: 140px;
}

.dressed-avatar-women .wearable-outer {
  top: 72px;
  width: 152px;
  height: 152px;
}

.dressed-avatar-women .wearable-bottom {
  top: 145px;
  width: 148px;
  height: 148px;
}

.dressed-avatar-women .wearable-shoes {
  bottom: 4px;
  width: 116px;
  height: 116px;
}

.worn-accessories {
  position: absolute;
  z-index: 9;
  inset: 0;
  pointer-events: none;
}

.worn-accessories svg {
  position: absolute;
  width: 82px;
  height: 82px;
  filter: drop-shadow(0 8px 10px rgba(45, 41, 38, 0.16));
}

.worn-accessories svg:first-child {
  right: 18%;
  top: 34px;
}

.worn-accessories svg:last-child {
  left: 18%;
  top: 42px;
}

.worn-accessories svg use:not([href]) {
  display: none;
}

@media (max-width: 620px) {
  .outfit-visual {
    min-height: 430px;
  }

  .dressed-pair {
    inset: 28px 8px 28px;
    gap: 12px;
  }

  .dressed-avatar {
    width: 132px;
    height: 312px;
  }

  .wearable-top {
    width: 116px;
    height: 116px;
  }

  .wearable-outer {
    width: 128px;
    height: 128px;
  }

  .wearable-bottom {
    width: 118px;
    height: 118px;
  }

  .wearable-shoes {
    width: 104px;
    height: 104px;
  }

  .worn-accessories svg {
    width: 60px;
    height: 60px;
  }

  .worn-accessories svg:first-child {
    right: 8%;
  }

  .worn-accessories svg:last-child {
    left: 8%;
  }
}

/* Final outfit look mode: use curated full-look illustrations instead of composited SVG layers. */
.outfit-visual {
  min-height: 500px;
  display: grid;
  place-items: end center;
  padding: 24px 24px 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 92%, rgba(45, 41, 38, 0.1) 0 20%, transparent 20.5%),
    linear-gradient(180deg, #eef8fb 0%, #fff7e8 100%);
}

.outfit-visual::before {
  left: 24%;
  right: 24%;
  bottom: 26px;
  height: 20px;
  background: rgba(45, 41, 38, 0.12);
}

.outfit-look-image {
  position: relative;
  z-index: 2;
  display: block;
  width: min(76%, 500px);
  max-height: 96%;
  object-fit: contain;
  filter: drop-shadow(0 22px 18px rgba(45, 41, 38, 0.15));
}

.dressed-pair,
.worn-accessories,
.wearable {
  display: none;
}

@media (max-width: 620px) {
  .outfit-visual {
    min-height: 470px;
    padding: 18px 8px 0;
  }

  .outfit-look-image {
    width: min(96%, 420px);
    max-height: 94%;
  }
}
