/* ── Subdomain Calendar — mobile-first ────────────────────────────────────── */

:root {
    --sdc-top: 52px;
    --sdc-strip: 76px;
}

/* ── Top bar ──────────────────────────────────────────────────────────────── */
.sdc-top-bar {
    position: sticky;
    top: 0;
    z-index: 120;
    display: flex;
    align-items: center;
    gap: 8px;
    height: var(--sdc-top);
    padding: 0 12px;
    background: rgba(255,248,239,.94);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--g-line);
}
.sdf-theme-anime .sdc-top-bar { background: rgba(15,16,32,.94); }


.sdc-date-pill {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-width: 0;
    height: 38px;
    padding: 0 10px;
    border-radius: 10px;
    border: 1px solid rgba(125,77,255,.18);
    background: rgba(125,77,255,.06);
    cursor: pointer;
    overflow: hidden;
}
.sdc-date-pill strong {
    font-size: .8rem;
    font-weight: 800;
    color: var(--g-violet);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    line-height: 1.2;
}
.sdc-date-pill span {
    font-size: .62rem;
    color: var(--g-muted);
    white-space: nowrap;
    line-height: 1;
}

.sdc-view-tabs {
    display: none;
    gap: 2px;
    background: rgba(0,0,0,.05);
    border-radius: 10px;
    padding: 3px;
    flex-shrink: 0;
}
.sdc-view-tabs button {
    padding: 5px 12px;
    border-radius: 8px;
    border: none;
    background: transparent;
    font-size: .75rem;
    font-weight: 700;
    color: var(--g-muted);
    cursor: pointer;
    transition: background .15s, color .15s;
}
.sdc-view-tabs button.is-active {
    background: #fff;
    color: var(--g-violet);
    box-shadow: 0 1px 4px rgba(0,0,0,.1);
}

.sdc-filter-toggle {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    height: 38px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid var(--g-line);
    background: rgba(255,255,255,.6);
    font-size: .78rem;
    font-weight: 700;
    color: var(--g-text);
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s, color .15s, border-color .15s;
}
.sdc-filter-toggle.is-active {
    background: var(--g-violet);
    border-color: var(--g-violet);
    color: #fff;
}
.sdc-filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--g-pink);
    color: #fff;
    font-size: .62rem;
    font-weight: 800;
}

/* ── Strip bar ────────────────────────────────────────────────────────────── */
.sdc-strip-bar {
    position: sticky;
    top: var(--sdc-top);
    z-index: 110;
    display: flex;
    align-items: stretch;
    background: rgba(255,248,239,.97);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--g-line);
    height: var(--sdc-strip);
}
.sdf-theme-anime .sdc-strip-bar { background: rgba(15,16,32,.97); }

.sdc-nav-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    border: none;
    background: transparent;
    font-size: 1.3rem;
    color: var(--g-muted);
    cursor: pointer;
    flex-shrink: 0;
}
.sdc-nav-arrow:hover { color: var(--g-violet); }

.sdc-week-strip {
    flex: 1;
    display: flex;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    gap: 3px;
    padding: 7px 4px;
    align-items: stretch;
}
.sdc-week-strip::-webkit-scrollbar { display: none; }

.sdc-week-day {
    flex: 1 0 0;
    min-width: 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    border-radius: 12px;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 5px 3px;
    transition: background .13s;
}
.sdc-week-day > span {
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--g-muted);
}
.sdc-week-day > strong {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--g-text);
    line-height: 1;
}
.sdc-week-day > em {
    font-style: normal;
    font-size: .58rem;
    font-weight: 700;
    color: transparent;
}
.sdc-week-day.has-events > em { color: var(--g-coral); }
.sdc-week-day.is-today > span,
.sdc-week-day.is-today > strong { color: var(--g-violet); }
.sdc-week-day.is-selected {
    background: var(--g-violet);
}
.sdc-week-day.is-selected > span,
.sdc-week-day.is-selected > strong,
.sdc-week-day.is-selected > em { color: #fff; }

/* ── Month grid ───────────────────────────────────────────────────────────── */
.sdc-month-wrap { padding: 12px 16px; }
.sdc-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-size: .67rem;
    font-weight: 700;
    color: var(--g-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    padding-bottom: 4px;
}
.sdc-month-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}
.sdc-day-cell {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 4px 2px;
    border-radius: 10px;
    border: none;
    background: transparent;
    cursor: pointer;
    transition: background .12s;
    min-height: 52px;
}
.sdc-day-cell:hover { background: rgba(125,77,255,.07); }
.sdc-day-cell.is-outside { opacity: .35; }
.sdc-day-cell.is-today .sdc-day-number { color: var(--g-violet); font-weight: 900; }
.sdc-day-cell.is-selected { background: rgba(125,77,255,.12); }
.sdc-day-number {
    font-size: .82rem;
    font-weight: 700;
    color: var(--g-text);
    display: flex;
    align-items: center;
    gap: 3px;
}
.sdc-day-count { font-size: .6rem; font-weight: 800; color: var(--g-violet); }
.sdc-day-events { display: flex; gap: 2px; margin-top: 2px; flex-wrap: wrap; justify-content: center; }
.sdc-event-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--g-violet); display: block; }
.sdc-event-more { font-size: .55rem; color: var(--g-muted); font-weight: 700; }

/* ── Quick rail ───────────────────────────────────────────────────────────── */
.sdc-quick-rail {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 10px 12px 4px;
    border-bottom: 1px solid var(--g-line);
}
.sdc-quick-rail::-webkit-scrollbar { display: none; }
.sdc-quick-rail button {
    display: inline-flex;
    align-items: center;
    height: 32px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1.5px solid var(--g-line);
    background: rgba(255,255,255,.6);
    font-size: .78rem;
    font-weight: 700;
    color: var(--g-text);
    cursor: pointer;
    white-space: nowrap;
    font-family: inherit;
    transition: background .13s, color .13s, border-color .13s;
    flex-shrink: 0;
}
.sdc-quick-rail button.is-active {
    background: var(--g-violet);
    border-color: var(--g-violet);
    color: #fff;
}
.sdf-theme-anime .sdc-quick-rail button { background: rgba(255,255,255,.06); color: var(--g-text); }
.sdf-theme-anime .sdc-quick-rail button.is-active { background: var(--g-violet); color: #fff; }

/* ── Agenda ───────────────────────────────────────────────────────────────── */
.sdc-main { min-height: 100dvh; }

.sdc-agenda {
    padding: 10px 12px calc(80px + env(safe-area-inset-bottom));
    display: grid;
    gap: 10px;
}
.sdc-agenda-meta {
    font-size: .76rem;
    font-weight: 700;
    color: var(--g-muted);
    padding: 2px 0;
}
.sdc-agenda-list { display: grid; gap: 10px; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.sdc-card {
    background: #fff;
    border: 1px solid var(--g-line);
    border-radius: 18px;
    overflow: hidden;
    display: grid;
    box-shadow: var(--g-shadow-sm);
    transition: box-shadow .18s, transform .18s;
}
.sdc-card:hover { transform: translateY(-2px); box-shadow: var(--g-shadow-md); }
.sdc-card--has-image { grid-template-columns: 96px 1fr; }
.sdf-theme-anime .sdc-card { background: rgba(255,255,255,.07); }

.sdc-card-img {
    display: block;
    overflow: hidden;
    background: var(--g-line);
}
.sdc-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .25s;
}
.sdc-card:hover .sdc-card-img img { transform: scale(1.04); }

.sdc-card-main {
    padding: 12px 13px 11px;
    display: grid;
    gap: 4px;
}
.sdc-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}
.sdc-card-top h3 {
    margin: 0;
    font-size: .95rem;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.2;
    flex: 1;
    min-width: 0;
}
.sdc-card-top h3 a { color: var(--g-text); text-decoration: none; }
.sdc-card-top h3 a:hover { color: var(--g-violet); }

.sdc-card .sdc-date-pill {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    border: none;
    background: rgba(125,77,255,.1);
    color: var(--g-violet);
    font-size: .65rem;
    font-weight: 800;
    cursor: default;
    width: auto;
    white-space: nowrap;
}
.sdc-card .sdc-date-pill strong { font-size: .65rem; color: inherit; line-height: 1; }
.sdc-card .sdc-date-pill span { display: none; }

.sdc-time { margin: 0; font-size: .74rem; color: var(--g-muted); font-weight: 600; gap: 4px; display: flex; align-items: center; }
.sdc-place {
    margin: 0;
    font-size: .76rem;
    color: var(--g-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: flex;
    align-items: center;
    gap: 4px;
}
.sdc-organizer { margin: 0; font-size: .72rem; color: var(--g-muted); display: flex; align-items: center; gap: 4px; }

.sdc-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
    margin-top: 2px;
}
.sdc-tags span {
    display: inline-flex;
    align-items: center;
    height: 20px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(125,77,255,.08);
    border: 1px solid rgba(125,77,255,.12);
    color: var(--g-violet);
    font-size: .64rem;
    font-weight: 700;
}
.sdc-tags .sdc-tag--call {
    background: rgba(255,79,163,.1);
    border-color: rgba(255,79,163,.2);
    color: var(--g-pink);
    font-size: .63rem;
}

.sdc-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    padding-top: 4px;
    flex-wrap: wrap;
}
.sdc-actions .sdf-btn {
    min-height: 34px;
    padding: 0 12px;
    font-size: .73rem;
    flex: 0 0 auto;
}
.sdc-actions .sdf-btn:first-child { flex: 1; }

.sdc-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid var(--g-line);
    background: rgba(255,255,255,.7);
    font-size: .72rem;
    font-weight: 800;
    color: var(--g-muted);
    cursor: pointer;
    flex-shrink: 0;
    text-decoration: none;
}
.sdc-icon-btn--ig {
    background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
    color: #fff;
    border-color: transparent;
}
.sdc-icon-btn.is-active { color: var(--g-violet); border-color: rgba(125,77,255,.3); }

/* ── Empty ────────────────────────────────────────────────────────────────── */
.sdc-empty { display: grid; gap: 10px; text-align: center; padding: 32px 16px; }
.sdc-empty p { margin: 0; color: var(--g-muted); font-size: .88rem; }

/* ── Bottom sheet / filter panel ─────────────────────────────────────────── */
.sdc-sheet-overlay {
    position: fixed;
    inset: 0;
    z-index: 300;
    background: rgba(34,21,45,.45);
    backdrop-filter: blur(3px);
    display: flex;
    align-items: flex-end;
    opacity: 0;
    transition: opacity .22s;
    pointer-events: none;
}
.sdc-sheet-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}
.sdc-sheet {
    width: 100%;
    max-height: 82dvh;
    background: var(--g-bg);
    border-radius: 22px 22px 0 0;
    padding-bottom: calc(16px + env(safe-area-inset-bottom));
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform .28s cubic-bezier(.22,1,.36,1);
}
.sdc-sheet-overlay.is-open .sdc-sheet { transform: translateY(0); }

.sdc-sheet-handle {
    width: 36px;
    height: 4px;
    border-radius: 2px;
    background: rgba(0,0,0,.14);
    margin: 10px auto 0;
}
.sdc-sheet-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 18px 8px;
}
.sdc-sheet-head strong { font-size: .95rem; font-weight: 800; }
.sdc-sheet-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    border: 1px solid var(--g-line);
    background: rgba(0,0,0,.04);
    font-size: 1.2rem;
    cursor: pointer;
}
.sdc-sheet-section {
    padding: 12px 18px;
    border-top: 1px solid var(--g-line);
}
.sdc-sheet-label {
    margin: 0 0 8px;
    font-size: .7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--g-muted);
}
.sdc-chip-rail { display: flex; flex-wrap: wrap; gap: 6px; }
.sdc-chip-rail button {
    display: inline-flex;
    align-items: center;
    height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--g-line);
    background: rgba(255,255,255,.7);
    font-size: .78rem;
    font-weight: 700;
    color: var(--g-text);
    cursor: pointer;
    transition: background .13s, color .13s, border-color .13s;
}
.sdc-chip-rail button.is-active {
    background: var(--g-violet);
    border-color: var(--g-violet);
    color: #fff;
}
.sdc-zone-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.sdc-zone-grid button {
    display: inline-flex;
    align-items: center;
    height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid var(--g-line);
    background: rgba(255,255,255,.6);
    font-size: .73rem;
    font-weight: 700;
    color: var(--g-text);
    cursor: pointer;
    transition: background .12s;
}
.sdc-zone-grid button.is-active {
    background: rgba(125,77,255,.12);
    border-color: rgba(125,77,255,.3);
    color: var(--g-violet);
}
.sdc-sheet-footer {
    display: flex;
    gap: 8px;
    padding: 14px 18px 0;
}
.sdc-sheet-footer .sdf-btn { flex: 1; min-height: 42px; }

/* ── Desktop ──────────────────────────────────────────────────────────────── */
@media (min-width: 640px) {
    :root { --sdc-top: 56px; --sdc-strip: 84px; }

    .sdc-view-tabs { display: flex; }
    .sdc-top-bar { padding: 0 20px; gap: 10px; }

    .sdc-quick-rail { padding: 12px 24px 6px; }

    .sdc-agenda { padding: 16px 24px 48px; max-width: 680px; margin: 0 auto; }

    .sdc-card--has-image { grid-template-columns: 120px 1fr; }

    .sdc-sheet-overlay { align-items: flex-start; justify-content: flex-end; padding: calc(var(--sdc-top) + 8px) 20px 0 0; }
    .sdc-sheet {
        width: 320px;
        max-height: calc(100dvh - var(--sdc-top) - 24px);
        border-radius: 18px;
        transform: translateY(-8px) scale(.96);
        opacity: 0;
        transition: transform .2s, opacity .2s;
    }
    .sdc-sheet-overlay.is-open .sdc-sheet { transform: translateY(0) scale(1); opacity: 1; }
    .sdc-sheet-handle { display: none; }

    [data-sdc-view="month"] .sdc-strip-bar { display: none; }
    [data-sdc-view="month"] .sdc-month-wrap { display: block !important; }
}

@media (prefers-reduced-motion: reduce) {
    .sdc-sheet, .sdc-sheet-overlay { transition: none !important; }
}
