/* ============================================================
   MEALHUG HOME — One-Screen Ordering Layout
   ============================================================ */

/* ════════════════════════════════════════════════════════════
   INTRO SPLASH — Cinematic Japanese editorial reveal
   Photo Ken Burns → sequential text → 『みなも』のジモ弁 finale
   ════════════════════════════════════════════════════════════ */
#intro-splash,
#intro-splash * {
    visibility: visible !important;
}
#intro-splash {
    position: fixed;
    inset: 0;
    z-index: 100000;
    overflow: hidden;
    background: #0a0a0a;
}

/* ── Photo background — Ken Burns slow zoom ── */
.intro-photo {
    position: absolute;
    inset: -8%;
    width: 116%;
    height: 116%;
    background-size: cover;
    background-position: center 40%;
    transform: scale(1) translate3d(0,0,0);
    animation: kb-zoom 13s linear forwards;
    will-change: transform;
}
@keyframes kb-zoom {
    0%   { transform: scale(1) translate3d(0,0,0); }
    100% { transform: scale(1.15) translate3d(0,0,0); }
}

/* ── Cinematic scrim ── */
.intro-scrim {
    position: absolute;
    inset: 0;
    background: transparent;
    z-index: 1;
    will-change: opacity;
    transition: opacity 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.intro-scrim.lift {
    opacity: 0;
}

/* ── Film grain ── */
.intro-grain {
    position: absolute;
    inset: 0;
    z-index: 2;
    opacity: 0.05;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 200px 200px;
}

/* ── Letterbox bars ── */
.intro-lbar {
    position: absolute;
    left: 0; right: 0;
    height: 7vh;
    background: #000;
    z-index: 5;
    will-change: transform;
    transition: transform 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.intro-lbar--top { top: 0; }
.intro-lbar--bot { bottom: 0; }
.intro-lbar--top.open { transform: translateY(-100%); }
.intro-lbar--bot.open { transform: translateY(100%); }

/* ── Text layer ── */
.intro-text-layer {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Sequential lines ── */
.intro-line {
    position: absolute;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: clamp(2rem, 7.5vw, 4.8rem);
    color: #FFD600;
    text-align: center;
    line-height: 1.2;
    letter-spacing: 0.1em;
    opacity: 0;
    white-space: nowrap;
    padding-bottom: 0.2em;
    border-bottom: 2px solid transparent;
    text-shadow: 0 2px 40px rgba(0,0,0,0.7);
    will-change: transform, opacity;
    transform: translateY(20px) translate3d(0,0,0);
}

/* ── Final group container ── */
.intro-final-group {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    opacity: 0;
    z-index: 4;
    will-change: transform, opacity;
    transform: translate3d(0,0,0);
}

/* Tagline above main (サ・地元飯) */
.intro-final-tag {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    font-size: clamp(0.9rem, 3vw, 1.6rem);
    letter-spacing: 0.4em;
    color: #FFD600;
    text-transform: uppercase;
    opacity: 0;
    transform: translateY(10px) translate3d(0,0,0);
    will-change: transform, opacity;
    text-shadow: 0 0 20px rgba(255,200,0,0.25);
}

/* ── HERO TITLE — 『みなも』のジモ弁 ── */
.intro-final-hero {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 900;
    font-size: clamp(1.8rem, 11vw, 10rem);
    letter-spacing: 0.04em;
    line-height: 1;
    color: #FFD600;
    text-align: center;
    white-space: nowrap;
    position: relative;
    margin: 0.15em 0;
    will-change: transform, opacity;
    text-shadow:
        0 0 100px rgba(255,200,0,0.35),
        0 4px 60px rgba(0,0,0,0.6);
}
/* 『みなも』highlight */
.intro-final-hero .hl {
    color: #FFD600;
    text-shadow:
        0 0 40px rgba(255,214,0,0.5),
        0 0 100px rgba(255,180,0,0.25);
}

/* White underline */
.intro-final-hero::after {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 5%;
    right: 5%;
    height: 3px;
    background: linear-gradient(90deg, transparent, #fff 20%, #fff 80%, transparent);
    border-radius: 2px;
    opacity: 0;
    transform: scaleX(0) translate3d(0,0,0);
    will-change: transform, opacity;
}

/* Sub-tagline below */
.intro-final-sub {
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: clamp(0.95rem, 3vw, 1.5rem);
    letter-spacing: 0.35em;
    color: #FFD600;
    text-shadow: 0 0 12px rgba(0,0,0,0.7), 0 2px 6px rgba(0,0,0,0.5);
    opacity: 0;
    transform: translateY(10px) translate3d(0,0,0);
    will-change: transform, opacity;
    margin-top: 0.3em;
}

/* ════════════════════════════
   ANIMATIONS (GPU-only: transform + opacity)
   ════════════════════════════ */

/* Line fade-in + rise */
@keyframes ln-enter {
    0%   { opacity: 0; transform: translateY(20px) translate3d(0,0,0); }
    100% { opacity: 1; transform: translateY(0) translate3d(0,0,0); border-bottom-color: rgba(255,255,255,0.5); }
}

/* Line fade-out + rise */
@keyframes ln-exit {
    0%   { opacity: 1; transform: translateY(0) translate3d(0,0,0); }
    100% { opacity: 0; transform: translateY(-25px) translate3d(0,0,0); }
}

/* Tag enter (small text above hero) */
@keyframes tag-enter {
    0%   { opacity: 0; transform: translateY(10px) translate3d(0,0,0); }
    100% { opacity: 1; transform: translateY(0) translate3d(0,0,0); }
}

/* Hero slam — ドン！ big → settle */
@keyframes hero-slam {
    0%   { opacity: 0; transform: scale(2.5) translate3d(0,0,0); }
    30%  { opacity: 1; transform: scale(0.94) translate3d(0,0,0); }
    50%  { transform: scale(1.04) translate3d(0,0,0); }
    70%  { transform: scale(0.99) translate3d(0,0,0); }
    100% { opacity: 1; transform: scale(1) translate3d(0,0,0); }
}

/* Underline grow */
@keyframes ul-grow {
    0%   { opacity: 0; transform: scaleX(0) translate3d(0,0,0); }
    100% { opacity: 1; transform: scaleX(1) translate3d(0,0,0); }
}

/* Whole splash dissolve out */
@keyframes splash-out {
    0%   { opacity: 1; transform: scale(1) translate3d(0,0,0); }
    100% { opacity: 0; transform: scale(1.04) translate3d(0,0,0); }
}

/* Final group container fade-in (no scale — hero has its own slam) */
@keyframes grp-enter {
    0%   { opacity: 0; }
    100% { opacity: 1; }
}

/* ── State classes ── */
.intro-line.enter {
    animation: ln-enter 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.intro-line.exit {
    animation: ln-exit 0.45s cubic-bezier(0.4, 0, 1, 1) forwards;
}

.intro-final-group.show {
    animation: grp-enter 0.3s ease forwards;
}
.intro-final-group.show .intro-final-tag {
    animation: tag-enter 0.6s 0s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.intro-final-group.show .intro-final-hero {
    animation: hero-slam 0.7s 0.15s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.intro-final-group.show .intro-final-hero::after {
    animation: ul-grow 0.6s 0.7s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.intro-final-group.show .intro-final-sub {
    animation: tag-enter 0.6s 0.9s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

#intro-splash.dissolve {
    animation: splash-out 1.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* ── Skip button ── */
#intro-skip {
    position: absolute;
    bottom: 10vh;
    right: 6vw;
    z-index: 10;
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 50px;
    padding: 10px 24px;
    font-family: 'Outfit', sans-serif;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: background 0.3s, transform 0.2s;
    animation: skipFadeIn 0.6s 1s ease forwards;
    opacity: 0;
}
#intro-skip:hover {
    background: rgba(255,255,255,0.25);
    transform: scale(1.05);
}
#intro-skip i {
    margin-left: 6px;
    font-size: 0.7rem;
}
@keyframes skipFadeIn {
    to { opacity: 1; }
}
@media (max-width: 600px) {
    #intro-skip {
        bottom: 5vh;
        right: 50%;
        transform: translateX(50%);
        padding: 10px 28px;
        font-size: 0.8rem;
    }
    #intro-skip:hover {
        transform: translateX(50%) scale(1.05);
    }
}

/* ── Home page wrapper ──────────────────── */
.home-page {
    font-family: 'Outfit', 'Noto Sans JP', sans-serif;
    color: var(--ink, #1A1A1A);
    background: var(--bg, #FFFFFF);
}

/* ════════════════════════════════════════════
   SECTION 1: BENTO CAROUSEL + PHILOSOPHY MARQUEE
   ════════════════════════════════════════════ */
.hero-new {
    position: relative;
    background: #0a0a0a;
    overflow: hidden;
}

/* ── Bento photo carousel (top half) ── */
.bento-carousel {
    position: relative;
    height: 48vh;
    min-height: 300px;
    overflow: hidden;
}
.bento-track {
    display: flex;
    gap: 16px;
    height: 100%;
    will-change: transform;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}
.bento-slide {
    flex: 0 0 auto;
    height: 100%;
}
.bento-slide img {
    height: 100%;
    width: auto;
    object-fit: cover;
    display: block;
    border-radius: 6px;
}

/* ── Info bar (between carousel & marquee) ── */
.hero-info-bar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.5rem;
    background: rgba(255,255,255,0.06);
    border-top: 1px solid rgba(255,255,255,0.08);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    font-size: 1.05rem;
    font-weight: 600;
    color: rgba(255,255,255,0.9);
}
.hero-info-bar .info-row {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.8rem;
}
.hero-info-bar .info-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
}
.hero-info-bar .info-chip i {
    font-size: 0.9rem;
    color: var(--y, #FFD700);
}
.hero-info-bar .info-sep {
    width: 1px;
    height: 16px;
    background: rgba(255,255,255,0.25);
}
.hero-info-bar .price-chip {
    font-weight: 700;
    color: var(--y, #FFD700);
    font-size: 1.1rem;
}

/* ── Philosophy marquee (bottom half) ── */
.philosophy-marquee {
    position: relative;
    overflow: hidden;
    padding: 1.0rem 0;
    background: #fff;
}
.marquee-track {
    display: flex;
    width: max-content;
    animation: marquee-scroll 60s linear infinite;
}
.marquee-content {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: clamp(1.1rem, 2.8vw, 1.6rem);
    letter-spacing: 0.08em;
    line-height: 1.8;
    color: #1a47b0;
    white-space: nowrap;
    padding-right: 6rem;
}

@keyframes marquee-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ════════════════════════════════════════════
   DAILY BENTO — コンセプト紹介
   ════════════════════════════════════════════ */
.daily-concept {
    padding: 2.5rem 1.5rem;
    background: #fff;
    border-bottom: 1px solid var(--border);
}
.daily-concept-inner {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}
.daily-concept-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--orange);
    letter-spacing: 0.06em;
    margin-bottom: 0.8rem;
}
.daily-concept-badge i {
    font-size: 0.9rem;
}
.daily-concept-text {
    font-family: 'Noto Serif JP', serif;
    font-size: clamp(0.95rem, 2.5vw, 1.15rem);
    line-height: 2;
    color: var(--slate);
    letter-spacing: 0.03em;
}

/* ════════════════════════════════════════════
   HOW TO ORDER — 簡単3ステップ (vertical)
   ════════════════════════════════════════════ */
.how-steps {
    padding: 3.5rem 1.5rem 3rem;
    background: var(--bg-soft, #FAFAF8);
    text-align: center;
}
.how-steps-title {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 800;
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--ink);
    letter-spacing: 0.04em;
}
.how-steps-sub {
    font-size: 0.9rem;
    color: var(--stone);
    margin-top: 0.4rem;
    margin-bottom: 2.5rem;
}

/* Vertical flow container */
.how-steps-flow {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    max-width: 400px;
    margin: 0 auto;
}

/* Each step item */
.hs-item {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    width: 100%;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.2rem 1.5rem;
    position: relative;
    transition: box-shadow 0.3s ease;
}
.hs-item:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}

/* Number badge */
.hs-num {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--orange);
    color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 3px 12px rgba(255,140,0,0.25);
}

/* Body text */
.hs-body {
    text-align: left;
    flex: 1;
    min-width: 0;
}
.hs-icon {
    display: none; /* hidden — icon is implicit from number */
}
.hs-name {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--ink);
    margin-bottom: 0.15rem;
}
.hs-desc {
    font-size: 0.82rem;
    color: var(--stone);
    line-height: 1.4;
}

/* Connector line between steps */
.hs-connector {
    display: flex;
    justify-content: center;
    height: 32px;
}
.hs-connector-line {
    width: 2px;
    height: 100%;
    background: linear-gradient(180deg, var(--orange), var(--y));
    border-radius: 1px;
}

/* ── Order CTA button (in how-steps section) ── */
.order-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    margin-top: 2rem;
    padding: 1rem 2.5rem;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 800;
    font-size: 1.15rem;
    color: #fff;
    background: var(--orange);
    border: none;
    border-radius: 50px;
    cursor: pointer;
    letter-spacing: 0.04em;
    box-shadow: 0 4px 20px rgba(255,140,0,0.35);
    transition: transform 0.2s, box-shadow 0.2s;
    animation: order-start-pulse 2s ease-in-out infinite;
}
.order-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 28px rgba(255,140,0,0.45);
}
.order-cta-btn:active {
    transform: translateY(0);
}

/* ════════════════════════════════════════════
   MISSION — mealHugの想い
   ════════════════════════════════════════════ */
.mission-section {
    background: var(--bg-soft, #FAFAF8);
    border-top: 1px solid var(--border, #E8E8E8);
    padding: 4rem 1.5rem 3.5rem;
}
.mission-inner {
    max-width: 740px;
    margin: 0 auto;
}

/* ── Lead copy ── */
.mission-lead {
    margin-bottom: 2.8rem;
}
.mission-kicker {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    color: var(--stone, #8C8C8C);
    text-transform: uppercase;
    margin: 0 0 0.8rem;
}
.mission-kicker::before {
    content: '';
    display: inline-block;
    width: 18px;
    height: 2px;
    background: var(--orange, #FF8C00);
    vertical-align: middle;
    margin-right: 0.6em;
}
.mission-headline {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: clamp(1.45rem, 3.8vw, 2rem);
    font-weight: 800;
    color: var(--ink, #1A1A1A);
    line-height: 1.5;
    margin: 0 0 1.4rem;
}
.mission-body p {
    font-size: 0.92rem;
    color: var(--slate, #3D3D3D);
    line-height: 1.85;
    margin: 0 0 0.5rem;
}
.mission-body p:last-child {
    margin-bottom: 0;
    color: var(--stone, #8C8C8C);
    font-size: 0.86rem;
}
.mission-body strong {
    color: var(--orange-dark, #CC7000);
    font-weight: 700;
}

/* ── 3 Pillars ── */
.mission-pillars-label {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.18em;
    color: var(--stone, #8C8C8C);
    text-align: center;
    margin: 0 0 1.4rem;
}
.mission-pillars {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.mission-pillar {
    display: flex;
    align-items: flex-start;
    gap: 1.1rem;
    padding: 1.2rem 0;
    border-top: 1px solid var(--border, #E8E8E8);
}
.mission-pillar:last-child {
    border-bottom: 1px solid var(--border, #E8E8E8);
}
.mission-pillar-num {
    font-family: 'Syne', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--orange, #FF8C00);
    flex-shrink: 0;
    padding-top: 0.15em;
    letter-spacing: 0.02em;
}
.mission-pillar-content {
    flex: 1;
}
.mission-pillar-name {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ink, #1A1A1A);
    margin: 0 0 0.3rem;
}
.mission-pillar-desc {
    font-size: 0.82rem;
    color: var(--slate, #3D3D3D);
    line-height: 1.65;
    margin: 0;
}

/* Mission mobile */
@media (max-width: 640px) {
    .mission-section { padding: 2.5rem 1rem 2rem; }
    .hide-sp { display: none; }
}

/* ════════════════════════════════════════════
   MAIN CONTENT GRID (sidebar layout)
   ════════════════════════════════════════════ */
.main-content-grid {
    max-width: 1120px;
    margin: 0 auto;
    padding: 1.5rem;
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 2rem;
    align-items: start;
}
.main-left {
    min-width: 0;
}

/* ════════════════════════════════════════════
   SECTION 2: WEEKLY MENU CALENDAR
   ════════════════════════════════════════════ */
.menu-calendar-section {
    margin-bottom: 2rem;
}
.calendar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}
.section-heading {
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
.section-heading i {
    color: var(--orange, #FF8C00);
    font-size: 1rem;
}
.menu-desc {
    font-size: 0.85rem;
    color: var(--stone, #8C8C8C);
    margin-bottom: 1rem;
}

/* Week tabs */
.week-tabs {
    display: flex;
    gap: 0.25rem;
    background: #f3f3f0;
    border-radius: 10px;
    padding: 3px;
}
.week-tab {
    padding: 0.4rem 1rem;
    border-radius: 8px;
    border: none;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    background: transparent;
    color: var(--stone);
    transition: all 0.15s;
}
.week-tab.active {
    background: white;
    color: var(--ink);
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

/* Day cards grid */
.day-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 0.75rem;
}

/* Day card */
.day-card {
    background: white;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 14px;
    overflow: hidden;
    transition: all 0.15s;
}
.day-card.is-orderable {
    border-color: var(--green, #32CD32);
    box-shadow: 0 0 0 1px rgba(50, 205, 50, 0.1);
}
.day-card.is-orderable:hover {
    box-shadow: 0 2px 12px rgba(50, 205, 50, 0.15);
}
.day-card.is-closed {
    opacity: 0.55;
}
.day-card.is-empty {
    opacity: 0.4;
}

.day-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 0.75rem 0.4rem;
}
.day-weekday {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--ink);
}
.day-date {
    font-size: 0.75rem;
    color: var(--stone);
    margin-left: 0.3rem;
}

/* Day badge */
.day-badge {
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 100px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.badge-open {
    background: rgba(50, 205, 50, 0.12);
    color: var(--green-dark, #228B22);
}
.badge-closed {
    background: rgba(0,0,0,0.06);
    color: var(--stone);
}
.badge-empty {
    background: rgba(0,0,0,0.04);
    color: #bbb;
}

.day-card-body {
    padding: 0 0.75rem 0.5rem;
    min-height: 110px;
}
.day-photo {
    width: 100%;
    height: 80px;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 0.4rem;
}
.day-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.day-dish-name {
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Menu items list (multiple items per day) */
.day-menu-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.day-menu-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.day-menu-thumb {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}
.day-menu-thumb--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange, #FF8C00);
    font-size: 1.1rem;
}
.day-menu-name {
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* Single item: show image full-width above name */
.day-menu-list:has(.day-menu-item:only-child) .day-menu-item {
    flex-direction: column;
    align-items: stretch;
}
.day-menu-list:has(.day-menu-item:only-child) .day-menu-thumb {
    width: 100%;
    height: 72px;
}
.day-menu-list:has(.day-menu-item:only-child) .day-menu-name {
    font-size: 0.85rem;
    text-align: center;
    margin-top: 0.15rem;
}

.day-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 80px;
    color: #ccc;
    font-size: 0.78rem;
    gap: 0.3rem;
}
.day-placeholder i {
    font-size: 1.2rem;
}

.day-card-footer {
    border-top: 1px solid var(--border, #E8E8E8);
    padding: 0.5rem 0.75rem;
    display: flex;
    justify-content: center;
}

/* Quantity stepper */
.qty-stepper {
    display: flex;
    align-items: center;
    gap: 0;
    background: #f7f7f5;
    border-radius: 10px;
    overflow: hidden;
}
.qty-btn {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    cursor: pointer;
    color: var(--ink);
    font-size: 0.75rem;
    transition: background 0.12s;
}
.qty-btn:hover:not(:disabled) {
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange);
}
.qty-btn:disabled {
    opacity: 0.3;
    cursor: default;
}
.qty-value {
    width: 32px;
    text-align: center;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ink);
}

/* ── Subscription: Day toggle button ── */
.day-toggle-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 2px solid var(--border, #E8E8E8);
    border-radius: 10px;
    background: #f7f7f5;
    cursor: pointer;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--slate, #3D3D3D);
    transition: all 0.15s;
    font-family: inherit;
}
.day-toggle-btn.is-on {
    border-color: var(--green, #32CD32);
    background: var(--green-soft, #E8FBE8);
    color: var(--green-dark, #228B22);
}
.day-toggle-btn:not(.is-on):hover:not(:disabled) {
    border-color: var(--orange);
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange);
}
.day-toggle-btn:disabled {
    opacity: 0.35;
    cursor: default;
}

/* ── Day card selected state (subscription) ── */
.day-card.is-selected {
    border-color: var(--green, #32CD32) !important;
    box-shadow: 0 0 0 2px rgba(50, 205, 50, 0.15);
}

/* ── Selection counter ── */
.sub-selection-counter {
    display: flex;
    align-items: center;
    padding: 0.5rem 0.75rem;
    margin-bottom: 0.75rem;
    background: var(--bg-soft, #FAFAF8);
    border: 1px solid var(--border, #E8E8E8);
    border-radius: 10px;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
}

/* ── Step badge ── */
.step-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--orange, #FF8C00);
    color: white;
    font-size: 0.7rem;
    font-weight: 800;
    flex-shrink: 0;
}

/* ── Frequency hint ── */
.freq-hint {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.6rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--orange, #FF8C00);
}

/* ── Subscription: recurring hint on day card ── */
.day-recurring-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    margin-top: 0.4rem;
    padding: 0.2rem 0.5rem;
    background: var(--orange-soft, #FFF3E0);
    border-radius: 6px;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--orange-dark, #CC7000);
}
.day-recurring-hint i {
    font-size: 0.55rem;
}

/* ── Subscription: schedule banner ── */
.sub-schedule-banner {
    margin-bottom: 0.75rem;
    padding: 0.75rem 1rem;
    background: var(--orange-soft, #FFF3E0);
    border: 1px solid rgba(255, 140, 0, 0.2);
    border-radius: 12px;
}
.sub-schedule-banner-head {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--orange-dark, #CC7000);
    margin-bottom: 0.4rem;
}
.sub-schedule-banner-head i {
    font-size: 0.75rem;
    color: var(--orange, #FF8C00);
}
.sub-schedule-line {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0;
    font-size: 0.75rem;
    color: var(--slate, #3D3D3D);
}
.sub-schedule-line i {
    font-size: 0.6rem;
    color: var(--orange, #FF8C00);
}
.sub-schedule-summary {
    margin-top: 0.35rem;
    padding-top: 0.35rem;
    border-top: 1px dashed rgba(255, 140, 0, 0.25);
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--orange-dark, #CC7000);
}

/* ── Subscription: delivery dates list ── */
.sub-schedule-dates {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px dashed rgba(255, 140, 0, 0.15);
}
.sub-schedule-dates-label {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--stone, #8C8C8C);
    margin-bottom: 0.4rem;
}
.sub-schedule-dates-label i {
    font-size: 0.6rem;
    color: var(--orange, #FF8C00);
}
.sub-schedule-dates-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}
.sub-schedule-date-chip {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    background: rgba(255, 140, 0, 0.08);
    border: 1px solid rgba(255, 140, 0, 0.18);
    border-radius: 0.4rem;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--orange-dark, #CC7000);
    white-space: nowrap;
}

/* ── Subscription: sidebar monthly label ── */
.summary-sub-label {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.6rem;
    margin-bottom: 0.5rem;
    background: var(--orange-soft, #FFF3E0);
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--orange-dark, #CC7000);
}
.summary-sub-label i {
    font-size: 0.6rem;
    color: var(--orange, #FF8C00);
}

/* ── Subscription: modal schedule display ── */
.confirm-sub-schedule {
    margin-bottom: 1rem;
    padding: 0.75rem 1rem;
    background: var(--orange-soft, #FFF3E0);
    border: 1px solid rgba(255, 140, 0, 0.2);
    border-radius: 12px;
}

/* ════════════════════════════════════════════
   ACTIVE SUBSCRIPTION BANNER
   ════════════════════════════════════════════ */
/* ── My Orders Overview (sub + upcoming) ── */
.my-orders-overview {
    max-width: 600px;
    margin: 0 auto;
    padding: 1.5rem 1.25rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* ── Upcoming Orders Section ── */
.upcoming-orders-section {
    background: white;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: 1.5rem;
}
.upcoming-orders-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: var(--green-soft, #E8FBE8);
    border-bottom: 1.5px solid var(--border, #E8E8E8);
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--green-dark, #228B22);
}
.upcoming-orders-head i {
    font-size: 0.9rem;
}
.upcoming-orders-count {
    margin-left: auto;
    font-size: 0.72rem;
    font-weight: 700;
    background: var(--green-dark, #228B22);
    color: white;
    padding: 2px 8px;
    border-radius: 100px;
}
.upcoming-orders-list {
    padding: 0.25rem 0;
}
.upcoming-order-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 1rem;
    border-bottom: 1px solid var(--border, #E8E8E8);
    transition: background 0.1s;
}
.upcoming-order-row:last-child {
    border-bottom: none;
}
.upcoming-order-row.is-today {
    background: #FFFDE7;
}
.upcoming-order-date {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    min-width: 110px;
}
.upcoming-order-datestr {
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--ink, #1A1A1A);
}
.upcoming-order-dow {
    font-size: 0.78rem;
    color: var(--stone, #8C8C8C);
    font-weight: 600;
}
.upcoming-order-soon {
    font-size: 0.6rem;
    font-weight: 800;
    color: white;
    background: var(--orange, #FF8C00);
    padding: 1px 6px;
    border-radius: 4px;
    letter-spacing: 0.03em;
    flex-shrink: 0;
}
.upcoming-order-soon.is-next {
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange-dark, #CC7000);
}
.upcoming-order-row.is-next {
    background: var(--orange-soft, #FFF3E0);
    border-left: 3px solid var(--orange, #FF8C00);
}
.upcoming-order-soon.is-tomorrow {
    background: var(--green-dark, #228B22);
}
.upcoming-order-info {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex: 1;
}
.upcoming-order-qty {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--ink, #1A1A1A);
}
.upcoming-order-type-tag {
    font-size: 0.6rem;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 4px;
    letter-spacing: 0.02em;
}
.upcoming-order-type-tag.is-sub {
    background: rgba(255, 140, 0, 0.1);
    color: var(--orange-dark, #CC7000);
}
.upcoming-order-type-tag.is-ind {
    background: rgba(50, 205, 50, 0.1);
    color: var(--green-dark, #228B22);
}
.upcoming-order-status {
    font-size: 0.72rem;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: 6px;
    text-align: center;
    white-space: nowrap;
    flex-shrink: 0;
    background: #F3F4F6;
    color: #6B7280;
}
/* 受付済 — グレー（落ち着いた待機状態） */
.upcoming-order-status.is-pending,
.upcoming-order-status.is-confirmed {
    background: #F3F4F6;
    color: #6B7280;
}
/* 準備中 — 黄色 */
.upcoming-order-status.is-preparing,
.upcoming-order-status.is-ready {
    background: #FEF3C7;
    color: #92400E;
}
/* 配達中 — オレンジ（目立つ） */
.upcoming-order-status.is-delivering {
    background: var(--orange, #FF8C00);
    color: #fff;
}
/* 配達済 — 緑 */
.upcoming-order-status.is-delivered {
    background: var(--green, #32CD32);
    color: #fff;
}
.upcoming-orders-more {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.6rem;
    border-top: 1px solid var(--border, #E8E8E8);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--orange, #FF8C00);
    text-decoration: none;
    transition: background 0.12s;
}
.upcoming-orders-more:hover {
    background: var(--orange-soft, #FFF3E0);
}

.active-sub-banner {
    margin-bottom: 1rem;
    padding: 1rem 1.25rem;
    background: var(--orange-soft, #FFF3E0);
    border: 2px solid var(--orange, #FF8C00);
    border-radius: 14px;
}
.active-sub-banner-head {
    margin-bottom: 0.6rem;
}
.active-sub-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.3rem 0.75rem;
    background: var(--orange, #FF8C00);
    color: #fff;
    border-radius: 100px;
    font-size: 0.78rem;
    font-weight: 700;
}
.active-sub-badge i {
    font-size: 0.7rem;
}
.active-sub-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}
.active-sub-days {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}
.active-sub-days-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
}
.active-sub-day-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    padding: 0.25rem 0.5rem;
    background: white;
    border: 1.5px solid var(--orange, #FF8C00);
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--orange-dark, #CC7000);
}
.active-sub-freq-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.65rem;
    background: var(--orange, #FF8C00);
    color: white;
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 700;
}
.active-sub-start-date {
    width: 100%;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--orange-dark, #CC7000);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.active-sub-next-delivery {
    width: 100%;
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--ink, #1A1A1A);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.active-sub-next-delivery strong {
    font-weight: 700;
    color: var(--orange, #FF8C00);
}
.active-sub-price {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink, #1A1A1A);
}
.active-sub-price small {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--stone, #8C8C8C);
}
.active-sub-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: space-between;
}
.active-sub-change-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1rem;
    border: 2px solid var(--orange, #FF8C00);
    border-radius: 10px;
    background: white;
    color: var(--orange-dark, #CC7000);
    font-size: 0.82rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
}
.active-sub-change-btn:hover {
    background: var(--orange-soft, #FFF3E0);
}
.active-sub-stop-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1rem;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 10px;
    background: white;
    color: var(--stone, #8C8C8C);
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
}
.active-sub-stop-btn:hover {
    border-color: #ef4444;
    color: #dc2626;
    background: #fef2f2;
}

/* ── Pending day change notice ── */
.pending-change-notice {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-top: 0.75rem;
    padding: 0.85rem 1rem;
    background: var(--orange-soft, #FFF3E0);
    border: 1px solid var(--orange, #FF8C00);
    border-radius: 10px;
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--ink, #1A1A1A);
}
.pending-change-notice-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--orange, #FF8C00);
    color: #fff;
    border-radius: 50%;
    font-size: 0.75rem;
    margin-top: 0.1rem;
}
.pending-change-notice-content strong {
    display: block;
    font-size: 0.85rem;
    color: var(--orange-dark, #CC7000);
    margin-bottom: 0.25rem;
}
.pending-change-notice-detail {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    flex-wrap: wrap;
    margin-bottom: 0.15rem;
}
.pending-day-tag {
    display: inline-block;
    padding: 0.1rem 0.5rem;
    background: var(--orange, #FF8C00);
    color: #fff;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
}
.pending-change-notice-date {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    color: var(--slate, #3D3D3D);
    font-size: 0.78rem;
}

/* Individual order button (outside banner) */
.active-sub-individual-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.75rem 2rem;
    border: none;
    border-radius: 12px;
    background: var(--orange, #FF8C00);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.18s;
    font-family: inherit;
    box-shadow: 0 2px 8px rgba(255,140,0,0.25);
}
.active-sub-individual-btn:hover {
    background: var(--orange-dark, #CC7000);
    box-shadow: 0 4px 14px rgba(255,140,0,0.35);
    transform: translateY(-1px);
}

/* Cancel subscription confirmation dialog */
.cancel-sub-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.cancel-sub-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}
.cancel-sub-dialog {
    position: relative;
    background: white;
    border-radius: 18px;
    padding: 2rem 1.75rem;
    max-width: 380px;
    width: 100%;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,0.2);
}
.cancel-sub-dialog-icon {
    font-size: 2.5rem;
    color: #f59e0b;
    margin-bottom: 0.75rem;
}
.cancel-sub-dialog-title {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--ink, #1A1A1A);
    margin-bottom: 0.5rem;
}
.cancel-sub-dialog-desc {
    font-size: 0.85rem;
    color: var(--stone, #8C8C8C);
    line-height: 1.6;
    margin-bottom: 1.5rem;
}
.cancel-sub-dialog-actions {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
}
.cancel-sub-dialog-back {
    padding: 0.6rem 1.25rem;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 10px;
    background: white;
    color: var(--slate, #3D3D3D);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.cancel-sub-dialog-back:hover {
    border-color: var(--slate);
}
.cancel-sub-dialog-confirm {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.6rem 1.25rem;
    border: none;
    border-radius: 10px;
    background: #dc2626;
    color: white;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.cancel-sub-dialog-confirm:hover {
    background: #b91c1c;
}

/* Edit subscription panel */
.edit-sub-panel {
    margin-bottom: 1rem;
    padding: 1rem 1.25rem;
    background: var(--orange-soft, #FFF3E0);
    border: 2px solid var(--orange, #FF8C00);
    border-radius: 14px;
}
.edit-sub-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.4rem;
}
.edit-sub-panel-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--orange-dark, #CC7000);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
.edit-sub-current-days {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
}
.edit-sub-current-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
}
.edit-sub-current-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.8rem;
    padding: 0.2rem 0.45rem;
    background: white;
    border: 1.5px solid var(--orange, #FF8C00);
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--orange-dark, #CC7000);
}
.edit-sub-current-freq {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--stone, #8C8C8C);
}
.edit-sub-panel-desc {
    font-size: 0.8rem;
    color: var(--slate, #3D3D3D);
    line-height: 1.5;
}
.edit-sub-week-tabs {
    display: flex;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

/* Editing confirm area */
.edit-sub-confirm-area {
    margin-top: 1.25rem;
    margin-bottom: 1.5rem;
    padding: 1.25rem;
    background: var(--green-soft, #E8FBE8);
    border: 2px solid var(--green, #32CD32);
    border-radius: 14px;
}
.edit-sub-confirm-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.edit-sub-confirm-new {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}
.edit-sub-confirm-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
}
.edit-sub-confirm-day {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.6rem;
    background: white;
    border: 1.5px solid var(--green, #32CD32);
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--green-dark, #228B22);
}
.edit-sub-confirm-price {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink, #1A1A1A);
}
.edit-sub-confirm-price small {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--stone, #8C8C8C);
}
.billing-loading-spinner {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--orange, #FF8C00);
    font-size: 0.9rem;
    font-weight: 600;
}
.edit-sub-confirm-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.75rem;
    border: none;
    border-radius: 12px;
    background: var(--green, #32CD32);
    color: var(--green-deep, #0A1F0A);
    font-size: 0.95rem;
    font-weight: 800;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.edit-sub-confirm-btn:hover {
    background: var(--green-dark, #228B22);
    color: white;
}

/* Day change confirmation modal */
.day-change-compare {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin: 1.25rem 0;
}
.day-change-col {
    text-align: center;
}
.day-change-label {
    display: block;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--stone, #8C8C8C);
    margin-bottom: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.day-change-tags {
    display: flex;
    gap: 0.3rem;
    flex-wrap: wrap;
    justify-content: center;
}
.day-change-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.3rem 0.6rem;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
}
.day-change-tag.old {
    background: #fef2f2;
    border: 1.5px solid #fca5a5;
    color: #dc2626;
    text-decoration: line-through;
}
.day-change-tag.new {
    background: var(--green-soft, #E8FBE8);
    border: 1.5px solid var(--green, #32CD32);
    color: var(--green-dark, #228B22);
}
.day-change-arrow {
    color: var(--stone, #8C8C8C);
    font-size: 1.1rem;
}
.day-change-notice {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    padding: 0.55rem 0.75rem;
    background: #FFF8E1;
    border: 1px solid #FFE082;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #7B6B00;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}
.day-change-notice i {
    color: #C49000;
    margin-top: 1px;
    flex-shrink: 0;
}
.day-change-price-confirm {
    font-size: 1.15rem;
    font-weight: 800;
    text-align: center;
    color: var(--ink, #1A1A1A);
    margin-bottom: 1.25rem;
}
.day-change-price-confirm small {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--stone, #8C8C8C);
}
.day-change-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 1.5rem 0;
}
.day-change-loading p {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
}
.day-change-success i {
    font-size: 2.5rem;
    color: var(--green, #32CD32);
}
.day-change-success p {
    font-size: 1rem;
    font-weight: 700;
    color: var(--green-dark, #228B22);
}
.day-change-redirect-msg {
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    color: var(--stone, #8C8C8C) !important;
    margin-top: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
.day-change-redirect-msg i {
    font-size: 0.85rem;
    color: var(--stone, #8C8C8C);
}
.day-change-confirm-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.6rem 1.25rem;
    border: none;
    border-radius: 10px;
    background: var(--green, #32CD32);
    color: var(--green-deep, #0A1F0A);
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.day-change-confirm-btn:hover {
    background: var(--green-dark, #228B22);
    color: white;
}
.day-change-confirm-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.active-sub-cancel-edit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.4rem 0.85rem;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 8px;
    background: white;
    color: var(--stone, #8C8C8C);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
}
.active-sub-cancel-edit-btn:hover {
    border-color: var(--slate);
    color: var(--ink);
}

/* ════════════════════════════════════════════
   SECTION: ORDER TYPE
   ════════════════════════════════════════════ */
.order-type-section {
    margin-bottom: 2rem;
}
.type-toggle {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.75rem;
}
.type-btn {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 2px solid var(--border);
    border-radius: 12px;
    background: white;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    transition: all 0.15s;
    color: var(--slate, #3D3D3D);
}
.type-btn.active {
    border-color: var(--orange);
    background: var(--orange-soft);
    color: var(--orange-dark, #CC7000);
}
.type-btn i {
    font-size: 0.85rem;
}

.sub-frequency {
    margin-top: 1rem;
}
.freq-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--slate);
    margin-bottom: 0.5rem;
}
.freq-options {
    display: flex;
    gap: 0.5rem;
}
.freq-btn {
    flex: 1;
    padding: 0.6rem;
    border: 2px solid var(--border);
    border-radius: 10px;
    background: white;
    cursor: pointer;
    text-align: center;
    transition: all 0.15s;
}
.freq-btn.active {
    border-color: var(--orange);
    background: var(--orange-soft);
}
.freq-times {
    display: block;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--ink);
}
.freq-price {
    display: block;
    font-size: 0.75rem;
    color: var(--orange);
    font-weight: 600;
    margin-top: 0.15rem;
}

.individual-notice {
    margin-top: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: #FFF8E1;
    border-radius: 10px;
    font-size: 0.82rem;
    color: #8B6914;
}
.individual-notice i {
    font-size: 0.9rem;
    color: #D4A017;
}

/* ════════════════════════════════════════════
   SECTION 4: DELIVERY & PAYMENT
   ════════════════════════════════════════════ */
.delivery-payment-section {
    margin-bottom: 2rem;
}
.dp-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.dp-block {
    background: #FAFAF8;
    border-radius: 12px;
    padding: 1rem;
}
.dp-notes {
    grid-column: 1 / -1;
}
.dp-label {
    font-size: 0.82rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 0.5rem;
    color: var(--ink);
}
.dp-label i {
    color: var(--orange);
    font-size: 0.8rem;
}
.dp-select {
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: 1.5px solid var(--border);
    border-radius: 10px;
    font-size: 0.82rem;
    background: white;
    outline: none;
    transition: border-color 0.15s;
}
.dp-select:focus {
    border-color: var(--orange);
}
.dp-empty {
    font-size: 0.82rem;
    color: var(--stone);
}

.pay-toggle {
    display: flex;
    gap: 0.4rem;
}
.pay-btn {
    flex: 1;
    padding: 0.55rem 0.75rem;
    border: 2px solid var(--border);
    border-radius: 10px;
    background: white;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    transition: all 0.15s;
    color: var(--slate);
}
.pay-btn.active {
    border-color: var(--orange);
    background: var(--orange-soft);
    color: var(--orange-dark);
}

.dp-textarea {
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: 1.5px solid var(--border);
    border-radius: 10px;
    font-size: 0.82rem;
    font-family: inherit;
    resize: vertical;
    outline: none;
    transition: border-color 0.15s;
}
.dp-textarea:focus {
    border-color: var(--orange);
}

/* ════════════════════════════════════════════
   SECTION 5: ORDER SUMMARY (Sticky Sidebar)
   ════════════════════════════════════════════ */
.summary-sidebar {
    display: block;
}
.summary-sticky {
    position: sticky;
    top: 80px;
    background: white;
    border: 1.5px solid var(--border);
    border-radius: 16px;
    padding: 1.25rem;
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
.summary-title {
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 1rem;
}
.summary-title i {
    color: var(--orange);
}
.summary-empty {
    text-align: center;
    padding: 1.5rem 0;
    color: var(--stone);
    font-size: 0.82rem;
}
.summary-empty i {
    font-size: 1.5rem;
    display: block;
    margin-bottom: 0.5rem;
    opacity: 0.4;
}

.summary-items {
    margin-bottom: 0.75rem;
}
.summary-item {
    display: flex;
    justify-content: space-between;
    padding: 0.35rem 0;
    font-size: 0.82rem;
    border-bottom: 1px dashed var(--border);
}
.summary-item:last-child {
    border-bottom: none;
}

.summary-totals {
    border-top: 1.5px solid var(--border);
    padding-top: 0.75rem;
    margin-bottom: 0.75rem;
}
.total-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.82rem;
    padding: 0.2rem 0;
    color: var(--slate);
}
.total-final {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--ink);
    padding-top: 0.5rem;
    margin-top: 0.3rem;
    border-top: 2px solid var(--ink);
}

.summary-warning {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: #D4642A;
    background: #FFF5F0;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    margin-bottom: 0.75rem;
}
.summary-warning i {
    font-size: 0.85rem;
}

.order-submit-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.85rem;
    border: none;
    border-radius: 12px;
    font-size: 0.92rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s;
    background: var(--orange, #FF8C00);
    color: white;
    text-decoration: none;
}
.order-submit-btn:hover:not(:disabled) {
    background: var(--orange-dark, #CC7000);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255,140,0,0.3);
}
.order-submit-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}
.order-submit-btn.login-btn {
    background: var(--green, #32CD32);
}
.order-submit-btn.login-btn:hover {
    background: var(--green-dark, #228B22);
}

/* ════════════════════════════════════════════
   SECTION 6: MINI INFO
   ════════════════════════════════════════════ */
.mini-info-section {
    margin-bottom: 2rem;
}
.steps-row {
    display: flex;
    align-items: center;
    gap: 0;
    margin-top: 1rem;
}
.step-card {
    flex: 1;
    text-align: center;
    padding: 1.25rem 0.75rem;
    background: #FAFAF8;
    border-radius: 14px;
}
.steps-animated .step-card.step-visible {
    animation: stepFadeUp 0.5s ease both;
}
.step-arrow {
    flex-shrink: 0;
    width: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--orange);
    font-size: 1rem;
}
.steps-animated .step-arrow.arrow-visible {
    animation: arrowSlideIn 0.4s ease both;
}
@keyframes stepFadeUp {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes arrowSlideIn {
    from { opacity: 0; transform: translateX(-8px); }
    to   { opacity: 1; transform: translateX(0); }
}
.step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--orange);
    color: white;
    font-weight: 800;
    font-size: 0.88rem;
    margin-bottom: 0.5rem;
}
.step-title {
    font-weight: 700;
    font-size: 0.88rem;
    margin-bottom: 0.25rem;
}
.step-desc {
    font-size: 0.78rem;
    color: var(--stone);
    line-height: 1.4;
}

.payment-methods-info {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 1rem;
    font-size: 0.82rem;
    color: var(--stone);
}
.payment-methods-info i {
    margin-right: 0.3rem;
    color: var(--orange);
}

/* ════════════════════════════════════════════
   MOBILE BOTTOM BAR (fixed)
   ════════════════════════════════════════════ */
.mobile-bottom-bar {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: white;
    border-top: 1.5px solid var(--border);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
    padding: 0.75rem 1rem;
    padding-bottom: calc(0.75rem + env(safe-area-inset-bottom));
}
.mobile-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    max-width: 600px;
    margin: 0 auto;
}
.mobile-bar-info {
    display: flex;
    flex-direction: column;
}
.mobile-bar-total {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--ink);
}
.mobile-bar-count {
    font-size: 0.75rem;
    color: var(--stone);
}
.mobile-bar-form {
    flex-shrink: 0;
}
.mobile-order-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1.5rem;
    border: none;
    border-radius: 12px;
    background: var(--orange);
    color: white;
    font-size: 0.88rem;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.15s;
}
.mobile-order-btn:hover:not(:disabled) {
    background: var(--orange-dark);
}
.mobile-order-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* ════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════ */
@media (max-width: 900px) {
    .main-content-grid {
        grid-template-columns: 1fr;
        padding: 1rem;
    }
    .summary-sidebar {
        display: none;
    }
    .mobile-bottom-bar {
        display: block;
    }
    .hero-inner {
        flex-direction: column;
        text-align: center;
    }
    .hero-info-strip {
        justify-content: center;
    }
}

@media (max-width: 640px) {
    .hero-compact {
        padding: 1.75rem 0.75rem 1rem;
    }
    .hero-title {
        font-size: 1.5rem;
    }
    .hero-tagline {
        font-size: 0.8rem;
        margin-bottom: 0.35rem;
    }
    .hero-info-strip {
        gap: 0.35rem;
    }
    .hero-info-bar {
        font-size: 0.85rem;
        padding: 0.7rem 0.75rem;
        gap: 0.4rem;
    }
    .hero-info-bar .info-row {
        gap: 0.5rem;
    }
    .hero-info-bar .price-chip {
        font-size: 0.9rem;
    }
    .day-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .steps-row {
        flex-direction: column;
    }
    .step-arrow {
        width: auto;
        height: 28px;
    }
    .step-arrow i {
        transform: rotate(90deg);
    }
    .steps-animated .step-arrow.arrow-visible {
        animation: arrowSlideDown 0.4s ease both;
    }
    @keyframes arrowSlideDown {
        from { opacity: 0; transform: translateY(-6px); }
        to   { opacity: 1; transform: translateY(0); }
    }
    .dp-grid {
        grid-template-columns: 1fr;
    }
    .type-toggle {
        flex-direction: column;
    }
    .freq-options {
        flex-direction: column;
    }
}

/* ============================================================
   PAYMENT MODAL
   ============================================================ */
.pay-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.pay-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.pay-modal {
    position: relative;
    background: #fff;
    border-radius: 1.25rem;
    box-shadow: 0 24px 80px rgba(0,0,0,0.25);
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    overflow-y: auto;
    max-height: 90vh;
    overflow-y: auto;
}
.pay-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: var(--bg-soft);
    color: var(--stone);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
    z-index: 2;
}
.pay-modal-close:hover {
    background: #eee;
    color: var(--ink);
}

/* Steps container — prevents layout shift during transition */
.pay-modal-steps {
    position: relative;
    overflow: hidden;
}
.pay-modal-step-panel {
    /* When leaving, panel is positioned absolutely so it doesn't affect layout */
}
.step-enter { transition: opacity 0.15s ease-out; }
.step-enter-from { opacity: 0; }
.step-enter-to { opacity: 1; }
.step-leave { transition: opacity 0.1s ease-in; position: absolute; top: 0; left: 0; right: 0; }
.step-leave-from { opacity: 1; }
.step-leave-to { opacity: 0; }

/* Step indicator */
.pay-modal-step-indicator {
    display: flex;
    align-items: center;
    gap: 0;
    margin-bottom: 0.75rem;
}
.step-dot {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid var(--border);
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.step-dot.active {
    border-color: var(--orange);
    background: var(--orange);
    color: #fff;
}
.step-dot.done {
    border-color: var(--orange);
    background: var(--orange-soft);
    color: var(--orange);
}
.step-line {
    width: 40px;
    height: 2px;
    background: var(--border);
    transition: background 0.2s;
}
.step-line.done {
    background: var(--orange);
}

/* Header / Body / Footer */
.pay-modal-header {
    padding: 1.5rem 1.5rem 0;
}
.pay-modal-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.15rem;
    color: var(--ink);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.pay-modal-body {
    padding: 1.25rem 1.5rem;
}
.pay-modal-footer {
    padding: 0 1.5rem 1.5rem;
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
}

/* Payment method badge */
.pm-current {
    margin-bottom: 1rem;
}
.pm-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    background: var(--orange-soft);
    color: var(--orange-dark);
    border-radius: 100px;
    font-size: 0.8rem;
    font-weight: 600;
}

/* Cash info */
.cash-info-box {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: 0.75rem;
    font-size: 0.85rem;
    color: var(--slate);
}

/* Saved card in modal */
.modal-saved-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    border: 2px solid var(--orange);
    border-radius: 0.75rem;
    background: var(--orange-soft);
}
.modal-saved-card-brand {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 0.65rem;
    font-weight: 800;
    color: var(--slate);
    text-transform: uppercase;
}
.modal-saved-card-info {
    flex: 1;
}
.modal-saved-card-num {
    font-family: 'Outfit', monospace;
    font-weight: 600;
    color: var(--ink);
    font-size: 0.9rem;
}
.modal-saved-card-exp {
    display: block;
    font-size: 0.7rem;
    color: var(--stone);
    margin-top: 1px;
}
.modal-switch-card {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: none;
    border: none;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--orange);
    cursor: pointer;
    margin-top: 0.6rem;
    padding: 0;
    transition: opacity 0.15s;
}
.modal-switch-card:hover {
    opacity: 0.7;
}

/* Stripe element in modal */
.modal-field-label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--slate);
    margin-bottom: 0.4rem;
}
.required-badge {
    display: inline-block;
    font-size: 0.6rem;
    font-weight: 700;
    color: #c33;
    background: rgba(204, 51, 51, 0.08);
    padding: 1px 6px;
    border-radius: 4px;
    margin-left: 0.3rem;
    vertical-align: middle;
    letter-spacing: 0.02em;
}
.modal-field-input {
    width: 100%;
    padding: 0.65rem 0.875rem;
    border: 2px solid var(--border);
    border-radius: 0.65rem;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9rem;
    color: var(--ink);
    outline: none;
    transition: border-color 0.15s;
    margin-bottom: 0.75rem;
}
.modal-field-input:focus {
    border-color: var(--orange);
}
.modal-field-input::placeholder {
    color: var(--stone);
}
.modal-stripe-element {
    padding: 0.75rem 0.875rem;
    border: 2px solid var(--border);
    border-radius: 0.65rem;
    background: #fff;
    transition: border-color 0.15s;
}
.modal-stripe-element.StripeElement--focus {
    border-color: var(--orange);
}
.modal-stripe-element.StripeElement--invalid {
    border-color: #ef4444;
}
.modal-card-error {
    min-height: 1.1em;
    font-size: 0.78rem;
    color: #ef4444;
    margin-top: 0.35rem;
}
.modal-security {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 1rem;
    font-size: 0.72rem;
    color: #16a34a;
    background: #f0fdf4;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
}

/* Modal buttons */
.modal-btn-secondary {
    padding: 0.6rem 1.2rem;
    border: 2px solid var(--border);
    border-radius: 0.65rem;
    background: #fff;
    font-family: 'Outfit', sans-serif;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--slate);
    cursor: pointer;
    transition: all 0.15s;
}
.modal-btn-secondary:hover:not(:disabled) {
    background: var(--bg-soft);
}
.modal-btn-primary {
    padding: 0.6rem 1.5rem;
    border: none;
    border-radius: 0.65rem;
    background: var(--orange);
    font-family: 'Outfit', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.15s;
}
.modal-btn-primary:hover:not(:disabled) {
    background: var(--orange-dark);
    transform: translateY(-1px);
}
.modal-btn-primary:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}
.modal-btn-confirm {
    background: var(--green, #32CD32);
    color: var(--green-deep, #0A1F0A);
}
.modal-btn-confirm:hover:not(:disabled) {
    background: var(--green-dark, #228B22);
    color: #fff;
}

/* Confirm step */
.confirm-order-list {
    border: 1px solid var(--border);
    border-radius: 0.75rem;
    overflow: hidden;
    margin-bottom: 1rem;
}
.confirm-order-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid #f3f3f3;
}
.confirm-order-row:last-child {
    border-bottom: none;
}
.confirm-date {
    font-weight: 600;
    color: var(--ink);
    font-size: 0.88rem;
}
.confirm-qty {
    font-size: 0.78rem;
    color: var(--stone);
    margin-left: 0.5rem;
}
.confirm-amount {
    font-weight: 700;
    color: var(--ink);
    font-size: 0.88rem;
}

.confirm-totals {
    margin-bottom: 1rem;
}
.confirm-total-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--slate);
    padding: 0.25rem 0;
}
.confirm-total-row.grand {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 2px solid var(--border);
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink);
}
.confirm-total-row.grand span:last-child {
    color: var(--orange);
}

.confirm-pay-method {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.875rem;
    background: var(--bg-soft);
    border-radius: 0.5rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--slate);
}

/* Spinner */
.modal-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2.5px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: modal-spin 0.6s linear infinite;
}
@keyframes modal-spin {
    to { transform: rotate(360deg); }
}

/* Result screen (step 3) */
.result-screen {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 2.5rem 1.5rem 2rem;
    text-align: center;
}
.processing-spinner-lg {
    width: 44px;
    height: 44px;
    border: 4px solid var(--border, #E8E8E8);
    border-top-color: var(--orange, #FF8C00);
    border-radius: 50%;
    animation: modal-spin 0.7s linear infinite;
}
.result-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    animation: result-pop 0.35s ease-out;
}
.result-icon.is-success {
    background: var(--green-soft, #E8FBE8);
    color: var(--green-dark, #228B22);
}
.result-icon.is-error {
    background: #FEF2F2;
    color: #DC2626;
}
@keyframes result-pop {
    0% { transform: scale(0.5); opacity: 0; }
    60% { transform: scale(1.15); }
    100% { transform: scale(1); opacity: 1; }
}
.result-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink);
}
.result-subtitle {
    font-size: 0.85rem;
    color: var(--stone, #8C8C8C);
}
.result-warning {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--slate, #3D3D3D);
    padding: 0.5rem 1rem;
    background: #FFF8E1;
    border-radius: 8px;
}
.result-warning i { color: var(--orange, #FF8C00); }
.result-summary {
    width: 100%;
    max-width: 260px;
    border: 2px solid var(--green, #32CD32);
    border-radius: 12px;
    padding: 0.75rem 1rem;
    background: var(--green-soft, #E8FBE8);
}
.result-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--ink);
}
.result-amount {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--green-dark, #228B22);
}
.result-redirect-msg {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    color: var(--stone, #8C8C8C);
    margin-top: 0.25rem;
}
.result-error-detail-box {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: #FEF2F2;
    border: 1px solid #FECACA;
    border-radius: 10px;
    max-width: 360px;
    margin: 0.5rem auto 0;
}
.result-error-detail {
    font-size: 0.85rem;
    color: #DC2626;
    word-break: break-word;
    line-height: 1.5;
    margin: 0;
}

/* ════════════════════════════════════════════
   AUTH MODAL
   ════════════════════════════════════════════ */
.auth-tabs {
    display: flex;
    border-bottom: 2px solid var(--border, #E8E8E8);
}
.auth-tab {
    flex: 1;
    padding: 1rem;
    border: none;
    background: transparent;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--stone, #8C8C8C);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    transition: all 0.15s;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    font-family: inherit;
}
.auth-tab.active {
    color: var(--orange, #FF8C00);
    border-bottom-color: var(--orange, #FF8C00);
}
.auth-tab:not(.active):hover {
    color: var(--ink, #1A1A1A);
    background: var(--bg-soft, #FAFAF8);
}

.auth-form-group {
    margin-bottom: 0.75rem;
}
.auth-error {
    padding: 0.6rem 0.75rem;
    background: #FEF2F2;
    border: 1px solid #FECACA;
    border-radius: 8px;
    font-size: 0.8rem;
    color: #DC2626;
    margin-top: 0.5rem;
}
.auth-submit-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}
.auth-switch-link {
    text-align: center;
    font-size: 0.8rem;
    color: var(--stone, #8C8C8C);
    margin-top: 1rem;
}
.auth-switch-link a {
    color: var(--orange, #FF8C00);
    font-weight: 700;
    text-decoration: none;
}
.auth-switch-link a:hover {
    text-decoration: underline;
}
.auth-note {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    color: var(--stone, #8C8C8C);
    margin-top: 0.75rem;
    padding: 0.5rem 0.75rem;
    background: var(--bg-soft, #FAFAF8);
    border-radius: 8px;
}

/* Mobile modal */
@media (max-width: 520px) {
    .pay-modal {
        max-width: 100%;
        border-radius: 1rem 1rem 0 0;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        max-height: 85vh;
        overflow-y: auto;
    }
    .pay-modal-overlay {
        align-items: flex-end;
        padding: 0;
    }
}

/* ════════════════════════════════════════════════════════════
   ORDER WIZARD — Step-by-step flow
   ════════════════════════════════════════════════════════════ */

/* Container */
.wizard-wrap {
    max-width: 780px;
    margin: 0 auto;
    padding: 2rem 1.5rem 7rem;
}

/* ── Stepper bar ── */
.wizard-stepper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin-bottom: 2.5rem;
    padding: 0 0.5rem;
    scroll-margin-top: 124px;
}

#days-section {
    scroll-margin-top: 124px;
}
.wz-step-group { display: contents; }
.wz-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    cursor: default;
}
.wz-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 0.88rem;
    border: 2.5px solid var(--border);
    color: var(--stone);
    background: #fff;
    transition: all 0.35s cubic-bezier(.4,0,.2,1);
}
.wz-step.is-active .wz-circle {
    border-color: var(--orange);
    background: var(--orange);
    color: #fff;
    box-shadow: 0 0 0 6px rgba(255,140,0,0.12), 0 3px 12px rgba(255,140,0,0.25);
}
.wz-step.is-done .wz-circle {
    border-color: var(--green);
    background: var(--green);
    color: #fff;
}
.wz-label {
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--stone);
    margin-top: 7px;
    white-space: nowrap;
    letter-spacing: 0.02em;
    transition: color 0.3s;
}
.wz-step.is-active .wz-label { color: var(--orange-dark); font-weight: 700; }
.wz-step.is-done .wz-label { color: var(--green-dark); }
.wz-line {
    flex: 1;
    height: 3px;
    background: var(--border);
    min-width: 20px;
    max-width: 80px;
    margin: 0 6px;
    margin-top: 19px;
    border-radius: 2px;
    transition: background 0.35s;
}
.wz-line.is-done { background: var(--green); }

/* ── Pulse animation (used by CTA buttons) ── */
@keyframes order-start-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(255,140,0,0.4); }
    50%      { box-shadow: 0 0 0 10px rgba(255,140,0,0); }
}

/* ── Step panels ── */
.wizard-panel {
    animation: wzSlideUp 0.35s cubic-bezier(.4,0,.2,1);
}
@keyframes wzSlideUp {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
}
.wz-step-title {
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--ink);
    text-align: center;
    margin-bottom: 0.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.wz-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--orange, #FF8C00);
    color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    flex-shrink: 0;
    line-height: 1;
}
.wz-step-desc {
    font-size: 0.85rem;
    color: var(--stone);
    text-align: center;
    margin-bottom: 1.75rem;
    line-height: 1.6;
}

/* ── Menu intro card ── */
.wz-menu-intro {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    background: rgba(255,255,255,0.45);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 12px;
    padding: 0.85rem 1rem;
    margin-top: 1.25rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.wz-menu-intro > i {
    color: var(--orange, #FF8C00);
    font-size: 0.85rem;
    margin-top: 2px;
    flex-shrink: 0;
}
.wz-menu-intro-title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--ink, #1A1A1A);
    margin-bottom: 3px;
}
.wz-menu-intro-desc {
    font-size: 0.78rem;
    color: var(--slate, #3D3D3D);
    line-height: 1.65;
}

/* ── Step 1: Type cards ── */
.wz-type-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.wz-type-card {
    border: 2.5px solid var(--border);
    border-radius: 18px;
    padding: 2rem 1.25rem 1.75rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(.4,0,.2,1);
    background: #fff;
    position: relative;
    overflow: hidden;
}
.wz-type-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--orange-soft);
    opacity: 0;
    transition: opacity 0.2s;
}
.wz-type-card:hover {
    border-color: var(--orange);
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.06);
}
.wz-type-card:hover::before { opacity: 0.4; }
.wz-type-card.is-selected {
    border-color: var(--orange);
    box-shadow: 0 0 0 4px rgba(255,140,0,0.1), 0 8px 30px rgba(0,0,0,0.06);
}
.wz-type-card.is-selected::before { opacity: 1; }
.wz-type-card > * { position: relative; z-index: 1; }
.wz-type-icon {
    font-size: 2.2rem;
    color: var(--orange);
    margin-bottom: 0.75rem;
}
.wz-type-card.is-selected .wz-type-icon { color: var(--orange-dark); }
.wz-type-name {
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 0.4rem;
}
.wz-type-desc {
    font-size: 0.78rem;
    color: var(--stone);
    line-height: 1.55;
    margin-bottom: 0.75rem;
}
.wz-type-price {
    display: inline-block;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--orange);
    background: rgba(255,140,0,0.08);
    padding: 4px 14px;
    border-radius: 100px;
}
.wz-type-prices {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}
.wz-type-price-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.1rem;
}
.wz-type-price-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--stone, #8C8C8C);
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.wz-type-price-label i {
    font-size: 0.7rem;
}
.wz-type-price-line {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--orange);
    white-space: nowrap;
}
.wz-type-price-line i {
    font-size: 0.85rem;
    color: var(--stone, #8C8C8C);
}
.wz-type-check {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--orange);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.25s cubic-bezier(.4,0,.2,1);
}
.wz-type-card.is-selected .wz-type-check {
    opacity: 1;
    transform: scale(1);
}

/* ── Step 2: Frequency cards ── */
.wz-freq-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.wz-freq-card {
    border: 2.5px solid var(--border);
    border-radius: 18px;
    padding: 1.75rem 1rem 1.5rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    background: #fff;
    position: relative;
    overflow: hidden;
}
.wz-freq-card:hover {
    border-color: var(--orange);
    transform: translateY(-2px);
    box-shadow: 0 6px 24px rgba(0,0,0,0.05);
}
.wz-freq-card.is-selected {
    border-color: var(--orange);
    background: var(--orange-soft);
    box-shadow: 0 0 0 4px rgba(255,140,0,0.1);
}
.wz-freq-badge {
    position: absolute;
    top: 12px;
    right: -32px;
    transform: rotate(35deg);
    background: var(--green);
    color: #fff;
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 0.58rem;
    font-weight: 800;
    padding: 3px 36px;
    white-space: nowrap;
    letter-spacing: 0.06em;
    z-index: 2;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.wz-freq-badge-recommend {
    background: var(--orange);
}
.wz-freq-badge-current {
    background: var(--green);
    right: -28px;
    top: 10px;
}
.wz-freq-times {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--ink);
    line-height: 1;
}
.wz-freq-unit {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--stone);
    margin-top: 0.25rem;
}
.wz-freq-price {
    font-size: 1rem;
    font-weight: 700;
    color: var(--orange);
    margin-top: 0.75rem;
}
.wz-freq-calc {
    font-size: 0.72rem;
    color: var(--stone);
    margin-top: 0.5rem;
    line-height: 1.4;
}
.wz-freq-check {
    position: absolute;
    top: 10px;
    left: 10px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--orange);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.25s;
}
.wz-freq-card.is-selected .wz-freq-check {
    opacity: 1;
    transform: scale(1);
}

/* ── Step 1: Photo marquee ── */
.wz-photo-marquee {
    overflow: hidden;
    margin-top: 1.5rem;
    margin-bottom: 1rem;
}
.wz-photo-track {
    display: flex;
    gap: 0.75rem;
    width: max-content;
    animation: marqueeScroll 25s linear infinite;
}
.wz-photo-item {
    width: 220px;
    height: 150px;
    object-fit: cover;
    border-radius: 14px;
    flex-shrink: 0;
}
@keyframes marqueeScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.wz-photo-marquee:hover .wz-photo-track {
    animation-play-state: paused;
}

/* ── Step 3: Subscription weekday buttons ── */
.wz-weekday-grid {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.wz-weekday-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    width: 64px;
    height: 64px;
    border: 2.5px solid var(--border);
    border-radius: 14px;
    background: #fff;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
    position: relative;
}
.wz-weekday-btn:hover {
    border-color: var(--orange);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.wz-weekday-btn.is-selected {
    border-color: var(--orange);
    background: var(--orange-soft);
    box-shadow: 0 0 0 3px rgba(255,140,0,0.1);
}
.wz-weekday-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    transform: none;
}
.wz-weekday-label {
    font-family: 'Syne', 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ink);
}
.wz-weekday-btn.is-selected .wz-weekday-label {
    color: var(--orange-dark);
}
.wz-weekday-check {
    font-size: 0.7rem;
    color: var(--orange);
}

/* ── Start date selector ── */
.wz-auto-start-date {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 1rem;
    padding: 0.75rem 1rem;
    background: var(--orange-soft, #FFF3E0);
    border: 1.5px solid var(--orange, #FF8C00);
    border-radius: 10px;
    font-size: 0.85rem;
    color: var(--ink);
}
.wz-auto-start-date > i {
    color: var(--orange);
    font-size: 0.9rem;
}
.wz-auto-start-date strong {
    color: var(--orange-dark, #CC7000);
}

/* ── Step 3: Day selection ── */
.wz-selection-status {
    text-align: center;
    font-size: 0.88rem;
    color: var(--stone);
    margin-bottom: 1rem;
    font-weight: 600;
}
.wz-selection-status .is-ok { color: var(--green-dark); }
.wz-week-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
    justify-content: center;
}

/* ── Individual order: Date + Qty rows ── */
.wz-ind-rows {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1rem;
}
.wz-ind-row {
    background: white;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 12px;
    padding: 0.75rem;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.wz-ind-row:focus-within {
    border-color: var(--orange, #FF8C00);
    box-shadow: 0 0 0 2px rgba(255, 140, 0, 0.1);
}
.wz-ind-row.has-warning {
    border-color: #e6a700;
    background: #fffbf0;
}
.wz-ind-row-fields {
    display: flex;
    align-items: flex-end;
    gap: 0.75rem;
}
.wz-ind-field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.wz-ind-field label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--stone, #8C8C8C);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.wz-ind-field--date {
    flex: 1;
    position: relative;
}

/* Calendar date button */
.wz-ind-date-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    text-align: left;
}
.wz-ind-date-btn.has-value {
    color: var(--ink, #1A1A1A);
}
.wz-ind-date-placeholder {
    color: var(--stone, #8C8C8C);
    font-weight: 500;
}
.wz-ind-date-icon {
    color: var(--orange, #FF8C00);
    font-size: 0.85rem;
    flex-shrink: 0;
}

/* Calendar dropdown (above fixed .wizard-nav z-index:100 on narrow screens) */
.wz-ind-cal-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    z-index: 280;
    background: #fff;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 14px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.12);
    padding: 12px;
    width: 280px;
}
.wz-ind-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}
.wz-ind-cal-title {
    font-size: 0.85rem;
    font-weight: 800;
    color: var(--ink, #1A1A1A);
}
.wz-ind-cal-nav {
    width: 28px;
    height: 28px;
    border: none;
    background: var(--bg-soft, #FAFAF8);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--slate, #3D3D3D);
    font-size: 0.65rem;
    transition: all 0.12s;
}
.wz-ind-cal-nav:hover {
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange, #FF8C00);
}
.wz-ind-cal-dow {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    margin-bottom: 4px;
}
.wz-ind-cal-dow span {
    text-align: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--stone, #8C8C8C);
    padding: 2px 0;
}
.wz-ind-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}
.wz-ind-cal-day {
    width: 100%;
    aspect-ratio: 1;
    border: none;
    border-radius: 8px;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--ink, #1A1A1A);
    cursor: pointer;
    transition: all 0.1s;
    font-family: inherit;
}
.wz-ind-cal-day:hover:not(.is-disabled):not(.is-empty):not(.is-selected) {
    background: var(--orange-soft, #FFF3E0);
    color: var(--orange, #FF8C00);
}
.wz-ind-cal-day.is-empty {
    cursor: default;
}
.wz-ind-cal-day.is-disabled {
    color: var(--border, #E8E8E8);
    cursor: not-allowed;
    text-decoration: line-through;
}
.wz-ind-cal-day.is-selected {
    background: var(--orange, #FF8C00);
    color: #fff;
    font-weight: 800;
}
.wz-ind-cal-day.is-today:not(.is-selected) {
    box-shadow: inset 0 0 0 1.5px var(--orange, #FF8C00);
}

.wz-ind-field--qty {
    width: 80px;
    flex-shrink: 0;
}
.wz-ind-input {
    padding: 0.5rem 0.6rem;
    border: 1.5px solid var(--border, #E8E8E8);
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ink, #1A1A1A);
    background: var(--bg-soft, #FAFAF8);
    font-family: inherit;
    transition: border-color 0.15s;
    width: 100%;
    box-sizing: border-box;
}
.wz-ind-input:focus {
    outline: none;
    border-color: var(--orange, #FF8C00);
}
.wz-ind-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: none;
    background: rgba(0,0,0,0.04);
    border-radius: 8px;
    cursor: pointer;
    color: var(--stone, #8C8C8C);
    font-size: 0.85rem;
    flex-shrink: 0;
    transition: all 0.12s;
    margin-bottom: 1px;
}
.wz-ind-remove:hover {
    background: rgba(220, 50, 50, 0.08);
    color: #c33;
}
.wz-ind-warning {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.5rem;
    padding: 0.35rem 0.6rem;
    background: #fff5db;
    border: 1px solid #e6c44a;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #8a6b00;
}
.wz-ind-warning i {
    color: #c49000;
    font-size: 0.8rem;
}
.wz-ind-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.65rem;
    border: 2px dashed var(--border, #E8E8E8);
    border-radius: 12px;
    background: transparent;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--orange, #FF8C00);
    font-family: inherit;
    transition: all 0.15s;
}
.wz-ind-add-btn:hover {
    border-color: var(--orange, #FF8C00);
    background: var(--orange-soft, #FFF3E0);
}
.wz-ind-summary {
    margin-top: 1rem;
    padding: 0.75rem 1rem;
    background: var(--bg-soft, #FAFAF8);
    border: 1px solid var(--border, #E8E8E8);
    border-radius: 10px;
}
.wz-ind-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--slate, #3D3D3D);
}
.wz-ind-summary-row + .wz-ind-summary-row {
    margin-top: 0.4rem;
}
.wz-ind-summary-row strong {
    font-size: 1.05rem;
    color: var(--ink, #1A1A1A);
}
.wz-ind-summary-warn {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    color: var(--orange-dark, #CC7000);
    font-weight: 600;
}
.wz-ind-summary-warn i {
    font-size: 0.75rem;
}

/* ── Step 4: Payment ── */
.wz-pay-section {
    max-width: 500px;
    margin: 0 auto;
}
.wz-pay-block {
    margin-bottom: 0;
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--border);
}
.wz-pay-block:last-child {
    border-bottom: none;
}
.wz-pay-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 0.6rem;
    display: flex;
    align-items: center;
    gap: 7px;
}
.wz-pay-label i { color: var(--orange); font-size: 0.9rem; }
.wz-pay-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}
.wz-pay-btn {
    border: 2.5px solid var(--border);
    border-radius: 14px;
    padding: 1.1rem 0.75rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.15s;
    background: #fff;
    font-family: inherit;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--slate);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.wz-pay-btn i { font-size: 1.2rem; }
.wz-pay-btn:hover { border-color: var(--orange); }
.wz-pay-btn.is-selected {
    border-color: var(--orange);
    background: var(--orange-soft);
    color: var(--orange-dark);
}
.wz-card-area {
    margin-top: 1.25rem;
    padding: 1.25rem;
    border: 1.5px solid var(--border);
    border-radius: 14px;
    background: var(--bg-soft);
}
.wz-select {
    width: 100%;
    padding: 0.7rem 0.875rem;
    border: 2px solid var(--border);
    border-radius: 10px;
    font-family: inherit;
    font-size: 0.88rem;
    color: var(--ink);
    background: #fff;
    outline: none;
    transition: border-color 0.15s;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%238C8C8C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 2.5rem;
}
.wz-select:focus { border-color: var(--orange); }
.wz-textarea {
    width: 100%;
    padding: 0.7rem 0.875rem;
    border: 2px solid var(--border);
    border-radius: 10px;
    font-family: inherit;
    font-size: 16px;
    color: var(--ink);
    background: #fff;
    outline: none;
    resize: vertical;
    transition: border-color 0.15s;
}
.wz-textarea:focus { border-color: var(--orange); }
.wz-security-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 0.75rem;
    font-size: 0.72rem;
    color: #16a34a;
    background: #f0fdf4;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
}

/* ── Step 5: Confirmation ── */
.wz-confirm {
    max-width: 520px;
    margin: 0 auto;
}
.wz-confirm-card {
    border: 2px solid var(--border);
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
}
.wz-confirm-section {
    padding: 0.85rem 1.25rem;
    border-bottom: 1px solid var(--border);
}
.wz-confirm-section:last-child { border-bottom: none; }
.wz-confirm-section-title {
    font-family: 'Syne', sans-serif;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 0.4rem;
}
.wz-confirm-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    font-size: 0.85rem;
    color: var(--ink);
    padding: 3px 0;
    gap: 0.75rem;
}
.wz-confirm-row .label {
    color: var(--slate);
    white-space: nowrap;
    flex-shrink: 0;
}
.wz-confirm-row .value {
    font-weight: 600;
    text-align: right;
}
.wz-confirm-day-tags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.wz-confirm-day-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--orange-soft);
    color: var(--orange-dark);
    border-radius: 100px;
    font-size: 0.78rem;
    font-weight: 600;
}
.wz-confirm-total-section {
    background: var(--orange-soft);
    padding: 1rem 1.25rem;
}
.wz-confirm-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    font-size: 0.85rem;
    color: var(--slate);
    padding: 3px 0;
}
.wz-confirm-grand {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.5rem;
    padding-top: 0.65rem;
    border-top: 2px solid rgba(255,140,0,0.2);
}
.wz-confirm-grand .label {
    font-size: 1rem;
    font-weight: 800;
    color: var(--ink);
}
.wz-confirm-grand .value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--orange-dark);
}

/* ── Wizard navigation ── */
.wizard-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 2.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1.5px solid var(--border);
    gap: 1rem;
}
.wz-nav-back {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 12px 22px;
    border: 2px solid var(--border);
    border-radius: 12px;
    background: #fff;
    font-family: inherit;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--slate);
    cursor: pointer;
    transition: all 0.15s;
}
.wz-nav-back:hover {
    border-color: var(--orange);
    color: var(--orange);
    background: var(--orange-soft);
}
.wz-nav-spacer { flex: 1; }
.wz-order-hint {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--orange);
    animation: hintBounce 1.2s ease-in-out infinite;
    white-space: nowrap;
}
@keyframes hintBounce {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(5px); }
}
.wz-nav-next {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 12px 32px;
    border: none;
    border-radius: 12px;
    background: var(--orange);
    font-family: inherit;
    font-size: 0.9rem;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 3px 12px rgba(255,140,0,0.25);
}
.wz-nav-next:hover:not(:disabled) {
    background: var(--orange-dark);
    transform: translateY(-1px);
    box-shadow: 0 5px 18px rgba(255,140,0,0.3);
}
.wz-nav-next:not(:disabled) {
    animation: wzNextPulse 1.8s ease-in-out infinite;
}
@keyframes wzNextPulse {
    0%, 100% { box-shadow: 0 3px 12px rgba(255,140,0,0.25); }
    50% { box-shadow: 0 4px 20px rgba(255,140,0,0.5); transform: translateY(-2px); }
}
.wz-nav-next:hover:not(:disabled) {
    animation: none;
}
.wz-nav-next:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
    animation: none;
}
.wz-nav-submit {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 36px;
    border: none;
    border-radius: 12px;
    background: var(--green);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 3px 14px rgba(50,205,50,0.3);
}
.wz-nav-submit:hover:not(:disabled) {
    background: var(--green-dark);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 5px 20px rgba(50,205,50,0.35);
}
.wz-nav-submit:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}
.wz-nav-login {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 36px;
    border: none;
    border-radius: 12px;
    background: var(--orange);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 3px 14px rgba(255,140,0,0.25);
}
.wz-nav-login:hover {
    background: var(--orange-dark);
    transform: translateY(-1px);
}

/* ── Processing overlay ── */
.wz-processing-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(6px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    animation: wzFadeIn 0.2s ease;
}
@keyframes wzFadeIn { from { opacity: 0; } to { opacity: 1; } }
.wz-processing-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--border);
    border-top-color: var(--orange);
    border-radius: 50%;
    animation: wzSpin 0.7s linear infinite;
}
@keyframes wzSpin { to { transform: rotate(360deg); } }
.wz-processing-text {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--ink);
}
.wz-processing-warning {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: var(--stone);
    background: #FFF8E1;
    padding: 0.5rem 1rem;
    border-radius: 8px;
}
.wz-processing-warning i { color: var(--orange); }

/* Result screen */
.wz-result-screen {
    text-align: center;
    padding: 3rem 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    animation: wzSlideUp 0.4s ease-out;
}
.wz-result-icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    margin-bottom: 1rem;
    animation: result-pop 0.4s cubic-bezier(.34,1.56,.64,1);
}
.wz-result-icon.is-success { background: var(--green-soft); color: var(--green-dark); }
.wz-result-icon.is-error { background: #FEF2F2; color: #DC2626; }
.wz-result-title {
    font-family: 'Syne', sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 0.35rem;
}
.wz-result-subtitle {
    font-size: 0.85rem;
    color: var(--stone);
    margin-bottom: 1rem;
}
.wz-result-summary {
    display: inline-block;
    border: 2px solid var(--green);
    border-radius: 14px;
    padding: 0.75rem 1.5rem;
    background: var(--green-soft);
    margin-bottom: 1rem;
}
.wz-result-amount {
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--green-dark);
}
.wz-cash-notice {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    margin-top: 1.25rem;
    padding: 1rem 1.25rem;
    background: var(--orange-soft);
    border-radius: 0.75rem;
    border: 1px solid var(--border);
    max-width: 22rem;
}
.wz-cash-notice-item {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.88rem;
    color: var(--slate);
    line-height: 1.5;
}
.wz-cash-notice-item i {
    flex-shrink: 0;
    margin-top: 0.2rem;
    color: var(--orange);
    font-size: 0.85rem;
}
.wz-result-redirect {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.78rem;
    color: var(--stone);
}
.wz-result-actions {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

/* ── Wizard responsive ── */
@media (max-width: 900px) {
    .wizard-nav {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: #fff;
        border-top: 1.5px solid var(--border);
        box-shadow: 0 -4px 24px rgba(0,0,0,0.08);
        padding: 0.5rem 0.75rem;
        padding-bottom: calc(0.5rem + env(safe-area-inset-bottom));
        margin-top: 0;
        z-index: 100;
        border-radius: 0;
    }
}
@media (max-width: 640px) {
    /* ── Wizard wrapper: tight padding ── */
    .wizard-wrap {
        padding: 0.75rem 0.75rem 5rem;
    }

    /* ── Stepper: ultra-compact ── */
    .wizard-stepper {
        margin-bottom: 0.75rem;
    }
    .wz-circle {
        width: 26px;
        height: 26px;
        font-size: 0.68rem;
        border-width: 2px;
    }
    .wz-step.is-active .wz-circle {
        box-shadow: 0 0 0 3px rgba(255,140,0,0.12);
    }
    .wz-line {
        min-width: 10px;
        margin-top: 12px;
        height: 2px;
    }
    .wz-label {
        font-size: 0.52rem;
        margin-top: 3px;
    }

    /* ── Step titles/desc: compact ── */
    .wz-step-title {
        font-size: 1rem;
        margin-bottom: 0.15rem;
    }
    .wz-step-desc {
        font-size: 0.72rem;
        margin-bottom: 0.6rem;
        line-height: 1.45;
    }

    /* ── Step 1: Photo marquee compact ── */
    .wz-photo-marquee {
        margin-top: 2.5rem;
    }
    .wz-photo-item {
        width: 170px;
        height: 115px;
        border-radius: 10px;
    }
    .wz-photo-track {
        gap: 0.5rem;
    }

    /* ── Step 1: Type cards side-by-side ── */
    .wz-type-grid {
        grid-template-columns: 1fr 1fr;
        gap: 0.5rem;
    }
    .wz-type-card {
        padding: 0.75rem 0.6rem 0.65rem;
        border-radius: 12px;
        border-width: 2px;
    }
    .wz-type-icon {
        font-size: 1.4rem;
        margin-bottom: 0.3rem;
    }
    .wz-type-name {
        font-size: 0.78rem;
        margin-bottom: 0.15rem;
    }
    .wz-type-desc {
        font-size: 0.6rem;
        line-height: 1.35;
        margin-bottom: 0.35rem;
    }
    .wz-type-price {
        font-size: 0.7rem;
        padding: 2px 8px;
    }
    .wz-type-price-line {
        font-size: 0.9rem;
    }
    .wz-type-check {
        top: 6px;
        right: 6px;
        width: 20px;
        height: 20px;
        font-size: 0.55rem;
    }

    /* ── Step 2: Frequency cards 3-col ── */
    .wz-freq-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 0.4rem;
    }
    .wz-freq-card {
        padding: 0.9rem 0.35rem 0.65rem;
        border-radius: 12px;
        border-width: 2px;
    }
    .wz-freq-badge {
        top: 8px;
        right: -34px;
        font-size: 0.45rem;
        padding: 2px 32px;
    }
    .wz-freq-times {
        font-size: 1.2rem;
    }
    .wz-freq-unit {
        font-size: 0.6rem;
    }
    .wz-freq-price {
        font-size: 0.8rem;
        margin-top: 0.35rem;
    }
    .wz-freq-price small {
        font-size: 0.6rem;
    }
    .wz-freq-calc {
        font-size: 0.6rem;
        margin-top: 0.25rem;
    }
    .wz-freq-check {
        top: 5px;
        left: 5px;
        width: 18px;
        height: 18px;
        font-size: 0.5rem;
    }

    /* ── Step 3: Day selection compact ── */
    .wz-weekday-grid {
        gap: 0.35rem;
        margin-bottom: 0.6rem;
    }
    .wz-weekday-btn {
        width: 52px;
        height: 52px;
        border-radius: 12px;
        border-width: 2px;
    }
    .wz-weekday-label {
        font-size: 0.9rem;
    }
    .wz-auto-start-date {
        font-size: 0.78rem;
        padding: 0.6rem 0.85rem;
    }
    .wz-selection-status {
        font-size: 0.75rem;
        margin-bottom: 0.5rem;
    }
    .wz-week-tabs {
        margin-bottom: 0.5rem;
    }

    /* ── Upcoming orders compact ── */
    .upcoming-order-row {
        padding: 0.5rem 0.75rem;
        gap: 0.5rem;
    }
    .upcoming-order-date {
        min-width: 90px;
    }
    .upcoming-order-datestr {
        font-size: 0.82rem;
    }
    .upcoming-order-status {
        font-size: 0.62rem;
        padding: 2px 6px;
    }

    /* ── Individual rows compact ── */
    .wz-ind-row {
        padding: 0.6rem;
    }
    .wz-ind-row-fields {
        gap: 0.5rem;
    }
    .wz-ind-field--qty {
        width: 68px;
    }
    .wz-ind-input {
        padding: 0.45rem 0.5rem;
        font-size: 0.85rem;
    }
    .wz-ind-cal-dropdown {
        width: 260px;
        left: 0;
        right: auto;
    }
    .wz-ind-add-btn {
        padding: 0.55rem;
        font-size: 0.8rem;
    }
    .wz-ind-summary {
        padding: 0.6rem 0.75rem;
    }

    /* ── Step 4: Payment compact ── */
    .wz-pay-section {
        gap: 0.6rem;
    }
    .wz-pay-block {
        padding: 0.85rem 0;
    }
    .wz-pay-label {
        font-size: 0.75rem;
        margin-bottom: 0.35rem;
    }
    .wz-pay-toggle {
        grid-template-columns: 1fr 1fr;
        gap: 0.4rem;
    }

    /* ── Step 5: Confirm compact ── */
    .wz-confirm-section {
        padding: 0.65rem 1rem;
    }
    .wz-confirm-section-title {
        font-size: 0.7rem;
        margin-bottom: 0.3rem;
    }
    .wz-confirm-row {
        font-size: 0.78rem;
    }
    .wz-confirm-total-section {
        padding: 0.85rem 1rem;
    }
    .wz-confirm-total-row {
        font-size: 0.78rem;
    }
    .wz-confirm-grand .value {
        font-size: 1.15rem;
    }

    /* ── Nav bar compact ── */
    .wizard-nav {
        margin-top: 1rem;
        padding-top: 0.75rem;
    }
    .wz-nav-back {
        padding: 8px 14px;
        font-size: 0.78rem;
        border-radius: 10px;
    }
    .wz-nav-next {
        padding: 8px 22px;
        font-size: 0.82rem;
        border-radius: 10px;
    }
    .wz-nav-submit {
        padding: 10px 24px;
        font-size: 0.85rem;
        border-radius: 10px;
    }
    .wz-nav-login {
        padding: 10px 24px;
        font-size: 0.85rem;
        border-radius: 10px;
    }
}
