body.solar-page {
  min-height: 100vh;
  background: #000;
  color: #f5f1e8;
}

.solar-main {
  overflow: hidden;
  background: #10100f;
}

.solar-hero {
  display: grid;
  min-height: calc(100svh - 60px);
  grid-template-columns: minmax(330px, 0.78fr) minmax(600px, 1.22fr);
  background:
    radial-gradient(circle at 78% 14%, rgba(255, 190, 91, 0.09), transparent 28%),
    #10100f;
}

.solar-copy {
  position: relative;
  z-index: 4;
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 70px 5vw 70px 6vw;
}

.solar-eyebrow {
  margin: 0 0 18px;
  color: #c8a96b;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.24em;
}

.solar-copy h1 {
  margin: 0;
  font-size: clamp(54px, 6.2vw, 92px);
  font-weight: 300;
  letter-spacing: -0.035em;
  line-height: 0.9;
}

.solar-lead {
  max-width: 470px;
  margin: 32px 0 42px;
  color: #aaa69e;
  font-size: 15px;
  line-height: 1.65;
}

.solar-time-card {
  max-width: 490px;
  padding: 24px;
  border: 1px solid #34332f;
  background: rgba(24, 24, 22, 0.78);
  backdrop-filter: blur(15px);
}

.solar-time-card__top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 27px;
}

.solar-time-card__top div {
  display: grid;
  gap: 3px;
}

.solar-time-card__top span {
  color: #85817a;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.solar-time-card__top strong {
  font-size: 35px;
  font-weight: 300;
}

.solar-time-card__top p {
  margin: 0 0 5px;
  color: #d3b779;
  font-size: 12px;
}

.solar-range {
  width: 100%;
  height: 2px;
  margin: 0;
  appearance: none;
  border-radius: 0;
  background: linear-gradient(90deg, #7f5830, #f2c677 48%, #d97945);
  cursor: pointer;
}

.solar-range::-webkit-slider-thumb {
  width: 18px;
  height: 18px;
  appearance: none;
  border: 4px solid #121210;
  border-radius: 50%;
  background: #f5ca78;
  box-shadow: 0 0 0 1px #f5ca78, 0 0 24px rgba(245, 202, 120, 0.48);
}

.solar-range::-moz-range-thumb {
  width: 12px;
  height: 12px;
  border: 4px solid #121210;
  border-radius: 50%;
  background: #f5ca78;
}

.solar-scale {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  color: #77736d;
  font-size: 9px;
}

.solar-presets {
  display: flex;
  gap: 8px;
  margin-top: 24px;
}

.solar-presets button {
  flex: 1;
  padding: 9px 12px;
  border: 1px solid #3b3934;
  background: transparent;
  color: #aaa69e;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  transition: 0.25s ease;
}

.solar-presets button:hover,
.solar-presets button.is-active {
  border-color: #d5af68;
  background: #d5af68;
  color: #15130f;
}

.solar-timezone {
  margin: 14px 0 0;
  color: #706d66;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-align: right;
  text-transform: uppercase;
}

.studio-visual {
  position: relative;
  min-height: 690px;
  overflow: hidden;
  background:
    linear-gradient(rgba(255, 255, 255, 0.017) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.017) 1px, transparent 1px);
  background-size: 40px 40px;
}

.sky-orbit {
  position: absolute;
  z-index: 1;
  inset: 5% 4% 4% 4%;
}

.sky-orbit__line {
  position: absolute;
  top: 7%;
  right: 5%;
  width: 21%;
  height: 84%;
  border-right: 1px dashed rgba(213, 175, 104, 0.4);
  border-radius: 0 55% 55% 0;
}

.sun {
  position: absolute;
  z-index: 5;
  top: var(--sun-y, 20%);
  left: var(--sun-x, 55%);
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #ffd98a;
  box-shadow:
    0 0 35px rgba(255, 198, 96, 0.72),
    0 0 100px rgba(255, 180, 67, 0.3);
  transform: translate(-50%, -50%);
  transition: top 0.5s ease, left 0.5s ease, opacity 0.5s ease;
}

.sun i {
  position: absolute;
  inset: -12px;
  border: 1px solid rgba(255, 217, 138, 0.24);
  border-radius: 50%;
}

.direction {
  position: absolute;
  color: #66635d;
  font-size: 9px;
  letter-spacing: 0.2em;
}

.direction--east {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.direction--south {
  top: 50%;
  right: 0;
  transform: translateY(-50%) rotate(90deg);
}

.direction--west {
  right: 50%;
  bottom: 0;
  transform: translateX(50%);
}

.direction--north {
  top: 50%;
  left: 0;
  transform: translateY(-50%) rotate(-90deg);
}

.studio-model {
  position: absolute;
  z-index: 2;
  right: 5%;
  bottom: 6%;
  left: 3%;
  height: 62%;
  perspective: 1200px;
}

.studio-floor {
  position: absolute;
  inset: 7% 4% 3%;
  display: grid;
  grid-template-columns: 1.12fr 0.88fr;
  grid-template-rows: 1fr 0.86fr;
  gap: 10px;
  padding: 10px;
  border: 1px solid #403e38;
  background: #191917;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.55);
  transform: rotateX(57deg) rotateZ(-8deg);
  transform-style: preserve-3d;
}

.studio-floor::after {
  position: absolute;
  z-index: -1;
  inset: 0;
  background: #080807;
  content: "";
  transform: translateZ(-24px);
  box-shadow: 22px 26px 0 #080807;
}

.studio-room {
  --light: 0;
  position: relative;
  overflow: hidden;
  padding: 19px 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(
      135deg,
      rgba(255, 220, 153, calc(var(--light) * 0.7)),
      rgba(183, 116, 49, calc(var(--light) * 0.18)) 45%,
      transparent 70%
    ),
    #242421;
  box-shadow:
    inset 0 0 45px rgba(255, 195, 102, calc(var(--light) * 0.28)),
    0 0 34px rgba(255, 181, 75, calc(var(--light) * 0.18));
  transform: translateZ(calc(4px + var(--light) * 16px));
  transition:
    background 0.45s ease,
    box-shadow 0.45s ease,
    transform 0.45s ease;
}

.studio-room::after {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    var(--beam-angle, 135deg),
    transparent 22%,
    rgba(255, 230, 177, calc(var(--light) * 0.34)) 23%,
    rgba(255, 213, 139, calc(var(--light) * 0.08)) 62%,
    transparent 63%
  );
  content: "";
  pointer-events: none;
}

.studio-room h2 {
  position: relative;
  z-index: 2;
  margin: 22px 0 4px;
  font-size: clamp(17px, 2vw, 27px);
  font-weight: 400;
}

.studio-room p,
.studio-room strong,
.room-number {
  position: relative;
  z-index: 2;
}

.studio-room p {
  margin: 0;
  color: #8e8b84;
  font-size: 9px;
}

.studio-room strong {
  position: absolute;
  right: 16px;
  bottom: 13px;
  color: #bcb7ae;
  font-size: 9px;
  font-weight: 400;
}

.studio-room.is-sunny strong {
  color: #ffe0a0;
}

.room-number {
  color: #77736c;
  font-size: 9px;
}

.room-windows {
  position: absolute;
  z-index: 3;
  top: 0;
  right: 12px;
  left: 12px;
  display: flex;
  gap: 5px;
}

.room-windows i {
  display: block;
  height: 5px;
  flex: 1;
  background: rgba(168, 204, 214, 0.4);
  box-shadow: 0 2px 10px rgba(255, 220, 161, calc(var(--light) * 0.9));
}

.studio-room--liberty {
  --beam-angle: 125deg;
}

.studio-room--blanc {
  --beam-angle: 150deg;
}

.studio-room--kvatro {
  --beam-angle: 30deg;
}

.studio-room--air {
  --beam-angle: 45deg;
}

.studio-room--liberty .room-windows,
.studio-room--kvatro .room-windows {
  top: 12px;
  right: auto;
  bottom: 12px;
  left: 0;
  width: 5px;
  flex-direction: column;
}

.studio-room--liberty .room-windows i,
.studio-room--kvatro .room-windows i {
  width: 5px;
  height: auto;
}

.studio-room--air .room-windows {
  top: auto;
  bottom: 0;
}

.studio-core {
  position: absolute;
  z-index: 4;
  top: 43%;
  left: 45%;
  display: grid;
  width: 92px;
  height: 70px;
  place-items: center;
  border: 1px solid #4d4b45;
  background: #151513;
  color: #a39e94;
  font-size: 10px;
  transform: translate(-50%, -50%) translateZ(25px);
}

.studio-core small {
  color: #625f59;
  font-size: 7px;
}

.sun-beam {
  position: absolute;
  z-index: 1;
  top: -9%;
  left: var(--beam-x, 55%);
  width: 48%;
  height: 90%;
  background: linear-gradient(180deg, rgba(255, 214, 139, 0.18), transparent 78%);
  clip-path: polygon(47% 0, 58% 0, 100% 100%, 0 100%);
  opacity: var(--daylight, 1);
  pointer-events: none;
  transform: translateX(-50%) rotate(var(--beam-rotation, 0deg));
  transform-origin: 50% 0;
  transition: left 0.5s ease, transform 0.5s ease, opacity 0.5s ease;
}

.solar-status {
  padding: 90px max(24px, 6vw);
  background: #eeeae1;
  color: #171715;
}

.solar-status__heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 30px;
  margin-bottom: 38px;
}

.solar-status__heading .solar-eyebrow {
  margin-bottom: 4px;
  color: #86652d;
}

.solar-status__heading h2 {
  margin: 0;
  font-size: clamp(30px, 4.5vw, 58px);
  font-weight: 300;
}

.solar-room-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid #bcb8af;
}

.solar-room-status {
  position: relative;
  min-height: 180px;
  padding: 25px 22px;
  border-right: 1px solid #bcb8af;
  border-bottom: 1px solid #bcb8af;
}

.solar-room-status:first-child {
  border-left: 1px solid #bcb8af;
}

.solar-room-status::after {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 12px;
  height: 12px;
  border: 1px solid #77736b;
  border-radius: 50%;
  background: rgba(255, 188, 72, var(--status-light));
  box-shadow: 0 0 18px rgba(255, 161, 35, var(--status-light));
  content: "";
}

.solar-room-status span {
  color: #77736b;
  font-size: 9px;
  letter-spacing: 0.16em;
}

.solar-room-status h3 {
  margin: 35px 0 8px;
  font-size: 23px;
  font-weight: 400;
}

.solar-room-status p {
  margin: 0;
  color: #706d66;
  font-size: 12px;
}

.solar-disclaimer {
  max-width: 680px;
  margin: 28px 0 0 auto;
  color: #77736b;
  font-size: 11px;
  line-height: 1.6;
  text-align: right;
}

@media (max-width: 1000px) {
  .solar-hero {
    grid-template-columns: 1fr;
  }

  .solar-copy {
    padding: 70px 8vw 20px;
  }

  .solar-lead {
    margin-bottom: 28px;
  }

  .solar-time-card {
    max-width: none;
  }

  .studio-visual {
    min-height: 680px;
  }

  .solar-room-list {
    grid-template-columns: repeat(2, 1fr);
  }

  .solar-room-status:nth-child(3) {
    border-left: 1px solid #bcb8af;
  }
}

@media (max-width: 700px) {
  .solar-copy {
    padding: 49px 20px 14px;
  }

  .solar-copy h1 {
    font-size: 49px;
  }

  .solar-lead {
    margin: 23px 0 27px;
    font-size: 13px;
  }

  .solar-time-card {
    padding: 19px 17px;
  }

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

  .sky-orbit {
    top: 1%;
    right: 5%;
    left: 5%;
    height: 40%;
  }

  .sun {
    width: 42px;
    height: 42px;
  }

  .studio-model {
    right: -7%;
    bottom: 4%;
    left: -7%;
    height: 66%;
  }

  .studio-floor {
    gap: 6px;
    padding: 6px;
  }

  .studio-room {
    padding: 10px;
  }

  .studio-room h2 {
    margin-top: 14px;
    font-size: 15px;
  }

  .studio-room p {
    display: none;
  }

  .studio-room strong {
    right: 8px;
    bottom: 7px;
    font-size: 7px;
  }

  .studio-core {
    width: 60px;
    height: 48px;
    font-size: 7px;
  }

  .solar-status {
    padding: 58px 16px;
  }

  .solar-status__heading {
    display: block;
    margin-bottom: 28px;
  }

  .solar-status__heading h2 {
    font-size: 31px;
  }

  .solar-room-list {
    grid-template-columns: 1fr;
  }

  .solar-room-status,
  .solar-room-status:nth-child(3) {
    min-height: 125px;
    border-left: 1px solid #bcb8af;
  }

  .solar-room-status h3 {
    margin-top: 20px;
  }

  .solar-disclaimer {
    text-align: left;
  }
}

@media (prefers-reduced-motion: reduce) {
  .sun,
  .sun-beam,
  .studio-room {
    transition: none;
  }
}

.studio-model {
  inset: 5% 11% 3% 3%;
  display: grid;
  height: auto;
  place-items: center;
  perspective: none;
}

.studio-plan {
  position: absolute;
  z-index: 2;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
  filter: drop-shadow(0 28px 38px rgba(0, 0, 0, 0.44));
}

.plan-outline,
.plan-service path,
.plan-corridor path,
.plan-room__base,
.plan-room__light,
.plan-wc path,
.plan-entry path,
.plan-windows path {
  vector-effect: non-scaling-stroke;
}

.plan-outline {
  fill: #151513;
  stroke: #77736a;
  stroke-width: 1.5;
}

.plan-service path {
  fill: #232320;
  stroke: #5b5851;
  stroke-width: 1;
}

.plan-service--dark path {
  fill: #34332f;
}

.plan-service text,
.plan-wc text,
.plan-entry text {
  fill: #8b877f;
  font-family: "Inter Digits", "Raleway", Arial, sans-serif;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-anchor: middle;
}

.plan-corridor path {
  fill: #191917;
  stroke: #4f4c46;
  stroke-width: 1;
}

.plan-room {
  --light: 0;
}

.plan-room__base {
  fill: #242421;
  stroke: #706c64;
  stroke-width: 1;
}

.plan-room__light {
  fill: #f0b95e;
  opacity: var(--light);
  stroke: #e5bc72;
  stroke-width: 1;
  filter: drop-shadow(0 0 22px rgba(255, 181, 64, var(--light)));
  transition: opacity 0.45s ease, filter 0.45s ease;
}

.plan-room__title,
.plan-room__state {
  fill: #e7e1d6;
  font-family: "Inter Digits", "Raleway", Arial, sans-serif;
  text-anchor: middle;
  transition: fill 0.4s ease;
}

.plan-room__title {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
}

.plan-room__state {
  fill: #8c887f;
  font-size: 9px;
  font-weight: 400;
}

.plan-room.is-sunny .plan-room__title,
.plan-room.is-sunny .plan-room__state {
  fill: #fff0c8;
}

.plan-wc path {
  fill: #1d1d1b;
  stroke: #59564f;
  stroke-width: 1;
}

.plan-entry path {
  fill: none;
  stroke: #77736a;
  stroke-width: 1.2;
}

.plan-entry circle {
  fill: #d5af68;
  filter: drop-shadow(0 0 7px rgba(213, 175, 104, 0.65));
}

.plan-entry text {
  fill: #d5af68;
  letter-spacing: 0.18em;
}

.plan-windows path {
  fill: none;
  stroke: #a9c3c8;
  stroke-width: 5;
  stroke-linecap: round;
  opacity: 0.62;
}

.sun-beam {
  z-index: 1;
  top: 4%;
  width: 54%;
  height: 92%;
  background: linear-gradient(
    180deg,
    rgba(255, 217, 150, 0.2),
    rgba(255, 182, 73, 0.06) 58%,
    transparent 88%
  );
  mix-blend-mode: screen;
}

@media (max-width: 1000px) {
  .studio-visual {
    min-height: 760px;
  }

  .studio-model {
    inset: 2% 12% 2% 5%;
  }
}

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

  .studio-model {
    inset: 3% 4% 2% 0;
  }

  .plan-room__title {
    font-size: 20px;
  }

  .plan-room__state {
    font-size: 10px;
  }

  .plan-service text,
  .plan-wc text,
  .plan-entry text {
    font-size: 11px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .plan-room__light,
  .plan-room__title,
  .plan-room__state {
    transition: none;
  }
}

/* Centered interactive sun map */
.solar-hero {
  position: relative;
  display: flex;
  height: calc(100svh - 60px);
  min-height: 0;
  padding: 35px max(24px, 4vw) 4px;
  align-items: center;
  flex-direction: column;
  isolation: isolate;
}

.studio-visual {
  position: relative;
  width: 100%;
  max-width: 1280px;
  height: auto;
  min-height: 0;
  margin-top: 4px;
  flex: 1;
}

.solar-copy {
  position: relative;
  z-index: 5;
  inset: auto;
  width: min(960px, 100%);
  padding: 0;
  align-items: center;
  background: none;
  text-align: center;
}

.solar-copy h1 {
  margin: 0 0 18px;
  font-size: clamp(30px, 4vw, 54px);
  font-weight: 300;
  letter-spacing: 0.03em;
  line-height: 1.1;
}

.solar-copy h1 br {
  display: none;
}

.solar-lead {
  max-width: 640px;
  margin: 0 auto 6px;
  font-size: 15px;
  line-height: 1.5;
}

.solar-time-card {
  position: relative;
  width: min(520px, 100%);
  max-width: none;
  margin-top: 6px;
  padding: 12px 16px;
  text-align: left;
}

.solar-time-card__title {
  display: none;
}

.solar-time-card__top {
  margin-bottom: 12px;
}

.solar-time-card__top strong {
  font-size: 28px;
}

.solar-presets {
  margin-top: 10px;
}

.solar-presets button {
  padding-block: 7px;
}

.studio-model {
  top: 50%;
  left: 50%;
  width: min(70vw, 68svh, 700px);
  height: auto;
  aspect-ratio: 620 / 980;
  transform: translate(-50%, -50%) rotate(-90deg);
  transform-origin: center;
}

.studio-plan {
  width: 100%;
  height: 100%;
}

.plan-compass text {
  fill: #77736c;
  font-family: "Inter Digits", "Raleway", Arial, sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-anchor: middle;
}

.plan-room__title {
  font-size: 26px;
}

.plan-room__state {
  font-size: 12px;
}

.plan-service text,
.plan-wc text,
.plan-entry text {
  font-size: 14px;
}

.plan-sun-orbit {
  fill: none;
  stroke: rgba(213, 175, 104, 0.72);
  stroke-width: 2;
  stroke-dasharray: 7 10;
  vector-effect: non-scaling-stroke;
}

.plan-sun-hit-area {
  fill: none;
  stroke: transparent;
  stroke-width: 54;
  cursor: grab;
  pointer-events: stroke;
  touch-action: none;
  vector-effect: non-scaling-stroke;
}

.plan-sun-beam {
  fill: rgba(255, 194, 92, 0.2);
  mix-blend-mode: screen;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.plan-sun {
  cursor: grab;
  outline: none;
  pointer-events: all;
  touch-action: none;
  transform-box: view-box;
  transform-origin: 0 0;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.35s ease;
}

.studio-plan.is-dragging-sun .plan-sun,
.studio-plan.is-dragging-sun .plan-sun-hit-area {
  cursor: grabbing;
}

.studio-plan.is-dragging-sun .plan-sun {
  transition: opacity 0.2s ease;
}

.plan-sun:focus-visible .plan-sun__ring {
  stroke: #fff;
  stroke-width: 2;
}

.plan-sun__glow {
  fill: rgba(255, 188, 77, 0.14);
  filter: drop-shadow(0 0 20px rgba(255, 184, 70, 0.75));
}

.plan-sun__core {
  fill: #ffd98a;
  filter: drop-shadow(0 0 13px rgba(255, 196, 92, 0.9));
}

.plan-sun.is-below-horizon .plan-sun__core {
  fill: #776c58;
  filter: none;
}

.plan-sun.is-below-horizon .plan-sun__glow {
  fill: rgba(119, 108, 88, 0.16);
  filter: none;
}

.plan-sun__ring {
  fill: none;
  stroke: rgba(255, 224, 164, 0.55);
  stroke-width: 1;
  vector-effect: non-scaling-stroke;
}

.plan-sun__ring {
  animation: sun-drag-pulse 1.9s ease-in-out infinite;
}

@keyframes sun-drag-pulse {
  50% {
    opacity: 0.35;
    r: 37px;
  }
}

@media (max-width: 1100px) {
  .studio-model {
    width: min(72vw, 68svh);
  }
}

@media (min-width: 901px) {
  .solar-time-card {
    display: grid;
    width: min(780px, 88vw);
    padding: 10px 16px;
    grid-template-columns: 155px minmax(300px, 1fr);
    grid-template-rows: auto auto;
    column-gap: 18px;
    row-gap: 5px;
  }

  .solar-time-card__top {
    display: grid;
    grid-row: 1 / 3;
    grid-column: 1;
    gap: 1px;
    margin: 0;
    align-self: center;
  }

  .solar-time-card__top p {
    margin: 0;
  }

  .solar-range {
    grid-row: 1;
    grid-column: 2;
    align-self: end;
  }

  .solar-scale {
    grid-row: 2;
    grid-column: 2;
    margin-top: 0;
  }

  .solar-range,
  .solar-scale {
    transform: translateY(4px);
  }

}

@media (max-width: 900px) {
  .solar-hero {
    min-height: calc(100svh - 60px);
    height: calc(100svh - 60px);
    padding: 28px 18px 12px;
  }

  .solar-copy {
    display: flex;
    width: 100%;
    padding: 0;
  }

  .solar-copy > .solar-eyebrow,
  .solar-copy > h1,
  .solar-lead {
    display: none;
  }

  .solar-copy h1 br {
    display: initial;
  }

  .solar-time-card {
    width: 100%;
    max-width: none;
  }

  .solar-time-card__title {
    position: absolute;
    top: 14px;
    right: 14px;
    display: block;
    color: #c8a96b;
    font-size: 10px;
    font-weight: 300;
    letter-spacing: 0.14em;
    line-height: 1.35;
    text-align: right;
    pointer-events: none;
  }

  .studio-visual {
    height: auto;
    min-height: 0;
    margin-top: 8px;
    flex: 1;
  }

  .studio-model {
    top: 50%;
    left: 50%;
    width: min(86vw, 40svh, 460px);
    transform: translate(-50%, -50%);
  }

  .studio-plan {
    touch-action: pan-y;
  }

  .plan-sun-hit-area {
    pointer-events: none;
    touch-action: pan-y;
  }

  .plan-entry circle {
    transform: translateX(-25px);
  }
}

@media (max-width: 700px) {
  .solar-hero {
    min-height: calc(100vh - 80px);
    min-height: calc(100dvh - 80px);
    height: calc(100vh - 80px);
    height: calc(100dvh - 80px);
    padding: 24px 12px 10px;
  }

  .solar-time-card {
    padding: 14px;
  }

  .solar-time-card__top {
    margin-bottom: 18px;
  }

  .solar-presets {
    margin-top: 16px;
  }

  .studio-model {
    width: min(88vw, 40svh);
  }

  .plan-room__title {
    font-size: 27px;
  }

  .plan-room__state {
    font-size: 13px;
  }

  .plan-service text,
  .plan-wc text,
  .plan-entry text {
    font-size: 14px;
  }

  .plan-compass text {
    font-size: 13px;
  }
}

@media (max-width: 390px) and (max-height: 700px) {
  .solar-time-card {
    padding: 8px 12px;
  }

  .solar-time-card__title {
    top: 9px;
    right: 12px;
    font-size: 9px;
  }

  .solar-time-card__top {
    margin-bottom: 8px;
  }

  .solar-time-card__top span {
    font-size: 9px;
  }

  .solar-time-card__top strong {
    font-size: 24px;
  }

  .solar-scale {
    margin-top: 6px;
    font-size: 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .plan-sun {
    transition: none;
  }

  .plan-sun__ring {
    animation: none;
  }
}
