@charset "UTF-8";
/*
Theme Name: LEGALUS
Author: LEGALUS
Author URI: https://legalus.jp/
Version: 1.0
Description: Responsive breakpoints (mobile / tablet / desktop)
*/

/* +++++++++++++++++++++++++++++++++++++++++++++
Tablet Styles
Desc：768px以上
+++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (min-width:768px) {
  /* Variables */
  :root {
    --font-size-base: var(--font-size-base-md);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Home MV Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .home-mv .home-mv-lead {
    padding: 0;
    width: var(--wrapper-width-fluid);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Section Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  section {
    padding: var(--spacing-section-md) 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Wrapper Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .wrapper {
    width: var(--wrapper-width-fluid);
    padding: 0;
    max-width: var(--wrapper-max-width-md);
    margin: 0 auto;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Explanation Box Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .explanation-box dl dd {
    width: 100%;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Breadcrumbs Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .breadcrumbs.block {
    width: var(--wrapper-width-fluid);
    max-width: var(--wrapper-max-width-md);
    margin: 0 auto;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Post Header Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .post-header .breadcrumbs {
    padding: 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Home News Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .home-news .news-list li a {
    padding: var(--spacing-sm-plus) var(--spacing-xs);
  }
  .home-news .news-list li a dl {
    flex-direction: row;
    align-items: baseline;
    gap: var(--spacing-md);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  FAQ Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .faq-content dt {
    padding: var(--spacing-md) var(--spacing-xs);
  }
  .faq-content dt .toggle-icon {
    width: var(--spacing-lg);
    height: var(--spacing-lg);
  }
  .faq-content dt .toggle-icon::before {
    width: 1.375rem;
    height: var(--border-width-default);
  }
  .faq-content dt .toggle-icon::after {
    width: var(--border-width-default);
    height: 1.375rem;
  }
  .faq-content dd .answer {
    padding: 0 var(--spacing-xs) 1.75rem;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  CTA Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .cta {
    min-height: auto;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Sticky CTA Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .sticky-cta-tel {
    display: none;
  }
  .sticky-cta-link {
    width: auto;
    height: auto;
    min-height: var(--sticky-cta-size);
    padding: var(--spacing-xs) var(--spacing-md);
    justify-content: flex-start;
    gap: var(--spacing-xs);
  }
  .sticky-cta-label {
    display: inline;
    font-size: var(--font-size-sm);
    font-weight: 700;
    line-height: 1.2;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Card List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .card-list:not(.overflow-card-list):not(.card-list-flex) {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Footer Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  footer .footer-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--spacing-xl) var(--spacing-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Drawer Menu Styles (Tablet/PC)
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .drawer-inner {
    flex-direction: row;
  }
  .drawer-pane-primary {
    flex: 0 0 42%;
    max-width: 560px;
    padding: calc(var(--header-height) + var(--spacing-xl)) clamp(var(--spacing-lg), 6vw, var(--spacing-2xl)) var(--spacing-2xl);
    border-right: var(--border-width-thin) solid rgba(255, 255, 255, 0.08);
  }
  .drawer-pane-secondary {
    position: relative;
    inset: auto;
    flex: 1 1 auto;
    padding: calc(var(--header-height) + var(--spacing-xl)) clamp(var(--spacing-lg), 6vw, var(--spacing-2xl)) var(--spacing-2xl);
    background-color: transparent;
    transform: none;
    visibility: visible;
    pointer-events: auto;
    transition: none;
  }
  .drawer-sub-back {
    display: none;
  }
  .drawer-nav-en {
    font-size: clamp(2rem, 3vw, 3.25rem);
    white-space: nowrap;
  }
  .drawer-nav-item:not(.is-active) .drawer-nav-en {
    opacity: 0.45;
  }
  .drawer-sub-en {
    font-size: var(--font-size-3xl);
  }
  .drawer-sub-list {
    gap: var(--spacing-sm);
  }
  .drawer-sub-list li a {
    font-size: var(--font-size-lg);
  }
  footer .footer-bottom {
    flex-direction: row-reverse;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
  }
}

/* +++++++++++++++++++++++++++++++++++++++++++++
Desktop Styles
Desc：1025px以上
+++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (min-width:1025px) {
  /* Variables */
  :root {
    --font-size-base: var(--font-size-base-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Breadcrumbs Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .breadcrumbs.block {
    max-width: var(--wrapper-max-width-lg);
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .list.grid-list {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Table Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .table th,
  .table td {
    padding: var(--spacing-sm);
    font-size: var(--font-size-md);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Section Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  section {
    padding: var(--spacing-section-lg) 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Wrapper Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .wrapper {
    max-width: var(--wrapper-max-width-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Page Section Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .page-section .wrapper h2.lawyer-title {
    margin-bottom: 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Header Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  header {
    padding-right: 0;
  }
  header .header-menu {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-right: var(--header-height);
  }
  header .global-menu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding-right: var(--spacing-sm);
    z-index: var(--z-index-panel);
    background-color: transparent;
  }
  header .global-menu ul {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--spacing-xs) var(--global-menu-gap);
    list-style: none;
    margin: 0;
    padding: 0;
  }
  header .global-menu ul li {
    flex-shrink: 0;
  }
  header .global-menu ul li a {
    position: relative;
    display: block;
    padding: var(--spacing-2xs) 0;
    font-size: var(--global-menu-font-size);
    white-space: nowrap;
    font-weight: bold;
    color: var(--color-primary);
    text-decoration: none;
    transition: color 0.2s;
    line-height: 1.1;
    text-align: center;
  }
  header .global-menu ul li a::after {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: var(--color-primary);
    bottom: calc(-0.5 * var(--spacing-xs));
    transform: scale(0, 1);
    transition: transform 0.5s;
    transform-origin: center top;
  }
  header .global-menu ul li a .ja {
    display: block;
  }
  header .global-menu ul li a .en {
    font-size: 0.7em;
    color: var(--color-primary-pale);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Home MV Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .home-mv {
    display: flex;
    flex-direction: column;
    height: calc(var(--stable-vh, 1vh) * 100 - var(--header-height) - var(--lu-admin-bar-height));
    padding: 0;
  }
  .home-mv .home-mv-lead {
    max-width: var(--wrapper-max-width-lg);
    font-size: clamp(3rem, 8vw, 4.5rem);
  }
  .home-mv-media {
    margin-top: 0;
    flex: 1 1 auto;
    min-height: 0;
  }
  .home-mv-media > img {
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Main Visual Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .main-visual .main-visual-contents h1 {
    font-size: clamp(2rem, 3vw, 4rem);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Home Features Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .home-features .contents {
    display: grid;
    align-items: center;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
  }
  .home-features .contents .desc {
    margin: 0 auto;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Card List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .card-list.card-list-flex {
    display: flex;
    align-items: stretch;
    gap: 0;
  }
  .card-list.card-list-flex .price-box {
    flex: 1;
    min-width: 0;
  }

  .box::before {
    font-size: 12rem;
    bottom: calc(-0.75 * var(--spacing-section-md));
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Overflow Card List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .overflow-card-list-stage {
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-gutter: stable;
  }
  .overflow-card-list-track {
    width: max-content;
    padding-bottom: var(--spacing-2xs);
  }
  .card-list.overflow-card-list {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: var(--spacing-sm);
    width: max-content;
    max-width: none;
  }
  .card-list.overflow-card-list .price-box {
    flex: 0 0 auto;
    width: clamp(20rem, 26vw, 25rem);
    min-width: 20rem;
  }
  .card-list.overflow-card-list .text {
    flex: auto;
  }
  .card-list.overflow-card-list .price.initial-price {
    font-size: .85em;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Price Content Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .price-content .price {
    font-size: var(--font-size-xl);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Works List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .works-list {
    grid-template-columns: repeat(3, 1fr);
  }
  .columns-list-card {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-xl);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Columns List Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .columns-list li {
    margin: 0;
    width: 100%;
  }
  .columns-list li + li {
    margin: 0;
  }
  .home-columns .columns-list li a .post-card-body,
  .page-section > .wrapper > .contents .columns-list li a .post-card-body {
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-sm);
  }
  .home-columns .columns-list li a .post-card-body .post-card-title,
  .page-section > .wrapper > .contents .columns-list li a .post-card-body .post-card-title {
    flex-grow: 1;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Sidebar Layout Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .page-section .sidebar-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--spacing-lg);
  }
  .page-section .sidebar-layout .sidebar {
    margin-top: 0;
  }
  .page-section .sidebar-layout .sidebar .contents {
    padding: var(--spacing-md);
  }
  .columns-single-page .columns-main > .works-img.images {
    margin-top: 0;
    margin-bottom: var(--spacing-md);
  }

  /* コラム詳細：左追従シェア */
  .columns-single-page .columns-main {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-md);
    align-items: start;
  }
  .columns-single-page .columns-main .works-img,
  .columns-single-page .columns-main .post-contents,
  .columns-single-page .columns-main .columns-author,
  .columns-single-page .columns-main .columns-end-cta,
  .columns-single-page .columns-main .columns-faq,
  .columns-single-page .columns-main .faq-content {
    grid-column: 2;
  }
  .columns-single-page .columns-main .works-img {
    grid-row: 1;
  }
  .columns-single-page .columns-main .columns-share {
    order: unset;
    grid-column: 1;
    grid-row: 1 / -1;
    margin: 0;
    align-self: start;
  }
  .columns-single-page .columns-main .columns-share.is-fixed {
    position: sticky;
    top: calc(var(--header-height) + var(--lu-admin-bar-height) + 2rem);
  }
  .columns-single-page .columns-main .columns-share h3 {
    display: none;
  }
  .columns-single-page .columns-main .columns-share .sns-share-box {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-xs);
  }
  .columns-single-page .columns-main .columns-share .sns-share-box a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    border: 1px solid var(--color-gray-300);
    border-radius: 50%;
    background: var(--color-white);
    transition: var(--transition-color);
  }
  .columns-single-page .columns-main .columns-share .sns-share-box .sns-title {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .columns-single-page .columns-main .columns-share .sns-share-box i {
    font-size: 1.25rem;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Contents Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .contents + .contents {
    margin-top: var(--spacing-section-page);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Access Flex Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .access-flex {
    display: grid;
    grid-template-columns: 2.5fr 3fr;
    gap: var(--spacing-xl);
  }
  .access-flex .images {
    margin-top: 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Sticky Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .sticky {
    position: sticky;
    top: calc(var(--header-height) + var(--lu-admin-bar-height) + 2rem);
    align-self: start;
    height: fit-content;
    margin-bottom: var(--spacing-lg);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Column Layout Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  .two-column-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
  }
  .two-column-layout.left {
    grid-template-columns: 1.5fr 1fr;
  }
  .two-column-layout.right {
    grid-template-columns: 1fr 1.5fr;
  }
  .two-column-layout.center {
    align-items: center;
  }
  .three-column-layout {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-lg);
  }
  .two-column-layout .contents,
  .three-column-layout .contents {
    margin-top: 0;
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Footer Styles
  +++++++++++++++++++++++++++++++++++++++++++++ */
  footer .footer-nav {
    grid-template-columns: 1fr;
    gap: var(--spacing-xl);
  }

  /* +++++++++++++++++++++++++++++++++++++++++++++
  Hover Animations
  +++++++++++++++++++++++++++++++++++++++++++++ */
  header .global-menu ul li a:hover {
    color: var(--color-secondary-dark);
  }
  header .global-menu ul li a:hover::after {
    transform: scale(1, 1)
  }
  .checkbox-field:hover .checkbox-field-box {
    border-color: var(--color-secondary-light);
  }
  .checkbox-field:has(input:checked):hover .checkbox-field-box {
    border-color: var(--color-secondary-dark);
    background: var(--color-secondary-dark);
  }
  .button a:hover,
  .button button:hover,
  .services-list-button a:hover,
  .block-button-list li a:hover {
    color: var(--color-on-primary);
  }
  .button a:hover::before,
  .button button:hover::before,
  .services-list-button a:hover::before,
  .block-button-list li a:hover::before {
    width: 100%;
    height: 100%;
    top: 0;
    transform: none;
    border-radius: var(--round-pill);
  }
  .button a:hover::after,
  .button button:hover::after,
  .services-list-button a:hover::after,
  .block-button-list li a:hover::after {
    transform: translate(calc(-50% + 0.125rem), -50%) rotate(-45deg);
  }
  .button.small[data-action="back"] a:hover::after {
    transform: translate(calc(-50% - 0.125rem), -50%) rotate(135deg);
  }
  header .header-logo a:hover {
    opacity: var(--opacity-muted);
  }
  .columns-list-card li a:hover .columns-img img {
    transform: scale(1.05);
  }
  .columns-list-card li a:hover .columns-title {
    color: var(--color-primary);
  }
  .columns-list li a:hover .post-thumbnail img {
    transform: scale(1.05);
  }
  .columns-list li a:hover {
    transform: translateY(-4px);
  }
  .columns-list li a:hover .post-card-title {
    color: var(--color-primary);
  }
  .sidebar-layout .sidebar .columns-list li a:hover {
    transform: none;
  }
  .cta .cta-buttons .button a:hover {
    background-color: var(--color-secondary);
    color: var(--color-on-primary);
    border-color: var(--color-on-primary);
  }
  .cta .cta-buttons .button a:hover::before {
    width: 300px;
    height: 300px;
    transform: translate(-50%, -50%);
  }
  a.to-top-button:hover {
    transform: scale(1.05);
  }
  .sticky-cta-tel:hover,
  .sticky-cta-mail:hover,
  .sticky-cta-chat:hover {
    opacity: 0.9;
  }
  .news-archive .news-list .news-content a:hover::after {
    width: 100%;
  }
  .news-archive .news-list .news-content a:hover {
    opacity: var(--opacity-muted);
  }
  p a:hover,
  .sitemap-list li a:hover,
  .list li a:hover,
  .home-news .news-list li a:hover,
  footer .footer-logo a:hover,
  .breadcrumbs ol li a:hover,
  .toc-nav li a:hover,
  .form-bottom-block .note a:hover,
  .sidebar-layout .sidebar li a:hover,
  .banner > a:hover {
    opacity: var(--opacity-muted);
  }
  .toc-nav li a:hover {
    color: var(--color-secondary-dark);
    text-decoration: underline;
  }
  .faq-content dt:hover {
    opacity: var(--opacity-muted);
  }
  .home-news .news-list li a:hover dt,
  .home-news .news-list li a:hover dd {
    color: var(--color-primary);
  }
  .archive-filter .list.grid-list li a:hover {
    color: var(--color-secondary-dark);
  }
  .archive-filter .list.grid-list li a.is-current:hover {
    color: var(--color-on-primary);
  }
  .works-list li a:hover .works-img img {
    opacity: var(--opacity-muted);
    transform: scale(1.05);
  }
  .works-list li a:hover .works-title {
    color: var(--color-primary);
  }
  .lawyer-list ul li a:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
    transform: translateY(-4px);
    box-shadow: var(--shadow-default);
  }
  .lawyer-list ul li a:hover::before {
    transform: scaleX(1);
  }
  footer .footer-legal-links li a:hover {
    color: var(--color-primary);
  }
  footer .footer-nav-list li a:hover {
    color: var(--color-secondary-light);
  }
  footer .footer-nav-list li a:hover::after {
    width: 100%;
  }
  .drawer-nav-trigger:hover .drawer-nav-en {
    opacity: 1;
    color: var(--color-secondary-pale);
  }
  .drawer-sub-list li a:hover {
    color: var(--color-secondary-pale);
  }
  .drawer-sub-list li a:hover::after {
    width: 100%;
  }
  .sidebar-layout .sidebar .list li a:hover {
    color: var(--color-secondary-dark);
  }
  nav.pagination .nav-links a.page-numbers:hover {
    background-color: var(--color-primary-super-pale);
    color: var(--color-primary);
  }
  .form-block input:not([type="submit"]):not([type="button"]):not([type="reset"]):hover:not(:disabled):not(:focus),
  .form-block select:hover:not(:disabled):not(:focus),
  .form-block textarea:hover:not(:disabled):not(:focus) {
    border-color: var(--color-gray-400);
  }
}

/* +++++++++++++++++++++++++++++++++++++++++++++
Member Card
+++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (max-width: 768px) {
  .member-card-list {
    grid-template-columns: 1fr;
  }
}

/* +++++++++++++++++++++++++++++++++++++++++++++
About Page
+++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (min-width: 900px) {
  .about-section.is-intro .about-section-ja {
    white-space: nowrap;
  }
}
@media screen and (max-width: 767px) {
  .about-services-inner {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  .about-toc {
    right: var(--spacing-xs);
  }
  .about-toc-list {
    gap: var(--spacing-sm);
  }
  .about-toc-track {
    padding-left: var(--spacing-2xs);
  }
  .about-toc-list li::before {
    width: 1px;
  }
  .about-toc-item {
    font-size: var(--font-size-xs);
    min-width: 1.25rem;
    text-align: center;
  }
}

/* +++++++++++++++++++++++++++++++++++++++++++++
簡易相談
+++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (max-width: 767px) {
  #chat-dialog.chat-dialog.dialog {
    right: 0;
    bottom: 0;
    left: 0;
    width: 100% !important;
    max-width: none !important;
    height: min(94dvh, 94vh);
    max-height: min(94dvh, 94vh);
    border-radius: 16px 16px 0 0;
  }
  #chat-dialog.chat-dialog.dialog.ready:not(.show) .chat-panel {
    opacity: 1;
    transform: translateY(100%);
  }
  #chat-dialog.chat-dialog.dialog.ready.show .chat-panel {
    opacity: 1;
    transform: translateY(0);
  }
  .chat-title {
    font-size: var(--font-size-md);
  }
  .chat-messages {
    flex: 1 1 0;
    min-height: 5rem;
    max-height: none;
    padding: var(--spacing-sm) var(--spacing-md);
    padding-top: var(--spacing-sm);
  }
  .chat-composer {
    max-height: min(52dvh, 52vh);
  }
  .chat-composer-pane {
    flex: 1 1 auto;
    min-height: 0;
    padding: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
    gap: var(--spacing-sm);
  }
  .chat-composer-error {
    padding-top: var(--spacing-xs);
  }
  .chat-composer-actions.buttons {
    flex-shrink: 0;
    padding: var(--spacing-sm) var(--spacing-md);
    padding-bottom: calc(var(--spacing-sm) + env(safe-area-inset-bottom, 0));
  }
}
