/**
 * ミライズレンタカー テーマ CSS
 *
 * プロトタイプ mirais_site_v12.html から抽出。
 * 全セレクタは `.mirais-theme` クラス内にスコープされており、WordPressテーマと共存可能。
 *
 * 使い方:
 *   <div class="mirais-theme">...</div>
 *
 * 必要なクラス:
 *   .mirais-theme            (ルート、スコープ用)
 *   .site-header / .site-nav / .header-actions / .lang-switcher / .currency-switcher
 *   .hero / .hero-inner / .hero-search / .search-row / .field
 *   .section / .section-inner / .section-head
 *   .features-grid / .feature-card / .feature-icon
 *   .car-class-tabs / .car-grid / .car-card / .car-image / .car-info / .car-emoji / .car-name / .car-spec / .car-price
 *   .reviews-grid / .review-card
 *   .cta-section / .cta-btn
 *   .site-footer / .footer-inner / .footer-cols / .footer-col
 *   .btn-next / .btn-reserve-header / .search-btn
 */


:root {
    --primary: #0F4C81;
    --primary-dark: #08315A;
    --primary-light: #E6F0FA;
    --accent: #00A3B4;
    --gold: #C9A55C;
    --text: #1B2738;
    --text-sub: #5C6B7F;
    --bg: #FFFFFF;
    --bg-alt: #F7F9FC;
    --border: #E2E8F0;
    --success: #198754;
    --danger: #D32F2F;
  }
.mirais-theme { font-family: -apple-system, BlinkMacSystemFont, 'Hiragino Sans', 'Helvetica Neue', Arial, sans-serif; color: var(--text); line-height: 1.7; background: var(--bg); -webkit-font-smoothing: antialiased; overflow-x: hidden; max-width: 100%; }

.mirais-theme a { color: var(--primary); text-decoration: none; }
.mirais-theme img { max-width: 100%; display: block; }
.mirais-theme h1, .mirais-theme h2, .mirais-theme h3, .mirais-theme h4 { font-weight: 600; letter-spacing: 0.02em; line-height: 1.3; }
.mirais-theme button { font-family: inherit; cursor: pointer; }

.mirais-theme .site-header { position: sticky; top: 0; background: rgba(255,255,255,0.95); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border); z-index: 100; }
.mirais-theme .header-inner { max-width: 1200px; margin: 0 auto; padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.mirais-theme .site-logo { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 18px; color: var(--primary); cursor: pointer; }
.mirais-theme .site-logo .logo-mark { width: 36px; height: 36px; background: var(--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; border-radius: 8px; letter-spacing: 0; }
.mirais-theme .site-nav { display: flex; gap: 28px; align-items: center; }
.mirais-theme .site-nav a { color: var(--text); font-size: 14px; font-weight: 500; cursor: pointer; transition: color 0.2s; }
.mirais-theme .site-nav a:hover { color: var(--primary); }
.mirais-theme .site-nav a.active { color: var(--primary); }
.mirais-theme .header-actions { display: flex; gap: 10px; align-items: center; }
.mirais-theme .lang-switcher { display: flex; gap: 2px; align-items: center; font-size: 12px; color: var(--text-sub); border: 1px solid var(--border); border-radius: 6px; padding: 3px; }
.mirais-theme .lang-switcher button { background: transparent; border: none; padding: 4px 10px; cursor: pointer; font-size: 12px; color: var(--text-sub); border-radius: 4px; }
.mirais-theme .lang-switcher button.active { background: var(--primary); color: #fff; }
.mirais-theme .btn-reserve-header { padding: 9px 22px; background: var(--primary); color: #fff; border: none; border-radius: 6px; font-size: 14px; font-weight: 500; }
.mirais-theme .btn-reserve-header:hover { background: var(--primary-dark); }
.mirais-theme .hamburger { display: none; background: transparent; border: none; padding: 8px; font-size: 20px; }

.mirais-theme .hero { position: relative; padding: 80px 20px 100px; background: linear-gradient(135deg, #0F4C81 0%, #06243F 100%); color: #fff; overflow: hidden; }
.mirais-theme .hero::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 80%, rgba(0,163,180,0.3), transparent 50%), radial-gradient(circle at 80% 20%, rgba(201,165,92,0.2), transparent 50%); }
.mirais-theme .hero-inner { max-width: 1200px; margin: 0 auto; position: relative; }
.mirais-theme .hero h1 { font-size: 44px; line-height: 1.25; margin-bottom: 20px; }
.mirais-theme .hero .sub { font-size: 18px; opacity: 0.9; margin-bottom: 40px; max-width: 560px; }
.mirais-theme .hero-search { background: #fff; color: var(--text); padding: 28px; border-radius: 12px; box-shadow: 0 8px 24px rgba(0,0,0,0.12); max-width: 900px; }
.mirais-theme .hero-search h3 { font-size: 16px; margin-bottom: 18px; }
.mirais-theme .search-row { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 14px; align-items: end; }
.mirais-theme .search-row .field { display: flex; flex-direction: column; gap: 6px; }
.mirais-theme .search-row .field label { font-size: 11px; color: var(--text-sub); font-weight: 500; }
.mirais-theme .search-row .field select, .mirais-theme .search-row .field input { padding: 10px 12px; border: 1px solid var(--border); border-radius: 6px; font-size: 14px; font-family: inherit; background: #fff; }
.mirais-theme .search-row .field input:focus, .mirais-theme .search-row .field select:focus { outline: none; border-color: var(--primary); }
.mirais-theme .search-btn { padding: 12px 28px; background: var(--accent); color: #fff; border: none; border-radius: 6px; font-size: 15px; font-weight: 600; white-space: nowrap; height: 44px; }
.mirais-theme .search-btn:hover { background: #008898; }

.mirais-theme .section { padding: 80px 20px; }
.mirais-theme .section-inner { max-width: 1200px; margin: 0 auto; }
.mirais-theme .section-head { text-align: center; margin-bottom: 50px; }
.mirais-theme .section-head .label { font-size: 12px; color: var(--accent); letter-spacing: 0.2em; font-weight: 600; margin-bottom: 10px; }
.mirais-theme .section-head h2 { font-size: 32px; margin-bottom: 16px; }
.mirais-theme .section-head p { font-size: 15px; color: var(--text-sub); max-width: 580px; margin: 0 auto; }
.mirais-theme .section.alt { background: var(--bg-alt); }

.mirais-theme .features-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.mirais-theme .feature-card { text-align: center; }
.mirais-theme .feature-icon { width: 72px; height: 72px; background: var(--primary-light); color: var(--primary); margin: 0 auto 18px; display: flex; align-items: center; justify-content: center; font-size: 32px; border-radius: 50%; }
.mirais-theme .feature-card h3 { font-size: 17px; margin-bottom: 10px; }
.mirais-theme .feature-card p { font-size: 13px; color: var(--text-sub); line-height: 1.7; }

.mirais-theme .car-class-tabs { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; margin-bottom: 36px; }
.mirais-theme .car-class-tabs button { padding: 9px 18px; background: #fff; border: 1px solid var(--border); border-radius: 24px; font-size: 13px; color: var(--text); }
.mirais-theme .car-class-tabs button.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.mirais-theme .car-class-tabs button:hover:not(.active) { border-color: var(--primary); color: var(--primary); }
.mirais-theme .car-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.mirais-theme .car-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; transition: all 0.2s; cursor: pointer; }
.mirais-theme .car-card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(15,76,129,0.10); border-color: var(--primary); }
.mirais-theme .car-image { background: linear-gradient(135deg, #E8EFF7 0%, #CDD9EA 100%); padding: 36px 20px; text-align: center; height: 180px; display: flex; align-items: center; justify-content: center; position: relative; }
.mirais-theme .car-emoji { font-size: 80px; filter: drop-shadow(0 4px 8px rgba(15,76,129,0.15)); }
.mirais-theme .car-class-tag { position: absolute; top: 12px; left: 12px; background: var(--primary); color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 10px; font-weight: 600; letter-spacing: 0.08em; }
.mirais-theme .car-info { padding: 18px 20px; }
.mirais-theme .car-name { font-size: 17px; font-weight: 600; margin-bottom: 6px; }
.mirais-theme .car-spec { font-size: 12px; color: var(--text-sub); margin-bottom: 14px; display: flex; gap: 12px; flex-wrap: wrap; }
.mirais-theme .car-price-row { display: flex; align-items: baseline; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--border); }
.mirais-theme .car-price { font-size: 22px; font-weight: 700; color: var(--primary); }
.mirais-theme .car-price .unit { font-size: 12px; font-weight: 400; color: var(--text-sub); margin-left: 4px; }

.mirais-theme .store-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.mirais-theme .store-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 24px; }
.mirais-theme .store-card .store-area { display: inline-block; padding: 3px 10px; background: var(--primary-light); color: var(--primary); border-radius: 4px; font-size: 11px; font-weight: 600; margin-bottom: 12px; }
.mirais-theme .store-card h3 { font-size: 18px; margin-bottom: 14px; }
.mirais-theme .store-card .info-row { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; font-size: 13px; color: var(--text-sub); }
.mirais-theme .store-card .info-row .icon { width: 16px; flex-shrink: 0; color: var(--primary); }

.mirais-theme .cta-section { padding: 80px 20px; background: var(--primary); color: #fff; text-align: center; }
.mirais-theme .cta-section h2 { font-size: 32px; margin-bottom: 16px; color: #fff; }
.mirais-theme .cta-section p { font-size: 16px; opacity: 0.9; margin-bottom: 30px; }
.mirais-theme .cta-btn { display: inline-block; padding: 16px 48px; background: var(--accent); color: #fff; border: none; border-radius: 8px; font-size: 16px; font-weight: 600; }
.mirais-theme .cta-btn:hover { background: #008898; }

.mirais-theme .reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.mirais-theme .review-card { background: #fff; padding: 24px; border: 1px solid var(--border); border-radius: 10px; }
.mirais-theme .review-stars { color: var(--gold); font-size: 16px; margin-bottom: 12px; letter-spacing: 0.05em; }
.mirais-theme .review-text { font-size: 13px; color: var(--text); line-height: 1.75; margin-bottom: 16px; min-height: 110px; }
.mirais-theme .review-meta { display: flex; align-items: center; gap: 10px; padding-top: 14px; border-top: 1px solid var(--border); font-size: 12px; color: var(--text-sub); }
.mirais-theme .review-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--primary-light); color: var(--primary); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 13px; }

.mirais-theme .site-footer { background: #06243F; color: #B8C5D6; padding: 60px 20px 30px; }
.mirais-theme .footer-inner { max-width: 1200px; margin: 0 auto; }
.mirais-theme .footer-cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.mirais-theme .footer-col h4 { font-size: 13px; color: #fff; margin-bottom: 16px; letter-spacing: 0.05em; }
.mirais-theme .footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.mirais-theme .footer-col ul li a { color: #B8C5D6; font-size: 12px; cursor: pointer; }
.mirais-theme .footer-col ul li a:hover { color: #fff; }
.mirais-theme .footer-logo { font-size: 18px; color: #fff; font-weight: 600; margin-bottom: 12px; }
.mirais-theme .footer-tagline { font-size: 12px; line-height: 1.7; margin-bottom: 16px; }
.mirais-theme .footer-contact { font-size: 12px; line-height: 1.8; }
.mirais-theme .footer-bottom { border-top: 1px solid #1B3A5A; padding-top: 20px; font-size: 11px; text-align: center; color: #6B7E96; }

.mirais-theme .page { display: none; }
.mirais-theme .page.active { display: block; }

.mirais-theme .breadcrumb-bar { background: var(--bg-alt); padding: 14px 20px; font-size: 12px; color: var(--text-sub); }
.mirais-theme .breadcrumb-bar .inner { max-width: 1200px; margin: 0 auto; }
.mirais-theme .breadcrumb-bar a { color: var(--text-sub); cursor: pointer; }
.mirais-theme .breadcrumb-bar a:hover { color: var(--primary); }
.mirais-theme .breadcrumb-bar .sep { margin: 0 8px; color: #C0CCDC; }

.mirais-theme .car-detail { padding: 50px 20px; }
.mirais-theme .car-detail-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 50px; }
.mirais-theme .car-detail-image { background: linear-gradient(135deg, #E8EFF7 0%, #CDD9EA 100%); border-radius: 16px; padding: 60px; text-align: center; min-height: 360px; display: flex; align-items: center; justify-content: center; }
.mirais-theme .car-detail-image .emoji-big { font-size: 180px; }
.mirais-theme .car-detail-info h1 { font-size: 30px; margin-bottom: 8px; }
.mirais-theme .car-detail-info .class-tag { display: inline-block; padding: 4px 12px; background: var(--primary); color: #fff; border-radius: 4px; font-size: 11px; font-weight: 600; margin-bottom: 14px; }
.mirais-theme .car-detail-info .description { font-size: 14px; color: var(--text-sub); margin-bottom: 24px; line-height: 1.8; }
.mirais-theme .car-detail-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; margin-bottom: 30px; padding: 20px; background: var(--bg-alt); border-radius: 8px; }
.mirais-theme .car-detail-specs .item { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.mirais-theme .car-detail-specs .item .ic { font-size: 20px; color: var(--primary); }
.mirais-theme .car-detail-specs .item .lbl { color: var(--text-sub); }
.mirais-theme .car-detail-specs .item .val { font-weight: 600; }
.mirais-theme .price-table { background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 20px; margin-bottom: 24px; }
.mirais-theme .price-table h3 { font-size: 14px; margin-bottom: 12px; }
.mirais-theme .price-table table { width: 100%; border-collapse: collapse; font-size: 13px; }
.mirais-theme .price-table td { padding: 7px 0; border-bottom: 1px solid #F0F4F8; }
.mirais-theme .price-table td:last-child { text-align: right; font-weight: 600; color: var(--primary); }
.mirais-theme .price-table tr:last-child td { border-bottom: none; }
.mirais-theme .reserve-btn-large { width: 100%; padding: 16px; background: var(--accent); color: #fff; border: none; border-radius: 8px; font-size: 16px; font-weight: 600; }
.mirais-theme .reserve-btn-large:hover { background: #008898; }
.mirais-theme .car-features-list { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 24px; }
.mirais-theme .car-features-list li { font-size: 13px; color: var(--text); padding-left: 22px; position: relative; }
.mirais-theme .car-features-list li::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; }

.mirais-theme .reserve-page { background: var(--bg-alt); padding: 40px 20px 80px; min-height: 80vh; }
.mirais-theme .reserve-inner { max-width: 900px; margin: 0 auto; }
.mirais-theme .reserve-stepper { display: flex; gap: 0; margin-bottom: 30px; background: #fff; padding: 20px; border-radius: 12px; }
.mirais-theme .reserve-step { flex: 1; display: flex; align-items: center; gap: 10px; opacity: 0.4; transition: opacity 0.3s; }
.mirais-theme .reserve-step.active { opacity: 1; }
.mirais-theme .reserve-step.done { opacity: 1; }
.mirais-theme .reserve-step.done .step-num { background: var(--success); }
.mirais-theme .reserve-step .step-num { width: 32px; height: 32px; background: #C0CCDC; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 600; flex-shrink: 0; }
.mirais-theme .reserve-step.active .step-num { background: var(--primary); }
.mirais-theme .reserve-step .step-label { font-size: 13px; font-weight: 500; }
.mirais-theme .reserve-content { background: #fff; padding: 36px; border-radius: 12px; }
.mirais-theme .reserve-content h2 { font-size: 22px; margin-bottom: 20px; }
.mirais-theme .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }
.mirais-theme .form-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.mirais-theme .form-field label { font-size: 12px; color: var(--text-sub); font-weight: 500; }
.mirais-theme .form-field label .req { color: var(--danger); }
.mirais-theme .form-field input, .mirais-theme .form-field select, .mirais-theme .form-field textarea { width: 100%; padding: 11px 14px; border: 1px solid var(--border); border-radius: 6px; font-size: 14px; font-family: inherit; background: #fff; box-sizing: border-box; min-width: 0; }
.mirais-theme .form-field input:focus, .mirais-theme .form-field select:focus, .mirais-theme .form-field textarea:focus { outline: none; border-color: var(--primary); }
.mirais-theme .form-field textarea { min-height: 90px; resize: vertical; }
.mirais-theme .reserve-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 30px; padding-top: 24px; border-top: 1px solid var(--border); }
.mirais-theme .btn-prev { padding: 11px 24px; background: #fff; border: 1px solid var(--border); border-radius: 6px; font-size: 14px; color: var(--text); }
.mirais-theme .btn-next { padding: 11px 32px; background: var(--primary); color: #fff; border: none; border-radius: 6px; font-size: 14px; font-weight: 500; }
.mirais-theme .btn-next:hover { background: var(--primary-dark); }
.mirais-theme .btn-submit { padding: 14px 40px; background: var(--accent); color: #fff; border: none; border-radius: 6px; font-size: 15px; font-weight: 600; }
.mirais-theme .btn-submit:hover { background: #008898; }
.mirais-theme .reserve-car-display { background: var(--bg-alt); padding: 18px; border-radius: 8px; display: flex; align-items: center; gap: 18px; margin-bottom: 24px; }
.mirais-theme .reserve-car-display .emoji { font-size: 56px; }
.mirais-theme .reserve-car-display .info { flex: 1; }
.mirais-theme .reserve-car-display .name { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.mirais-theme .reserve-car-display .spec { font-size: 12px; color: var(--text-sub); }
.mirais-theme .reserve-car-display .price { font-size: 20px; font-weight: 700; color: var(--primary); }

.mirais-theme .option-cat-block { margin-bottom: 24px; }
.mirais-theme .option-cat-block h4 { font-size: 14px; color: var(--text-sub); margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border); }
.mirais-theme .option-item { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--bg-alt); border-radius: 6px; margin-bottom: 6px; cursor: pointer; }
.mirais-theme .option-item:hover { background: #EBF2FA; }
.mirais-theme .option-item input[type=checkbox] { width: 18px; height: 18px; cursor: pointer; flex-shrink: 0; }
.mirais-theme .option-item .opt-info { flex: 1; }
.mirais-theme .option-item .opt-name { font-size: 13px; font-weight: 500; }
.mirais-theme .option-item .opt-desc { font-size: 11px; color: var(--text-sub); }
.mirais-theme .option-item .opt-price { font-size: 13px; font-weight: 600; color: var(--primary); }
.mirais-theme .option-item .opt-price.free { color: var(--success); }

.mirais-theme .confirm-section { margin-bottom: 24px; }
.mirais-theme .confirm-section h3 { font-size: 14px; margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border); color: var(--text-sub); }
.mirais-theme .confirm-row { display: grid; grid-template-columns: 140px 1fr; gap: 12px; padding: 6px 0; font-size: 13px; }
.mirais-theme .confirm-row .label { color: var(--text-sub); }
.mirais-theme .confirm-row .value { font-weight: 500; }
.mirais-theme .total-price-bar { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); color: #fff; padding: 20px 24px; border-radius: 10px; display: flex; justify-content: space-between; align-items: center; margin-top: 20px; }
.mirais-theme .total-price-bar .lbl { font-size: 14px; opacity: 0.9; }
.mirais-theme .total-price-bar .val { font-size: 30px; font-weight: 700; }
.mirais-theme .agreement-box { background: var(--bg-alt); padding: 14px; border-radius: 6px; font-size: 12px; margin: 18px 0; }
.mirais-theme .agreement-box label { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; }

.mirais-theme .complete-screen { text-align: center; padding: 60px 20px; background: #fff; border-radius: 12px; }
.mirais-theme .complete-icon { width: 100px; height: 100px; background: var(--success); color: #fff; border-radius: 50%; margin: 0 auto 24px; display: flex; align-items: center; justify-content: center; font-size: 56px; }
.mirais-theme .complete-screen h2 { font-size: 26px; margin-bottom: 12px; color: var(--success); }
.mirais-theme .complete-screen p { font-size: 14px; color: var(--text-sub); margin-bottom: 24px; }
.mirais-theme .complete-screen .reservation-no { background: var(--bg-alt); padding: 18px; border-radius: 8px; margin: 24px auto; max-width: 400px; }
.mirais-theme .complete-screen .reservation-no .lbl { font-size: 11px; color: var(--text-sub); margin-bottom: 4px; }
.mirais-theme .complete-screen .reservation-no .no { font-size: 22px; font-weight: 700; font-family: monospace; color: var(--primary); }

.mirais-theme .faq-list { max-width: 800px; margin: 0 auto; }
.mirais-theme .faq-item { background: #fff; border: 1px solid var(--border); border-radius: 10px; margin-bottom: 12px; overflow: hidden; }
.mirais-theme .faq-q { padding: 18px 24px; font-size: 14px; font-weight: 600; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 14px; list-style: none; }
.mirais-theme .faq-q::-webkit-details-marker { display: none; }
.mirais-theme .faq-q .arr { transition: transform 0.3s; color: var(--primary); }
/* v1.22.1: <details> open属性に対応 (旧.openクラスベース → 属性セレクタ) */
.mirais-theme .faq-item[open] .faq-q .arr,
.mirais-theme .faq-item.open .faq-q .arr { transform: rotate(180deg); }
.mirais-theme .faq-a { padding: 0 24px 18px; font-size: 13px; color: var(--text-sub); line-height: 1.8; border-top: 1px solid var(--border); padding-top: 14px; }

.mirais-theme .company-info { max-width: 800px; margin: 0 auto; }
.mirais-theme .company-table { width: 100%; border-collapse: collapse; }
.mirais-theme .company-table th, .mirais-theme .company-table td { padding: 14px 20px; text-align: left; border-bottom: 1px solid var(--border); font-size: 14px; }
.mirais-theme .company-table th { width: 200px; color: var(--text-sub); font-weight: 500; background: var(--bg-alt); }

.mirais-theme .mypage-inner { max-width: 900px; margin: 0 auto; padding: 40px 20px; }
.mirais-theme .mypage-header { display: flex; align-items: center; gap: 20px; padding: 24px; background: #fff; border-radius: 12px; margin-bottom: 24px; border: 1px solid var(--border); }
.mirais-theme .mypage-avatar { width: 72px; height: 72px; border-radius: 50%; background: var(--primary-light); color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 28px; font-weight: 700; }
.mirais-theme .mypage-user h2 { font-size: 20px; margin-bottom: 4px; }
.mirais-theme .mypage-user p { font-size: 13px; color: var(--text-sub); }
.mirais-theme .reservation-list-item { background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 18px 20px; margin-bottom: 10px; display: grid; grid-template-columns: 60px 1fr auto; gap: 16px; align-items: center; }
.mirais-theme .reservation-list-item .emoji { font-size: 36px; }
.mirais-theme .reservation-list-item .info .id { font-size: 11px; color: var(--text-sub); font-family: monospace; margin-bottom: 4px; }
.mirais-theme .reservation-list-item .info .name { font-size: 15px; font-weight: 600; margin-bottom: 4px; }
.mirais-theme .reservation-list-item .info .period { font-size: 12px; color: var(--text-sub); }
.mirais-theme .reservation-list-item .status-tag { padding: 4px 10px; border-radius: 4px; font-size: 11px; font-weight: 500; }
.mirais-theme .reservation-list-item .status-tag.upcoming { background: var(--primary-light); color: var(--primary); }
.mirais-theme .reservation-list-item .status-tag.done { background: #E8F5E9; color: var(--success); }
.mirais-theme .reservation-list-item .status-tag.cancelled { background: #FFEBEE; color: var(--danger); }

@media (max-width: 900px) {
  .mirais-theme .site-nav { display: none; }
  .mirais-theme .hamburger { display: block; }
  .mirais-theme .hero h1 { font-size: 30px; }
  .mirais-theme .hero .sub { font-size: 15px; }
  .mirais-theme .search-row { grid-template-columns: 1fr; }
  .mirais-theme .hero { padding: 50px 20px 60px; }
  .mirais-theme .section { padding: 50px 20px; }
  .mirais-theme .section-head h2 { font-size: 24px; }
  .mirais-theme .features-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .mirais-theme .car-grid { grid-template-columns: 1fr; }
  .mirais-theme .store-grid { grid-template-columns: 1fr; }
  .mirais-theme .reviews-grid { grid-template-columns: 1fr; }
  .mirais-theme .footer-cols { grid-template-columns: 1fr 1fr; gap: 24px; }
  .mirais-theme .car-detail-inner { grid-template-columns: 1fr; gap: 30px; }
  .mirais-theme .car-detail-image { padding: 30px; min-height: 220px; }
  .mirais-theme .car-detail-image .emoji-big { font-size: 120px; }
  .mirais-theme .form-row { grid-template-columns: 1fr; gap: 14px; margin-bottom: 14px; }
  .mirais-theme .form-field input, .mirais-theme .form-field select, .mirais-theme .form-field textarea { font-size: 16px; padding: 10px 12px; }
  .mirais-theme .reserve-page { padding: 20px 12px 60px; }
  .mirais-theme .reserve-stepper { padding: 14px; flex-wrap: wrap; gap: 8px; }
  .mirais-theme .reserve-stepper .step-label { display: none; }
  .mirais-theme .reserve-content { padding: 16px; }
  .mirais-theme .reserve-content h2 { font-size: 18px; margin-bottom: 14px; }
  .mirais-theme .reserve-car-display { flex-direction: column; text-align: center; gap: 10px; padding: 14px; }
  .mirais-theme .reserve-car-display .price { font-size: 18px; }
  .mirais-theme .reserve-login-hint { padding: 12px; gap: 10px; flex-wrap: wrap; }
  .mirais-theme .reserve-login-hint .ic { font-size: 18px; }
  .mirais-theme .reserve-login-hint .text { font-size: 12px; flex: 1 1 100%; }
  .mirais-theme .flight-lookup-row input { font-size: 13px; padding: 10px 12px; letter-spacing: 0; }
  .mirais-theme .flight-lookup-row input::placeholder { font-size: 11px; }
  .mirais-theme .flight-lookup-row button { padding: 10px 12px; font-size: 12px; }
  .mirais-theme .signup-extra-fields { padding: 14px; margin-top: 14px; }
  .mirais-theme .signup-extra-fields .head h4 { font-size: 13px; }
  .mirais-theme .signup-extra-fields .head p { font-size: 10px; }
    /* 「grid-column:span 2」がスマホで効かないように */
  .mirais-theme .reserve-content .form-field[style*="grid-column"] { grid-column: auto !important; }
  .mirais-theme .car-detail-specs { grid-template-columns: 1fr; }
  .mirais-theme .car-features-list { grid-template-columns: 1fr; }
  .mirais-theme .cta-section h2 { font-size: 24px; }
  .mirais-theme .lang-switcher button { padding: 3px 6px; font-size: 11px; }
  .mirais-theme .btn-reserve-header { padding: 8px 14px; font-size: 12px; }
  .mirais-theme .header-inner { padding: 12px 10px; gap: 6px; flex-wrap: wrap; }
  .mirais-theme .site-logo { font-size: 14px; flex-shrink: 0; }
  .mirais-theme .site-logo .logo-mark { width: 30px; height: 30px; font-size: 14px; }
  .mirais-theme .header-actions { gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
  }

@media (max-width: 500px) {
  .mirais-theme .site-logo span:not(.logo-mark) { display: none; }
  .mirais-theme .lang-switcher { padding: 2px; gap: 0; }
  .mirais-theme .lang-switcher button { padding: 3px 5px; font-size: 10px; }
  }

.mirais-theme .back-to-admin { position: fixed; bottom: 20px; right: 20px; padding: 10px 18px; background: rgba(0,0,0,0.7); color: #fff !important; border-radius: 30px; font-size: 12px; cursor: pointer; box-shadow: 0 4px 12px rgba(0,0,0,0.15); z-index: 200; backdrop-filter: blur(4px); text-decoration: none; display: inline-block; }
.mirais-theme .back-to-admin:hover { background: rgba(0,0,0,0.9); }

  /* ===== 認証モーダル ===== */
.mirais-theme .auth-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); display: none; align-items: center; justify-content: center; z-index: 500; padding: 20px; }
.mirais-theme .auth-overlay.open { display: flex; }
.mirais-theme .auth-modal { background: #fff; border-radius: 16px; padding: 40px; width: 100%; max-width: 480px; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.2); position: relative; }
.mirais-theme .auth-header { text-align: center; margin-bottom: 28px; }
.mirais-theme .auth-header .logo-mark { width: 56px; height: 56px; background: var(--primary); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 24px; font-weight: 700; border-radius: 12px; margin-bottom: 14px; }
.mirais-theme .auth-header h2 { font-size: 22px; margin-bottom: 6px; }
.mirais-theme .auth-header p { font-size: 13px; color: var(--text-sub); }
.mirais-theme .auth-field { margin-bottom: 16px; }
.mirais-theme .auth-field label { display: block; font-size: 12px; color: var(--text-sub); font-weight: 500; margin-bottom: 6px; }
.mirais-theme .auth-field label .req { color: var(--danger); margin-left: 2px; }
.mirais-theme .auth-field input, .mirais-theme .auth-field select { width: 100%; padding: 12px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 14px; font-family: inherit; background: #fff; }
.mirais-theme .auth-field input:focus, .mirais-theme .auth-field select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(15,76,129,0.1); }
.mirais-theme .auth-field .help { font-size: 11px; color: var(--text-sub); margin-top: 4px; }
.mirais-theme .auth-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mirais-theme .auth-btn-primary { width: 100%; padding: 14px; background: var(--primary); color: #fff; border: none; border-radius: 8px; font-size: 15px; font-weight: 600; margin-top: 8px; }
.mirais-theme .auth-btn-primary:hover { background: var(--primary-dark); }
.mirais-theme .auth-switch { text-align: center; font-size: 13px; color: var(--text-sub); margin-top: 14px; }
.mirais-theme .auth-switch a { color: var(--primary); font-weight: 600; cursor: pointer; }
.mirais-theme .auth-close { position: absolute; top: 16px; right: 16px; background: transparent; border: none; font-size: 24px; color: var(--text-sub); cursor: pointer; padding: 4px 10px; border-radius: 6px; line-height: 1; }
.mirais-theme .auth-close:hover { background: var(--bg-alt); }
.mirais-theme .benefit-box { background: linear-gradient(135deg, #E6F0FA 0%, #F0F7FF 100%); border: 1px solid var(--primary-light); border-radius: 10px; padding: 16px; margin-bottom: 20px; }
.mirais-theme .benefit-box h4 { font-size: 13px; color: var(--primary); margin-bottom: 10px; }
.mirais-theme .benefit-box ul { list-style: none; padding: 0; }
.mirais-theme .benefit-box ul li { font-size: 12px; padding: 4px 0 4px 22px; position: relative; color: var(--text); }
.mirais-theme .benefit-box ul li::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; }
.mirais-theme .agree-row { display: flex; align-items: flex-start; gap: 8px; font-size: 12px; color: var(--text-sub); margin-bottom: 16px; cursor: pointer; }
.mirais-theme .agree-row input { margin-top: 3px; flex-shrink: 0; }

  /* ヘッダーの未ログイン・ログイン済表示 */
.mirais-theme .header-auth-buttons { display: flex; gap: 8px; align-items: center; }
.mirais-theme .btn-login-header { padding: 7px 14px; background: transparent; color: var(--text); border: 1px solid var(--border); border-radius: 6px; font-size: 13px; cursor: pointer; }
.mirais-theme .btn-login-header:hover { border-color: var(--primary); color: var(--primary); }
.mirais-theme .btn-signup-header { padding: 7px 14px; background: var(--bg-alt); color: var(--text); border: 1px solid var(--border); border-radius: 6px; font-size: 13px; cursor: pointer; font-weight: 500; }
.mirais-theme .btn-signup-header:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

.mirais-theme .user-menu { display: flex; align-items: center; gap: 8px; padding: 6px 12px; border: 1px solid var(--border); border-radius: 24px; cursor: pointer; transition: all 0.2s; position: relative; }
.mirais-theme .user-menu:hover { border-color: var(--primary); background: var(--primary-light); }
.mirais-theme .user-menu .avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; }
.mirais-theme .user-menu .name { font-size: 13px; font-weight: 500; color: var(--text); }
.mirais-theme .user-menu .arrow { font-size: 10px; color: var(--text-sub); }
.mirais-theme .user-dropdown { position: absolute; top: 100%; right: 0; margin-top: 8px; background: #fff; border: 1px solid var(--border); border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 200px; display: none; z-index: 110; overflow: hidden; }
.mirais-theme .user-dropdown.open { display: block; }
.mirais-theme .user-dropdown a { display: flex; align-items: center; gap: 10px; padding: 12px 18px; font-size: 13px; color: var(--text); cursor: pointer; }
.mirais-theme .user-dropdown a:hover { background: var(--bg-alt); }
.mirais-theme .user-dropdown a.danger { color: var(--danger); border-top: 1px solid var(--border); }

.mirais-theme .login-required { text-align: center; padding: 80px 20px; background: var(--bg-alt); border-radius: 12px; }
.mirais-theme .login-required .ic { font-size: 56px; margin-bottom: 16px; }
.mirais-theme .login-required h3 { font-size: 20px; margin-bottom: 10px; }
.mirais-theme .login-required p { font-size: 14px; color: var(--text-sub); margin-bottom: 24px; max-width: 400px; margin-left: auto; margin-right: auto; }
.mirais-theme .login-required .btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

  /* 予約フォームのログイン誘導 */
.mirais-theme .reserve-login-hint { background: var(--primary-light); border: 1px solid var(--primary); border-radius: 8px; padding: 14px 18px; margin-bottom: 20px; display: flex; gap: 12px; align-items: center; }
.mirais-theme .reserve-login-hint .ic { font-size: 22px; }
.mirais-theme .reserve-login-hint .text { flex: 1; font-size: 13px; color: var(--primary-dark); }
.mirais-theme .reserve-login-hint .text strong { display: block; margin-bottom: 2px; }
.mirais-theme .reserve-login-hint button { padding: 8px 16px; background: var(--primary); color: #fff; border: none; border-radius: 6px; font-size: 13px; cursor: pointer; font-weight: 500; }
.mirais-theme .reserve-login-hint button:hover { background: var(--primary-dark); }

  /* ===== Phase 2: 事前サイン ===== */
.mirais-theme .presign-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.85); display: none; align-items: center; justify-content: center; z-index: 600; padding: 0; }
.mirais-theme .presign-overlay.open { display: flex; }
.mirais-theme .presign-screen { background: #fff; width: 100%; max-width: 800px; height: 95vh; border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; }
.mirais-theme .presign-head { padding: 16px 24px; background: var(--primary); color: #fff; display: flex; justify-content: space-between; align-items: center; }
.mirais-theme .presign-head h2 { font-size: 17px; margin: 0; }
.mirais-theme .presign-head .close-btn { background: rgba(255,255,255,0.15); border: none; color: #fff; padding: 6px 14px; border-radius: 4px; cursor: pointer; font-size: 13px; }
.mirais-theme .presign-stepper { display: flex; padding: 14px 24px; background: var(--bg-alt); border-bottom: 1px solid var(--border); gap: 0; }
.mirais-theme .presign-step { flex: 1; display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-sub); }
.mirais-theme .presign-step.active { color: var(--primary); font-weight: 600; }
.mirais-theme .presign-step.done { color: var(--success); }
.mirais-theme .presign-step-num { width: 26px; height: 26px; border-radius: 50%; background: var(--border); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; flex-shrink: 0; }
.mirais-theme .presign-step.active .presign-step-num { background: var(--primary); }
.mirais-theme .presign-step.done .presign-step-num { background: var(--success); }
.mirais-theme .presign-body { flex: 1; overflow-y: auto; padding: 24px; }
.mirais-theme .presign-foot { padding: 16px 24px; background: var(--bg-alt); border-top: 1px solid var(--border); display: flex; justify-content: space-between; gap: 10px; }
.mirais-theme .license-upload-area { background: var(--bg-alt); border: 2px dashed var(--border); border-radius: 10px; padding: 40px 20px; text-align: center; cursor: pointer; transition: all 0.2s; }
.mirais-theme .license-upload-area:hover { border-color: var(--primary); background: var(--primary-light); }
.mirais-theme .license-upload-area.uploaded { border-color: var(--success); background: #E8F5E9; }
.mirais-theme .license-upload-area .icon { font-size: 48px; margin-bottom: 12px; }
.mirais-theme .license-upload-area .label { font-size: 14px; font-weight: 600; margin-bottom: 6px; }
.mirais-theme .license-upload-area .hint { font-size: 11px; color: var(--text-sub); }
.mirais-theme .sign-canvas-wrap { background: #fff; border: 1px solid var(--primary); border-radius: 8px; overflow: hidden; }
.mirais-theme .sign-canvas-label { padding: 10px 14px; background: var(--primary-light); border-bottom: 1px solid var(--primary); font-size: 13px; font-weight: 500; color: var(--primary-dark); display: flex; justify-content: space-between; align-items: center; }
.mirais-theme .sign-canvas-label .clear-btn { background: #fff; border: 1px solid var(--border); padding: 4px 12px; border-radius: 4px; cursor: pointer; font-size: 11px; }
.mirais-theme .sign-canvas { width: 100%; height: 180px; background: #fff; display: block; touch-action: none; cursor: crosshair; }
.mirais-theme .sign-status-bar { padding: 8px 14px; background: var(--bg-alt); border-top: 1px solid var(--border); font-size: 11px; display: flex; justify-content: space-between; }

  /* Phase 2: 写真ギャラリー */
.mirais-theme .photo-gallery { display: flex; flex-direction: column; gap: 12px; }
.mirais-theme .photo-main { background: linear-gradient(135deg, #E8EFF7 0%, #CDD9EA 100%); border-radius: 12px; padding: 60px 20px; text-align: center; min-height: 320px; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; }
.mirais-theme .photo-main .emoji-huge { font-size: 160px; line-height: 1; }
.mirais-theme .photo-main .photo-caption { position: absolute; bottom: 14px; left: 14px; background: rgba(0,0,0,0.6); color: #fff; padding: 6px 12px; border-radius: 4px; font-size: 11px; }
.mirais-theme .photo-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.mirais-theme .photo-thumb { background: linear-gradient(135deg, #E8EFF7 0%, #CDD9EA 100%); border-radius: 8px; padding: 20px 8px; text-align: center; cursor: pointer; border: 2px solid transparent; transition: all 0.2s; }
.mirais-theme .photo-thumb:hover { border-color: var(--primary); }
.mirais-theme .photo-thumb.active { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-light); }
.mirais-theme .photo-thumb .emoji-thumb { font-size: 32px; line-height: 1; margin-bottom: 4px; }
.mirais-theme .photo-thumb .label { font-size: 9px; color: var(--text-sub); }

  /* Phase 2: クーポン */
.mirais-theme .coupon-section { background: linear-gradient(135deg, #FFF8E1 0%, #FFE0B2 100%); border: 1px solid #FFB300; border-radius: 10px; padding: 16px 18px; margin-bottom: 18px; }
.mirais-theme .coupon-section h4 { font-size: 13px; color: #B26A00; margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.mirais-theme .coupon-row { display: flex; gap: 8px; align-items: center; }
.mirais-theme .coupon-row input { flex: 1; padding: 10px 12px; border: 1px solid #FFB300; border-radius: 6px; font-size: 14px; font-family: monospace; text-transform: uppercase; background: #fff; }
.mirais-theme .coupon-row button { padding: 10px 18px; background: #B26A00; color: #fff; border: none; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; white-space: nowrap; }
.mirais-theme .coupon-row button:hover { background: #8C5500; }
.mirais-theme .coupon-applied { padding: 10px 14px; background: var(--success); color: #fff; border-radius: 6px; font-size: 12px; display: flex; justify-content: space-between; align-items: center; margin-top: 10px; }
.mirais-theme .coupon-applied button { background: rgba(255,255,255,0.2); border: none; color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 11px; cursor: pointer; }
.mirais-theme .coupon-suggestions { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.mirais-theme .coupon-chip { padding: 4px 10px; background: rgba(255,255,255,0.7); border: 1px solid #FFB300; border-radius: 14px; font-size: 11px; cursor: pointer; color: #B26A00; font-family: monospace; }
.mirais-theme .coupon-chip:hover { background: #fff; }

  /* Phase 2: 地図 */
.mirais-theme .map-container { background: linear-gradient(135deg, #DCEEFE 0%, #BFDBF7 100%); border-radius: 10px; overflow: hidden; position: relative; margin-bottom: 16px; }
.mirais-theme .map-placeholder { padding: 0; position: relative; height: 280px; background-image: linear-gradient(rgba(255,255,255,0.4) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.4) 1px, transparent 1px); background-size: 30px 30px; display: flex; align-items: center; justify-content: center; }
.mirais-theme .map-pin { position: absolute; font-size: 36px; transform: translate(-50%, -100%); filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }
.mirais-theme .map-overlay { position: absolute; top: 12px; right: 12px; background: rgba(255,255,255,0.95); padding: 8px 12px; border-radius: 6px; font-size: 11px; color: var(--text-sub); box-shadow: 0 2px 6px rgba(0,0,0,0.1); }
.mirais-theme .map-controls { position: absolute; bottom: 12px; right: 12px; display: flex; flex-direction: column; gap: 4px; }
.mirais-theme .map-controls button { width: 32px; height: 32px; background: #fff; border: 1px solid var(--border); border-radius: 4px; cursor: pointer; font-size: 16px; font-weight: 600; box-shadow: 0 2px 6px rgba(0,0,0,0.1); }
.mirais-theme .map-info { padding: 14px 18px; background: #fff; }
.mirais-theme .map-info .row { display: flex; align-items: center; gap: 10px; font-size: 12px; margin-bottom: 6px; }
.mirais-theme .map-info .row .ic { color: var(--primary); width: 16px; flex-shrink: 0; }
.mirais-theme .map-info .directions-btn { display: inline-block; margin-top: 8px; padding: 8px 14px; background: var(--primary); color: #fff; border-radius: 6px; font-size: 12px; text-decoration: none; }

@media (max-width: 900px) {
  .mirais-theme .auth-modal { padding: 28px 20px; }
  .mirais-theme .auth-row2 { grid-template-columns: 1fr; }
  .mirais-theme .user-menu .name { display: none; }
  .mirais-theme .header-auth-buttons { gap: 4px; }
  .mirais-theme .btn-login-header, .mirais-theme .btn-signup-header { padding: 6px 10px; font-size: 12px; }
  .mirais-theme .presign-screen { max-width: 100%; max-height: 100vh; height: 100vh; border-radius: 0; }
  .mirais-theme .presign-body { padding: 14px; }
  .mirais-theme .photo-thumbs { grid-template-columns: repeat(3, 1fr); }
  .mirais-theme .photo-main { padding: 30px 16px; min-height: 220px; }
  .mirais-theme .photo-main .emoji-huge { font-size: 100px; }
  }

  /* ===== Phase 3: 電話・チャット予約 ===== */
.mirais-theme .contact-channels-section { background: var(--bg-alt); padding: 50px 20px; }
.mirais-theme .contact-channels-inner { max-width: 900px; margin: 0 auto; }
.mirais-theme .contact-channels-head { text-align: center; margin-bottom: 30px; }
.mirais-theme .contact-channels-head h2 { font-size: 26px; margin-bottom: 10px; }
.mirais-theme .contact-channels-head p { font-size: 14px; color: var(--text-sub); }
.mirais-theme .phone-cta { background: linear-gradient(135deg, #FFB300 0%, #F57C00 100%); color: #fff; border-radius: 12px; padding: 24px 30px; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; gap: 20px; box-shadow: 0 6px 20px rgba(245,124,0,0.25); cursor: pointer; text-decoration: none; transition: transform 0.2s; }
.mirais-theme .phone-cta:hover { transform: translateY(-2px); }
.mirais-theme .phone-cta .ic { font-size: 38px; }
.mirais-theme .phone-cta .text { text-align: left; }
.mirais-theme .phone-cta .lbl { font-size: 13px; opacity: 0.9; margin-bottom: 4px; }
.mirais-theme .phone-cta .num { font-size: 28px; font-weight: 700; letter-spacing: 0.04em; font-family: 'Courier New', monospace; }
.mirais-theme .phone-cta .hours { font-size: 11px; opacity: 0.85; margin-top: 4px; }
.mirais-theme .chat-channels-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.mirais-theme .chat-channel-card { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 18px 16px; text-align: center; cursor: pointer; transition: all 0.2s; }
.mirais-theme .chat-channel-card:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,76,129,0.1); }
.mirais-theme .chat-channel-card.line { border-top: 4px solid #06C755; }
.mirais-theme .chat-channel-card.kakao { border-top: 4px solid #FEE500; }
.mirais-theme .chat-channel-card.whatsapp { border-top: 4px solid #25D366; }
.mirais-theme .chat-channel-card.wechat { border-top: 4px solid #07C160; }
.mirais-theme .chat-channel-card.messenger { border-top: 4px solid #0084FF; }
.mirais-theme .chat-channel-card .ic { font-size: 36px; margin-bottom: 8px; }
.mirais-theme .chat-channel-card .name { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
.mirais-theme .chat-channel-card .lang-hint { font-size: 10px; color: var(--text-sub); margin-bottom: 8px; }
.mirais-theme .chat-channel-card .qr-mini { width: 80px; height: 80px; margin: 0 auto; background-image: repeating-linear-gradient(0deg, #000 0px, #000 2px, transparent 2px, transparent 4px), repeating-linear-gradient(90deg, #000 0px, #000 2px, transparent 2px, transparent 4px); background-color: #fff; border: 1px solid var(--border); position: relative; margin-bottom: 6px; }
.mirais-theme .chat-channel-card .qr-mini .qr-ic { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: #fff; padding: 6px; border-radius: 50%; font-size: 18px; line-height: 1; }
.mirais-theme .chat-channel-card.line .qr-mini .qr-ic { color: #06C755; }
.mirais-theme .chat-channel-card.kakao .qr-mini .qr-ic { color: #3C1E1E; }
.mirais-theme .chat-channel-card.whatsapp .qr-mini .qr-ic { color: #25D366; }
.mirais-theme .chat-channel-card.wechat .qr-mini .qr-ic { color: #07C160; }
.mirais-theme .chat-channel-card .open-btn { display: inline-block; padding: 6px 14px; background: var(--primary); color: #fff; border-radius: 4px; font-size: 11px; font-weight: 500; text-decoration: none; margin-top: 4px; }

  /* QRモーダル */
.mirais-theme .qr-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: none; align-items: center; justify-content: center; z-index: 700; padding: 20px; }
.mirais-theme .qr-modal-overlay.open { display: flex; }
.mirais-theme .qr-modal { background: #fff; border-radius: 16px; padding: 32px; max-width: 380px; width: 100%; text-align: center; position: relative; }
.mirais-theme .qr-modal-close { position: absolute; top: 12px; right: 12px; background: var(--bg-alt); border: none; padding: 6px 12px; border-radius: 6px; cursor: pointer; font-size: 18px; line-height: 1; }
.mirais-theme .qr-big { width: 240px; height: 240px; margin: 14px auto; background-image: repeating-linear-gradient(0deg, #000 0px, #000 3px, transparent 3px, transparent 6px), repeating-linear-gradient(90deg, #000 0px, #000 3px, transparent 3px, transparent 6px); background-color: #fff; border: 1px solid var(--border); position: relative; }
.mirais-theme .qr-big .qr-ic-big { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: #fff; padding: 14px; border-radius: 12px; font-size: 44px; line-height: 1; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }

  /* ===== Phase 3: 通貨切替 ===== */
.mirais-theme .currency-switcher { display: flex; align-items: center; gap: 2px; border: 1px solid var(--border); border-radius: 6px; padding: 3px; background: #fff; }
.mirais-theme .currency-switcher button { background: transparent; border: none; padding: 4px 8px; cursor: pointer; font-size: 11px; color: var(--text-sub); border-radius: 4px; font-weight: 500; }
.mirais-theme .currency-switcher button.active { background: var(--primary); color: #fff; }

  /* ===== Phase 3: ライブチャット ===== */
.mirais-theme .live-chat-bubble { position: fixed; bottom: 80px; right: 20px; width: 60px; height: 60px; background: linear-gradient(135deg, #0F4C81 0%, #08315A 100%); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 26px; cursor: pointer; box-shadow: 0 4px 16px rgba(15,76,129,0.4); z-index: 200; transition: transform 0.2s; border: none; }
.mirais-theme .live-chat-bubble:hover { transform: scale(1.05); }
.mirais-theme .live-chat-bubble.has-notification::after { content: ''; position: absolute; top: 8px; right: 8px; width: 12px; height: 12px; background: var(--danger); border-radius: 50%; border: 2px solid #fff; }
.mirais-theme .live-chat-panel { position: fixed; bottom: 150px; right: 20px; width: 360px; max-width: calc(100vw - 40px); height: 480px; max-height: calc(100vh - 200px); background: #fff; border-radius: 16px; box-shadow: 0 20px 50px rgba(0,0,0,0.2); display: none; flex-direction: column; overflow: hidden; z-index: 200; }
.mirais-theme .live-chat-panel.open { display: flex; }
.mirais-theme .live-chat-head { background: linear-gradient(135deg, #0F4C81 0%, #08315A 100%); color: #fff; padding: 14px 18px; display: flex; justify-content: space-between; align-items: center; }
.mirais-theme .live-chat-head .title { font-size: 14px; font-weight: 600; }
.mirais-theme .live-chat-head .status { font-size: 11px; opacity: 0.9; display: flex; align-items: center; gap: 4px; }
.mirais-theme .live-chat-head .status .dot { width: 8px; height: 8px; background: #4CAF50; border-radius: 50%; }
.mirais-theme .live-chat-head .close { background: transparent; border: none; color: #fff; cursor: pointer; font-size: 22px; line-height: 1; padding: 2px 6px; border-radius: 4px; }
.mirais-theme .live-chat-body { flex: 1; overflow-y: auto; padding: 18px; background: var(--bg-alt); }
.mirais-theme .chat-msg { margin-bottom: 12px; display: flex; gap: 8px; }
.mirais-theme .chat-msg.bot { align-items: flex-end; }
.mirais-theme .chat-msg.user { flex-direction: row-reverse; }
.mirais-theme .chat-msg .avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
.mirais-theme .chat-msg.user .avatar { background: var(--accent); }
.mirais-theme .chat-msg .bubble { background: #fff; padding: 10px 14px; border-radius: 12px; max-width: 240px; font-size: 13px; line-height: 1.6; box-shadow: 0 1px 2px rgba(0,0,0,0.05); }
.mirais-theme .chat-msg.user .bubble { background: var(--primary); color: #fff; }
.mirais-theme .chat-msg .time { font-size: 10px; color: var(--text-sub); margin-top: 2px; }
.mirais-theme .chat-quick-replies { display: flex; flex-wrap: wrap; gap: 6px; padding: 10px 14px; background: var(--bg-alt); border-top: 1px solid var(--border); }
.mirais-theme .chat-quick-replies button { padding: 6px 12px; background: #fff; border: 1px solid var(--primary); color: var(--primary); border-radius: 14px; font-size: 11px; cursor: pointer; }
.mirais-theme .chat-quick-replies button:hover { background: var(--primary); color: #fff; }
.mirais-theme .live-chat-foot { padding: 12px 14px; background: #fff; border-top: 1px solid var(--border); display: flex; gap: 8px; }
.mirais-theme .live-chat-foot input { flex: 1; padding: 10px 12px; border: 1px solid var(--border); border-radius: 20px; font-size: 13px; }
.mirais-theme .live-chat-foot button { padding: 10px 16px; background: var(--primary); color: #fff; border: none; border-radius: 20px; font-size: 13px; cursor: pointer; }

  /* ===== Phase 3: 会員ランクカード ===== */
.mirais-theme .rank-card { background: linear-gradient(135deg, #1B355F 0%, #0F4C81 100%); color: #fff; border-radius: 12px; padding: 20px; margin-bottom: 18px; position: relative; overflow: hidden; }
.mirais-theme .rank-card.gold { background: linear-gradient(135deg, #B07B0E 0%, #DAA520 100%); }
.mirais-theme .rank-card.platinum { background: linear-gradient(135deg, #4A4A4A 0%, #888 100%); }
.mirais-theme .rank-card.bronze { background: linear-gradient(135deg, #8B4513 0%, #CD7F32 100%); }
.mirais-theme .rank-card::before { content: ''; position: absolute; top: -40px; right: -40px; width: 180px; height: 180px; background: rgba(255,255,255,0.07); border-radius: 50%; }
.mirais-theme .rank-card .rank-label { font-size: 10px; opacity: 0.85; letter-spacing: 0.15em; margin-bottom: 4px; }
.mirais-theme .rank-card .rank-name { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.mirais-theme .rank-card .rank-info { font-size: 12px; opacity: 0.9; margin-bottom: 14px; }
.mirais-theme .rank-card .points-row { display: flex; justify-content: space-between; align-items: baseline; padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.2); }
.mirais-theme .rank-card .points-row .pts { font-size: 26px; font-weight: 700; font-variant-numeric: tabular-nums; }
.mirais-theme .rank-card .points-row .next { font-size: 11px; opacity: 0.85; text-align: right; }
.mirais-theme .rank-progress { background: rgba(255,255,255,0.2); height: 5px; border-radius: 3px; margin-top: 8px; overflow: hidden; }
.mirais-theme .rank-progress .fill { background: #fff; height: 100%; transition: width 0.5s; }

  /* ===== Phase 3: SNSログインボタン ===== */
.mirais-theme .social-login-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 14px; }
.mirais-theme .social-login-btn { padding: 10px; border: 1px solid var(--border); border-radius: 8px; background: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 6px; font-size: 12px; font-weight: 500; transition: all 0.2s; }
.mirais-theme .social-login-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 10px rgba(0,0,0,0.08); }
.mirais-theme .social-login-btn.line { color: #06C755; border-color: #06C755; }
.mirais-theme .social-login-btn.facebook { color: #1877F2; border-color: #1877F2; }
.mirais-theme .social-login-btn.google { color: #DB4437; border-color: #DB4437; }
.mirais-theme .social-login-btn .ic { font-size: 16px; }

@media (max-width: 600px) {
  .mirais-theme .phone-cta { flex-direction: column; gap: 6px; padding: 18px; text-align: center; }
  .mirais-theme .phone-cta .text { text-align: center; }
  .mirais-theme .phone-cta .num { font-size: 22px; }
  .mirais-theme .live-chat-panel { right: 10px; left: 10px; width: auto; bottom: 140px; }
  .mirais-theme .live-chat-bubble { bottom: 70px; right: 14px; width: 52px; height: 52px; font-size: 22px; }
  }

  /* ===== v8: 便名検索 ===== */
.mirais-theme .flight-lookup-row { display: flex; gap: 6px; align-items: stretch; }
.mirais-theme .flight-lookup-row input { flex: 1; min-width: 0; padding: 11px 14px; border: 1px solid var(--border); border-radius: 6px; font-family: monospace; font-size: 14px; text-transform: uppercase; letter-spacing: 0.05em; box-sizing: border-box; }
.mirais-theme .flight-lookup-row button { padding: 11px 16px; background: var(--primary); color: #fff; border: none; border-radius: 6px; font-size: 13px; cursor: pointer; white-space: nowrap; font-weight: 500; flex-shrink: 0; }
.mirais-theme .flight-lookup-row button:hover { background: var(--primary-dark); }
.mirais-theme .flight-info-card { margin-top: 12px; background: linear-gradient(135deg, #E6F0FA 0%, #F0F7FF 100%); border: 1px solid var(--primary); border-radius: 8px; padding: 14px 16px; }
.mirais-theme .flight-info-card .head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid rgba(15,76,129,0.2); }
.mirais-theme .flight-info-card .head .flight-no { font-family: monospace; font-weight: 700; color: var(--primary); font-size: 16px; }
.mirais-theme .flight-info-card .head .status-badge { padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; }
.mirais-theme .flight-info-card .head .status-badge.on-time { background: var(--success); color: #fff; }
.mirais-theme .flight-info-card .head .status-badge.delayed { background: var(--warning, #BA7517); color: #fff; }
.mirais-theme .flight-info-card .head .status-badge.cancelled { background: var(--danger); color: #fff; }
.mirais-theme .flight-route { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; }
.mirais-theme .flight-route .airport { flex: 1; text-align: center; }
.mirais-theme .flight-route .airport .code { font-family: monospace; font-size: 22px; font-weight: 700; color: var(--primary); }
.mirais-theme .flight-route .airport .name { font-size: 10px; color: var(--text-sub); margin-top: 2px; }
.mirais-theme .flight-route .airport .time { font-size: 13px; margin-top: 4px; font-weight: 500; }
.mirais-theme .flight-route .plane-icon { font-size: 20px; color: var(--primary); }
.mirais-theme .flight-meta { display: flex; gap: 14px; margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(15,76,129,0.2); font-size: 11px; color: var(--text-sub); }
.mirais-theme .flight-meta .item { display: flex; align-items: center; gap: 4px; }
.mirais-theme .pickup-suggestion { margin-top: 10px; padding: 10px 12px; background: rgba(255,255,255,0.6); border-radius: 6px; font-size: 12px; color: var(--primary-dark); display: flex; gap: 8px; align-items: center; }
.mirais-theme .pickup-suggestion .ic { font-size: 18px; flex-shrink: 0; }

  /* ===== v8: 保険比較表 ===== */
.mirais-theme .insurance-compare-section { padding: 30px 0; }
.mirais-theme .insurance-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 18px; }
.mirais-theme .insurance-card { background: #fff; border: 2px solid var(--border); border-radius: 12px; padding: 20px; position: relative; transition: all 0.2s; }
.mirais-theme .insurance-card.recommended { border-color: var(--accent); box-shadow: 0 8px 20px rgba(0,163,180,0.15); }
.mirais-theme .insurance-card .recommended-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--accent); color: #fff; padding: 4px 14px; border-radius: 12px; font-size: 11px; font-weight: 600; white-space: nowrap; }
.mirais-theme .insurance-card .name { font-size: 16px; font-weight: 700; margin-bottom: 4px; text-align: center; }
.mirais-theme .insurance-card .icon-big { font-size: 38px; text-align: center; margin-bottom: 10px; line-height: 1; }
.mirais-theme .insurance-card .price { text-align: center; font-size: 22px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
.mirais-theme .insurance-card .price .unit { font-size: 11px; color: var(--text-sub); font-weight: 400; }
.mirais-theme .insurance-card .tagline { font-size: 11px; color: var(--text-sub); text-align: center; margin-bottom: 14px; min-height: 32px; }
.mirais-theme .insurance-card .features { list-style: none; padding: 0; margin: 0 0 14px 0; border-top: 1px solid var(--border); padding-top: 12px; }
.mirais-theme .insurance-card .features li { font-size: 12px; padding: 6px 0; padding-left: 22px; position: relative; line-height: 1.5; }
.mirais-theme .insurance-card .features li.yes::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; }
.mirais-theme .insurance-card .features li.no::before { content: '✕'; position: absolute; left: 0; color: var(--text-sub); font-weight: 400; }
.mirais-theme .insurance-card .features li.no { color: var(--text-sub); }
.mirais-theme .insurance-card .select-btn { width: 100%; padding: 11px; background: #fff; color: var(--primary); border: 1px solid var(--primary); border-radius: 6px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.2s; }
.mirais-theme .insurance-card .select-btn:hover { background: var(--primary); color: #fff; }
.mirais-theme .insurance-card.recommended .select-btn { background: var(--accent); color: #fff; border-color: var(--accent); }
.mirais-theme .insurance-card.recommended .select-btn:hover { background: #008898; }
.mirais-theme .insurance-card.selected { border-color: var(--success); }
.mirais-theme .insurance-card.selected .select-btn { background: var(--success); color: #fff; border-color: var(--success); }
.mirais-theme .insurance-detail-toggle { text-align: center; margin-top: 14px; }
.mirais-theme .insurance-detail-toggle button { background: transparent; border: none; color: var(--primary); font-size: 13px; cursor: pointer; padding: 6px 14px; }
.mirais-theme .insurance-detail-toggle button:hover { text-decoration: underline; }
.mirais-theme .insurance-compare-table { display: none; margin-top: 18px; background: #fff; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.mirais-theme .insurance-compare-table.open { display: block; }
.mirais-theme .insurance-compare-table table { width: 100%; border-collapse: collapse; font-size: 12px; }
.mirais-theme .insurance-compare-table th, .mirais-theme .insurance-compare-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); }
.mirais-theme .insurance-compare-table th { background: var(--bg-alt); font-weight: 500; text-align: left; color: var(--text-sub); }
.mirais-theme .insurance-compare-table td { text-align: center; vertical-align: top; }
.mirais-theme .insurance-compare-table td:first-child { text-align: left; font-weight: 500; }
.mirais-theme .insurance-compare-table td .check { color: var(--success); font-weight: 700; }
.mirais-theme .insurance-compare-table td .x { color: var(--text-sub); }

@media (max-width: 700px) {
  .mirais-theme .insurance-cards { grid-template-columns: 1fr; }
  }

  /* ===== v10: 空車カレンダー ===== */
.mirais-theme .availability-calendar { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 18px; margin: 18px 0; }
.mirais-theme .availability-calendar .cal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.mirais-theme .availability-calendar .cal-title { font-size: 15px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.mirais-theme .availability-calendar .cal-nav { display: flex; align-items: center; gap: 10px; }
.mirais-theme .availability-calendar .cal-nav button { background: var(--bg-alt); border: 1px solid var(--border); padding: 6px 12px; border-radius: 6px; cursor: pointer; font-size: 13px; }
.mirais-theme .availability-calendar .cal-nav button:hover:not(:disabled) { background: var(--primary-light); border-color: var(--primary); }
.mirais-theme .availability-calendar .cal-nav button:disabled { opacity: 0.4; cursor: not-allowed; }
.mirais-theme .availability-calendar .cal-month-label { font-size: 14px; font-weight: 600; min-width: 110px; text-align: center; }
.mirais-theme .availability-calendar .cal-legend { display: flex; gap: 14px; font-size: 11px; color: var(--text-sub); margin-bottom: 12px; flex-wrap: wrap; }
.mirais-theme .availability-calendar .cal-legend .item { display: flex; align-items: center; gap: 5px; }
.mirais-theme .availability-calendar .cal-legend .dot { width: 12px; height: 12px; border-radius: 3px; }
.mirais-theme .availability-calendar .cal-legend .dot.ok { background: #C8E6C9; border: 1px solid #66BB6A; }
.mirais-theme .availability-calendar .cal-legend .dot.few { background: #FFF3E0; border: 1px solid #FB8C00; }
.mirais-theme .availability-calendar .cal-legend .dot.full { background: #FFCDD2; border: 1px solid #E53935; }
.mirais-theme .availability-calendar .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.mirais-theme .availability-calendar .cal-day-label { text-align: center; font-size: 11px; font-weight: 600; color: var(--text-sub); padding: 6px 0; }
.mirais-theme .availability-calendar .cal-day-label.sun { color: #E53935; }
.mirais-theme .availability-calendar .cal-day-label.sat { color: #1E88E5; }
.mirais-theme .availability-calendar .cal-day { aspect-ratio: 1 / 1; min-height: 50px; border: 1px solid var(--border); border-radius: 6px; padding: 6px; display: flex; flex-direction: column; align-items: center; justify-content: space-between; cursor: pointer; transition: all 0.15s; background: #fff; }
.mirais-theme .availability-calendar .cal-day:hover { border-color: var(--primary); box-shadow: 0 2px 6px rgba(15,76,129,0.15); transform: translateY(-1px); }
.mirais-theme .availability-calendar .cal-day.past { opacity: 0.35; cursor: not-allowed; background: var(--bg-alt); }
.mirais-theme .availability-calendar .cal-day.past:hover { border-color: var(--border); box-shadow: none; transform: none; }
.mirais-theme .availability-calendar .cal-day.empty { border: none; cursor: default; background: transparent; }
.mirais-theme .availability-calendar .cal-day.empty:hover { transform: none; box-shadow: none; }
.mirais-theme .availability-calendar .cal-day .num { font-size: 13px; font-weight: 600; }
.mirais-theme .availability-calendar .cal-day.sun .num { color: #E53935; }
.mirais-theme .availability-calendar .cal-day.sat .num { color: #1E88E5; }
.mirais-theme .availability-calendar .cal-day .mark { font-size: 16px; font-weight: 700; line-height: 1; }
.mirais-theme .availability-calendar .cal-day.ok { background: #E8F5E9; border-color: #66BB6A; }
.mirais-theme .availability-calendar .cal-day.ok .mark { color: #2E7D32; }
.mirais-theme .availability-calendar .cal-day.few { background: #FFF3E0; border-color: #FB8C00; }
.mirais-theme .availability-calendar .cal-day.few .mark { color: #E65100; }
.mirais-theme .availability-calendar .cal-day.full { background: #FFEBEE; border-color: #E53935; cursor: not-allowed; }
.mirais-theme .availability-calendar .cal-day.full:hover { transform: none; box-shadow: none; }
.mirais-theme .availability-calendar .cal-day.full .mark { color: #C62828; }
.mirais-theme .availability-calendar .cal-day.today { box-shadow: 0 0 0 2px var(--accent); }
.mirais-theme .availability-calendar .cal-day .price { font-size: 9px; color: var(--text-sub); font-variant-numeric: tabular-nums; }
.mirais-theme .availability-calendar .cal-footer { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); font-size: 11px; color: var(--text-sub); text-align: center; }

@media (max-width: 600px) {
  .mirais-theme .availability-calendar { padding: 12px; }
  .mirais-theme .availability-calendar .cal-grid { gap: 2px; }
  .mirais-theme .availability-calendar .cal-day { min-height: 44px; padding: 3px; }
  .mirais-theme .availability-calendar .cal-day .num { font-size: 11px; }
  .mirais-theme .availability-calendar .cal-day .mark { font-size: 13px; }
  .mirais-theme .availability-calendar .cal-day .price { display: none; }
  .mirais-theme .availability-calendar .cal-legend { gap: 8px; font-size: 10px; }
  }

  /* ===== v11: 予約時の会員選択トグル ===== */
.mirais-theme .booking-mode-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 22px; }
.mirais-theme .booking-mode-card { background: #fff; border: 2px solid var(--border); border-radius: 10px; padding: 18px; cursor: pointer; transition: all 0.2s; position: relative; }
.mirais-theme .booking-mode-card:hover { border-color: var(--primary); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(15,76,129,0.08); }
.mirais-theme .booking-mode-card.active { border-color: var(--primary); background: var(--primary-light); }
.mirais-theme .booking-mode-card.active::before { content: '✓'; position: absolute; top: 10px; right: 14px; width: 24px; height: 24px; background: var(--primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; }
.mirais-theme .booking-mode-card .icon { font-size: 28px; margin-bottom: 8px; }
.mirais-theme .booking-mode-card .title { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
.mirais-theme .booking-mode-card .desc { font-size: 11px; color: var(--text-sub); line-height: 1.6; }
.mirais-theme .booking-mode-card .recommended { display: inline-block; padding: 2px 8px; background: var(--accent); color: #fff; border-radius: 10px; font-size: 9px; font-weight: 600; margin-left: 6px; letter-spacing: 0.04em; vertical-align: middle; }
.mirais-theme .booking-mode-card .benefits { margin-top: 8px; padding-top: 8px; border-top: 1px dashed var(--border); }
.mirais-theme .booking-mode-card .benefits li { font-size: 11px; padding: 2px 0 2px 18px; position: relative; list-style: none; line-height: 1.6; color: var(--text); }
.mirais-theme .booking-mode-card .benefits li::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; }
.mirais-theme .booking-mode-card.active .benefits li { color: var(--text); }

.mirais-theme .signup-extra-fields { background: linear-gradient(135deg, #E8F5E9 0%, #F1F8F1 100%); border: 1px solid var(--success); border-radius: 8px; padding: 18px; margin-top: 16px; }
.mirais-theme .signup-extra-fields .head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.mirais-theme .signup-extra-fields .head .icon { font-size: 22px; }
.mirais-theme .signup-extra-fields .head h4 { font-size: 14px; color: #1B5E20; margin: 0; }
.mirais-theme .signup-extra-fields .head p { font-size: 11px; color: #2E7D32; margin: 2px 0 0 0; }
.mirais-theme .signup-extra-fields .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mirais-theme .signup-extra-fields .form-field label { font-size: 11px; color: var(--text-sub); display: block; margin-bottom: 4px; }
.mirais-theme .signup-extra-fields .form-field input { width: 100%; padding: 10px 12px; border: 1px solid var(--border); border-radius: 6px; font-size: 13px; background: #fff; }
.mirais-theme .signup-extra-fields .form-field input:focus { outline: none; border-color: var(--primary); }
.mirais-theme .signup-extra-fields .agree-mini { display: flex; align-items: flex-start; gap: 8px; font-size: 11px; color: var(--text-sub); margin-top: 12px; cursor: pointer; }
.mirais-theme .signup-extra-fields .agree-mini input { margin-top: 3px; flex-shrink: 0; }

@media (max-width: 600px) {
  .mirais-theme .booking-mode-cards { grid-template-columns: 1fr; }
  .mirais-theme .signup-extra-fields .form-row { grid-template-columns: 1fr; }
  }



