@layer reset, tokens, base, layout, components, wordpress, utilities;

@property --anes-progress-value {
  syntax: "<number>";
  inherits: true;
  initial-value: 0;
}

@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html {
    scroll-behavior: smooth;
    text-size-adjust: 100%;
  }

  body {
    min-block-size: 100svh;
    margin: 0;
  }

  img,
  video,
  svg {
    max-inline-size: 100%;
    block-size: auto;
  }

  button,
  input,
  textarea,
  select {
    font: inherit;
  }
}

@layer tokens {
  :root {
    color-scheme: light;
    --anes-ink: #06152f;
    --anes-text: #25324d;
    --anes-muted: #64708a;
    --anes-surface: #ffffff;
    --anes-soft: #eef5ff;
    --anes-blue: #174eea;
    --anes-cyan: #10a7ff;
    --anes-violet: #6d46ff;
    --anes-green: #00a676;
    --anes-amber: #ffb000;
    --anes-line: color-mix(in srgb, var(--anes-blue), transparent 84%);
    --anes-shadow: 0 24px 64px color-mix(in srgb, var(--anes-ink), transparent 88%);
    --anes-radius: 8px;
    --anes-radius-lg: 18px;
    --anes-content: min(100% - 32px, 1040px);
    --anes-wide: min(100% - 32px, 1280px);
    --anes-space-1: clamp(0.5rem, 0.42rem + 0.4vw, 0.75rem);
    --anes-space-2: clamp(0.85rem, 0.7rem + 0.7vw, 1.35rem);
    --anes-space-3: clamp(1.3rem, 1rem + 1.2vw, 2rem);
    --anes-space-4: clamp(2rem, 1.35rem + 2.6vw, 3.8rem);
    --anes-space-5: clamp(3rem, 2rem + 4.4vw, 6.25rem);
  }
}

@layer base {
  body {
    color: var(--anes-text);
    background:
      radial-gradient(circle at top left, color-mix(in srgb, var(--anes-cyan), transparent 84%), transparent 34rem),
      linear-gradient(180deg, #f8fbff 0%, #eef5ff 48%, #ffffff 100%);
    font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
    font-size: clamp(1rem, 0.96rem + 0.22vw, 1.125rem);
    line-height: 1.8;
    letter-spacing: 0;
    accent-color: var(--anes-blue);
  }

  :where(h1, h2, h3, h4) {
    color: var(--anes-ink);
    line-height: 1.18;
    letter-spacing: 0;
    text-wrap: balance;
  }

  :where(p, li) {
    overflow-wrap: break-word;
  }

  :where(a) {
    color: var(--anes-blue);
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.18em;
  }

  :where(a:hover) {
    color: var(--anes-violet);
  }

  :where(:focus-visible) {
    outline: 3px solid color-mix(in srgb, var(--anes-cyan), white 12%);
    outline-offset: 4px;
  }
}

@layer layout {
  .anes-shell {
    inline-size: var(--anes-content);
    margin-inline: auto;
  }

  .anes-shell--wide {
    inline-size: var(--anes-wide);
  }

  .anes-section {
    padding-block: var(--anes-space-5);
  }

  .anes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
    gap: var(--anes-space-3);
  }

  .anes-grid--dense {
    align-items: stretch;
  }

  .anes-split {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--anes-space-4);
    align-items: center;
  }

  @media (min-width: 860px) {
    .anes-split {
      grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    }
  }
}

@layer components {
  .anes-header {
    position: sticky;
    z-index: 30;
    inset-block-start: 0;
    border-block-end: 1px solid color-mix(in srgb, var(--anes-line), transparent 12%);
    background: color-mix(in srgb, white, transparent 10%);
    backdrop-filter: blur(18px);
  }

  .anes-scroll-progress {
    position: absolute;
    inset-block-start: 0;
    inset-inline-start: 0;
    inline-size: calc(var(--anes-scroll-progress, 0) * 100%);
    block-size: 3px;
    background: linear-gradient(90deg, var(--anes-cyan), var(--anes-blue), var(--anes-violet));
    transform-origin: left center;
    transition: inline-size 120ms linear;
  }

  @supports (animation-timeline: scroll()) {
    @keyframes anes-scroll-progress {
      from {
        --anes-progress-value: 0;
      }

      to {
        --anes-progress-value: 1;
      }
    }

    .anes-scroll-progress {
      inline-size: calc(var(--anes-progress-value) * 100%);
      animation: anes-scroll-progress linear both;
      animation-timeline: scroll(root block);
    }
  }

  .anes-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-block-size: 72px;
    gap: 1rem;
  }

  .anes-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--anes-ink);
    font-weight: 850;
    text-decoration: none;
  }

  .anes-nav {
    display: none;
    align-items: center;
    gap: clamp(0.75rem, 1.6vw, 1.5rem);
    font-size: 0.94rem;
    font-weight: 700;
  }

  @media (min-width: 860px) {
    .anes-nav {
      display: flex;
    }
  }

  .anes-button,
  .wp-block-button__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-block-size: 44px;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--anes-blue), var(--anes-violet));
    color: white;
    font-weight: 850;
    line-height: 1.2;
    text-decoration: none;
    box-shadow: 0 14px 30px color-mix(in srgb, var(--anes-blue), transparent 72%);
    transition: translate 180ms ease, box-shadow 180ms ease;
  }

  .anes-button:hover,
  .wp-block-button__link:hover {
    color: white;
    translate: 0 -2px;
    box-shadow: 0 18px 40px color-mix(in srgb, var(--anes-blue), transparent 66%);
  }

  .anes-hero {
    min-block-size: min(760px, calc(100svh - 72px));
    display: grid;
    align-items: center;
    padding-block: var(--anes-space-5);
  }

  .anes-hero__title {
    max-inline-size: 11ch;
    margin: 0;
    font-size: clamp(2.35rem, 1.5rem + 4.2vw, 5.25rem);
  }

  .anes-hero__lead {
    max-inline-size: 42rem;
    color: var(--anes-text);
    font-size: clamp(1.12rem, 1.02rem + 0.55vw, 1.45rem);
  }

  .anes-metric-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 9.5rem), 1fr));
    gap: 0.75rem;
    margin-block-start: var(--anes-space-2);
  }

  .anes-metric {
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    background: color-mix(in srgb, white, var(--anes-soft) 26%);
    padding: 1rem;
  }

  .anes-metric__value {
    display: block;
    color: var(--anes-blue);
    font-size: clamp(1.75rem, 1.35rem + 1.8vw, 2.8rem);
    font-weight: 900;
    line-height: 1;
  }

  .anes-metric__label {
    display: block;
    margin-block-start: 0.45rem;
    color: var(--anes-muted);
    font-size: 0.86rem;
    font-weight: 750;
  }

  .anes-card {
    container-type: inline-size;
    display: grid;
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    background: color-mix(in srgb, var(--anes-surface), transparent 2%);
    box-shadow: var(--anes-shadow);
    padding: clamp(1rem, 0.7rem + 1.4vw, 1.75rem);
  }

  @supports (grid-template-rows: subgrid) {
    .anes-grid--dense > .anes-card {
      grid-template-rows: subgrid;
      grid-row: span 2;
    }
  }

  .anes-card:has(.anes-card__body) {
    padding: 0;
    overflow: clip;
  }

  .anes-card__body {
    padding: clamp(1rem, 0.7rem + 1.4vw, 1.75rem);
  }

  .anes-card__media {
    aspect-ratio: 16 / 9;
    background:
      linear-gradient(135deg, color-mix(in srgb, var(--anes-blue), transparent 8%), color-mix(in srgb, var(--anes-violet), transparent 10%)),
      radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--anes-cyan), white 12%), transparent 28%);
  }

  .anes-feature-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 11rem), 1fr));
    gap: 1px;
    overflow: clip;
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    background: var(--anes-line);
  }

  .anes-feature-strip__item {
    min-block-size: 7rem;
    padding: 1rem;
    background: color-mix(in srgb, white, var(--anes-soft) 18%);
  }

  .anes-flow {
    counter-reset: anes-flow;
    display: grid;
    gap: 0.75rem;
    padding: 0;
    list-style: none;
  }

  .anes-flow__item {
    counter-increment: anes-flow;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    padding: 1rem;
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    background: white;
  }

  .anes-flow__item::before {
    display: grid;
    place-items: center;
    inline-size: 2rem;
    block-size: 2rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--anes-amber), white 14%);
    color: var(--anes-ink);
    font-weight: 900;
    content: counter(anes-flow);
  }

  @container (min-width: 28rem) {
    .anes-card {
      padding: clamp(1.35rem, 1rem + 1.5vw, 2.25rem);
    }

    .anes-card:has(.anes-card__body) {
      padding: 0;
    }
  }

  .anes-kicker {
    margin: 0 0 0.75rem;
    color: var(--anes-blue);
    font-size: 0.82rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .anes-sns-slider {
    display: grid;
    gap: 1rem;
  }

  .anes-sns-slider__viewport {
    display: grid;
    grid-auto-columns: minmax(min(82vw, 20rem), 1fr);
    grid-auto-flow: column;
    gap: 1rem;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    scroll-snap-type: inline mandatory;
    scrollbar-width: thin;
    padding-block-end: 0.6rem;
  }

  .anes-sns-slide {
    display: grid;
    align-content: space-between;
    scroll-snap-align: start;
    min-block-size: 13rem;
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    background: linear-gradient(145deg, white, color-mix(in srgb, var(--anes-soft), transparent 28%));
    padding: 1.25rem;
  }

  .anes-sns-slider__controls {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
  }

  .anes-sns-slider__status {
    margin-inline-end: auto;
    color: var(--anes-muted);
    font-size: 0.86rem;
    font-weight: 750;
  }

  .anes-icon-button {
    inline-size: 44px;
    block-size: 44px;
    border: 1px solid var(--anes-line);
    border-radius: 999px;
    background: white;
    color: var(--anes-ink);
    cursor: pointer;
  }

  .anes-footer {
    padding-block: var(--anes-space-4);
    border-block-start: 1px solid var(--anes-line);
    background: var(--anes-ink);
    color: color-mix(in srgb, white, transparent 16%);
  }

  [data-anes-reveal] {
    opacity: 0;
    translate: 0 18px;
    transition: opacity 520ms ease, translate 520ms ease;
  }

  [data-anes-reveal].is-anes-visible {
    opacity: 1;
    translate: 0 0;
  }
}

@layer wordpress {
  .wp-site-blocks {
    min-block-size: 100svh;
  }

  :where(.wp-block-post-content) > :where(*) {
    margin-block-start: var(--anes-space-2);
    margin-block-end: 0;
  }

  :where(.wp-block-post-content) > :where(h2, h3) {
    margin-block-start: var(--anes-space-4);
  }

  :where(.wp-block-post-content) :where(h2) {
    padding-block-start: 0.85rem;
    border-block-start: 3px solid color-mix(in srgb, var(--anes-blue), white 12%);
    font-size: clamp(1.55rem, 1.22rem + 1.25vw, 2.25rem);
  }

  :where(.wp-block-post-content) :where(h3) {
    font-size: clamp(1.25rem, 1.08rem + 0.72vw, 1.65rem);
  }

  :where(.wp-block-post-content) :where(p, ul, ol) {
    max-inline-size: 72ch;
  }

  :where(.wp-block-image img) {
    border-radius: var(--anes-radius);
  }

  :where(.alignwide) {
    max-inline-size: var(--anes-wide);
  }

  :where(.alignfull) {
    max-inline-size: none;
  }

  :where(.mw_wp_form input, .mw_wp_form textarea, .wpcf7 input, .wpcf7 textarea) {
    inline-size: 100%;
    border: 1px solid var(--anes-line);
    border-radius: var(--anes-radius);
    padding: 0.9rem 1rem;
    background: white;
  }

  :where(.mw_wp_form input[type="submit"], .wpcf7-submit) {
    inline-size: auto;
    cursor: pointer;
    background: var(--anes-blue);
    color: white;
    font-weight: 800;
  }

  .anes-news-list {
    display: grid;
    gap: 0.85rem;
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .anes-news-list__item {
    display: grid;
    gap: 0.25rem;
    padding-block-end: 0.85rem;
    border-block-end: 1px solid color-mix(in srgb, var(--anes-line), transparent 10%);
  }

  .anes-news-list__item a {
    color: var(--anes-ink);
    font-weight: 800;
    line-height: 1.5;
    text-decoration: none;
  }

  .anes-news-list__item time,
  .anes-news-empty {
    color: var(--anes-muted);
    font-size: 0.88rem;
  }

  :where(.wp-block-post-content) :where(.container, .row, .col) {
    max-inline-size: var(--anes-wide);
  }

  :where(.wp-block-post-content) :where(.row) {
    display: flex;
    flex-wrap: wrap;
    gap: var(--anes-space-2);
  }

  :where(.wp-block-post-content) :where(.col) {
    flex: 1 1 min(100%, 18rem);
    min-inline-size: 0;
  }
}

@layer utilities {
  .anes-visually-hidden {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
}

@supports (animation-timeline: view()) {
  @keyframes anes-view-in {
    from {
      opacity: 0;
      translate: 0 22px;
    }

    to {
      opacity: 1;
      translate: 0 0;
    }
  }

  [data-anes-reveal] {
    animation: anes-view-in 1s ease both;
    animation-timeline: view();
    animation-range: entry 8% cover 28%;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }

  [data-anes-reveal] {
    opacity: 1;
    translate: 0 0;
  }
}

/* Unlayered guard: keeps Anes namespaced layout stable when legacy unlayered CSS is present. */
.wp-site-blocks :where(.anes-shell) {
  inline-size: var(--anes-content);
  margin-inline: auto;
}

.wp-site-blocks :where(.anes-grid) {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}

.wp-site-blocks {
  color: var(--anes-text);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1rem, 0.96rem + 0.22vw, 1.125rem);
  line-height: 1.8;
  letter-spacing: 0;
}

.wp-site-blocks :where(.anes-hero__title) {
  color: var(--anes-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(2.35rem, 1.5rem + 4.2vw, 5.25rem);
  line-height: 1.18;
  letter-spacing: 0;
}

.wp-site-blocks :where(.anes-section h2, .anes-card h2, .anes-sns-slider h2) {
  color: var(--anes-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1.55rem, 1.22rem + 1.25vw, 2.25rem);
  line-height: 1.18;
  letter-spacing: 0;
}

.wp-site-blocks :where(.anes-card h3, .anes-sns-slide h3) {
  color: var(--anes-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1.25rem, 1.08rem + 0.72vw, 1.65rem);
  line-height: 1.18;
  letter-spacing: 0;
}

.wp-site-blocks :where(.anes-hero__lead, .anes-card p, .anes-sns-slide p) {
  color: var(--anes-text);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  line-height: 1.8;
}

.wp-site-blocks :where(.anes-sns-slider__viewport) {
  display: grid;
  grid-auto-columns: minmax(min(82vw, 20rem), 1fr);
  grid-auto-flow: column;
  gap: 1rem;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  padding-block-end: 0.6rem;
}

.wp-site-blocks :where(.anes-button, .wp-block-button__link) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-block-size: 44px;
  padding-inline: 1.15rem;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--anes-blue), var(--anes-violet));
  color: white;
  font-weight: 850;
  line-height: 1.2;
  text-decoration: none;
  box-shadow: 0 14px 30px color-mix(in srgb, var(--anes-blue), transparent 72%);
}

.wp-site-blocks .wp-block-post-content .container {
  inline-size: 100%;
  max-inline-size: var(--anes-wide);
  margin-inline: 0;
}

.wp-site-blocks .wp-block-post-content .row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--anes-space-2);
  inline-size: 100%;
  max-inline-size: var(--anes-wide);
}

.wp-site-blocks .wp-block-post-content .col {
  float: none;
  flex: 1 1 min(100%, 18rem);
  min-inline-size: 0;
  max-inline-size: 100%;
  inline-size: auto;
}

.wp-site-blocks .wp-block-post-content h2 {
  margin-block-start: var(--anes-space-4);
  padding-block-start: 0.85rem;
  border-block-start: 3px solid color-mix(in srgb, var(--anes-blue), white 12%);
  color: var(--anes-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1.55rem, 1.22rem + 1.25vw, 2.25rem);
  line-height: 1.18;
  letter-spacing: 0;
}

.wp-site-blocks .wp-block-post-content h3 {
  margin-block-start: var(--anes-space-4);
  color: var(--anes-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1.25rem, 1.08rem + 0.72vw, 1.65rem);
  line-height: 1.18;
  letter-spacing: 0;
}

.wp-site-blocks .wp-block-post-content :where(p, ul, ol) {
  max-inline-size: 72ch;
  color: var(--anes-text);
  font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
  font-size: clamp(1rem, 0.96rem + 0.22vw, 1.125rem);
  line-height: 1.8;
}

@media (max-width: 768px) {
  .wp-site-blocks .wp-block-post-content .da-business-grid {
    grid-template-columns: 1fr !important;
  }
}
