.home-container {
    max-width: 640px;
    padding-top: 0.5rem;
    padding-bottom: 5rem;
}

/* Greeting uses shared .hero-card-dark from astro.css */

.home-location-banner {
    background: var(--surface-1);
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    font-size: var(--fs-sm);
    color: var(--ink-3);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Cards */
.home-card {
    background: var(--surface-1);
    border: 1px solid var(--border-soft);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.home-card__header {
    padding: 14px 16px 0;
    font-weight: 700;
    font-size: 15px;
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--ink-1);
}

.header-right-text {
    margin-left: auto;
    font-size: 11px;
    font-weight: 500;
    color: var(--ink-3);
}

.panchang-location {
    margin-left: auto;
    font-size: 11px;
    font-weight: 500;
    color: var(--bad);
}

.home-card__body {
    padding: 10px 16px 14px;
}

/* Panchang */
.panchang-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.panchang-item {
    background: var(--surface-2, var(--surface-1));
    border: 1px solid var(--border-soft);
    border-radius: 10px;
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
}

.panchang-label {
    font-size: 10px;
    color: var(--ink-3);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
    margin-bottom: 2px;
}

.panchang-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--ink-1);
}

.panchang-sub {
    font-size: 10px;
    color: var(--ink-3);
    font-weight: 500;
}

/* Sun times */
.sun-row {
    display: flex;
    justify-content: space-around;
    padding: 12px 0 4px;
    border-top: 1px solid var(--border-soft);
    margin-top: 10px;
}

.sun-item {
    text-align: center;
}

.sun-icon {
    font-size: 18px;
}

.sun-time {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-1);
}

.sun-label {
    font-size: 10px;
    color: var(--ink-3);
}

/* Abhijit Muhurta */
.abhijit-row {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    margin-top: 8px;
    background: var(--good-soft, rgba(46,125,50,0.06));
    border-radius: 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--ink-2);
}

.abhijit-time {
    margin-left: auto;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

/* Inauspicious */
.kaal-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.kaal-chip {
    flex: 1 1 calc(33% - 6px);
    min-width: 80px;
    border-radius: 10px;
    padding: 8px 10px;
    text-align: center;
    border: 1.5px solid transparent;
}

.kaal-chip .kaal-name {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.kaal-chip .kaal-time {
    font-size: 12px;
    font-weight: 600;
    margin-top: 2px;
    color: var(--ink-1);
}

.kaal-chip .kaal-status {
    font-size: 9px;
    margin-top: 2px;
    font-weight: 600;
}

.kaal-chip.active {
    background: var(--bad-soft, rgba(198,40,40,0.06));
    border-color: var(--bad);
}
.kaal-chip.active .kaal-name { color: var(--bad); }
.kaal-chip.active .kaal-status { color: var(--bad); }

.kaal-chip.upcoming {
    background: var(--warn-soft, rgba(230,81,0,0.06));
}
.kaal-chip.upcoming .kaal-name { color: var(--warn); }

.kaal-chip.passed {
    background: var(--surface-2, var(--surface-1));
    opacity: 0.6;
}
.kaal-chip.passed .kaal-name { color: var(--ink-3); }

.kaal-chip.auspicious {
    background: var(--good-soft, rgba(46,125,50,0.06));
}
.kaal-chip.auspicious .kaal-name { color: var(--good); }

.kaal-chip.auspicious-active {
    background: var(--good-soft, rgba(46,125,50,0.06));
    border-color: var(--good);
}
.kaal-chip.auspicious-active .kaal-name { color: var(--good); }
.kaal-chip.auspicious-active .kaal-status { color: var(--good); }

/* Moon */
.moon-card-inner {
    display: flex;
    align-items: center;
    gap: 16px;
}

.moon-visual {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1a1a2e 50%, #e8e4f0 50%);
    flex-shrink: 0;
    position: relative;
    box-shadow: 0 0 20px rgba(103,80,164,0.15);
}
.moon-visual::after {
    content: '';
    position: absolute;
    top: 8px;
    left: 18px;
    width: 36px;
    height: 56px;
    border-radius: 50%;
    background: #1a1a2e;
}

.moon-phase-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--primary, #6750a4);
}

.moon-position {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-2);
    margin-top: 2px;
}

.moon-mood {
    font-size: 12px;
    color: var(--ink-3);
    margin-top: 4px;
    line-height: 1.4;
}

.nakshatra-divider {
    margin-top: 14px;
    border-top: 1px solid var(--border-soft);
    padding-top: 12px;
}

.nakshatra-spotlight {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}

.nakshatra-deity {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: var(--primary-soft, rgba(103,80,164,0.08));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
}

.nakshatra-details {
    flex: 1;
}

.nak-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--ink-1);
}

.nak-meaning {
    font-size: 11px;
    color: var(--primary, #6750a4);
    font-weight: 600;
}

.nak-desc {
    font-size: 12px;
    color: var(--ink-3);
    margin-top: 4px;
    line-height: 1.4;
}

.nak-tags {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-top: 6px;
}

.nak-tag {
    font-size: 10px;
    background: var(--surface-2, var(--surface-1));
    border: 1px solid var(--border-soft);
    padding: 3px 8px;
    border-radius: 20px;
    color: var(--ink-3);
    font-weight: 500;
}

/* Transits */
.retro-banner {
    background: var(--warn-soft, rgba(230,81,0,0.06));
    border: 1px solid rgba(230,81,0,0.15);
    border-radius: 10px;
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.retro-icon {
    font-size: 20px;
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--warn-soft, rgba(230,81,0,0.08));
    display: flex;
    align-items: center;
    justify-content: center;
}

.retro-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--warn);
}

.retro-detail {
    font-size: 11px;
    color: var(--ink-3);
    margin-top: 2px;
}

.retro-countdown {
    font-size: 11px;
    font-weight: 600;
    color: var(--warn);
    margin-top: 2px;
}

.transit-row {
    display: flex;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-soft);
}

.transit-row:last-child {
    border-bottom: none;
}

.transit-symbol {
    width: 32px;
    font-size: 18px;
    text-align: center;
    flex-shrink: 0;
    color: var(--ink-3);
}

.transit-info {
    flex: 1;
    margin-left: 8px;
}

.transit-planet-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-1);
}

.transit-sign-info {
    font-size: 11px;
    color: var(--ink-3);
}

.transit-badges {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

.transit-badge {
    font-size: 9px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 4px;
    text-transform: uppercase;
}

.badge-exalted { background: var(--good-soft, rgba(46,125,50,0.08)); color: var(--good); }
.badge-debil { background: var(--bad-soft, rgba(198,40,40,0.08)); color: var(--bad); }
.badge-own { background: var(--primary-soft, rgba(103,80,164,0.08)); color: var(--primary, #6750a4); }
.badge-retro { background: var(--warn-soft, rgba(230,81,0,0.08)); color: var(--warn); }
.badge-ingress { background: var(--primary-soft, rgba(103,80,164,0.08)); color: var(--primary, #6750a4); }

/* Hora */
.hora-row {
    display: flex;
    align-items: center;
    padding: 6px 8px;
    border-radius: 8px;
    gap: 8px;
    font-size: 13px;
}

.hora-row.hora-active {
    background: var(--primary-soft, rgba(103,80,164,0.08));
    font-weight: 600;
    border-radius: 8px;
    margin: 0 -8px;
    padding: 6px 16px;
}

.hora-row.hora-past {
    opacity: 0.5;
}

.hora-time-range {
    font-size: 12px;
    color: var(--ink-3);
    font-variant-numeric: tabular-nums;
    min-width: 140px;
}

.hora-glyph {
    font-size: 16px;
    width: 24px;
    text-align: center;
}

.hora-planet-name {
    font-weight: 600;
    color: var(--ink-1);
    flex: 1;
}

.hora-keyword {
    font-size: 11px;
    font-weight: 500;
    color: var(--primary, #6750a4);
    text-align: right;
}

/* Festivals */
.festival-item {
    display: flex;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-soft);
}

.festival-item:last-child {
    border-bottom: none;
}

.festival-date-box {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-weight: 700;
}

.festival-date-box .festival-day {
    font-size: 18px;
    line-height: 1;
}

.festival-date-box .festival-month {
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.festival-date-box.vrat {
    background: var(--good-soft, rgba(0,137,123,0.08));
    color: var(--good);
}

.festival-date-box.festival {
    background: var(--warn-soft, rgba(249,168,37,0.10));
    color: var(--warn);
}

.festival-info {
    flex: 1;
    margin-left: 12px;
}

.festival-info .festival-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-1);
}

.festival-info .festival-desc {
    font-size: 11px;
    color: var(--ink-3);
    margin-top: 1px;
}

.festival-countdown {
    font-size: 11px;
    font-weight: 600;
    color: var(--primary, #6750a4);
    flex-shrink: 0;
}

/* Weekly Summary */
.weekly-summary {
    background: var(--primary-soft, rgba(103,80,164,0.06));
    border-radius: 10px;
    padding: 14px;
}

.weekly-subhead {
    font-size: 13px;
    font-weight: 700;
    color: var(--primary, #6750a4);
    margin-bottom: 8px;
}

.weekly-bullet {
    font-size: 12px;
    color: var(--ink-3);
    padding: 4px 0;
    line-height: 1.5;
}

.weekly-bullet::before {
    content: '•';
    color: var(--primary, #6750a4);
    font-weight: 700;
    margin-right: 6px;
}

.weekly-bullet strong {
    color: var(--ink-1);
}

/* Section label */
.section-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--ink-3);
    padding: 16px 4px 6px;
}

/* Transit alerts */
.profile-transit-card {
    background: var(--surface-2, var(--surface-1));
    border: 1px solid var(--border-soft);
    border-radius: 10px;
    padding: 12px;
    margin-bottom: 8px;
}

.profile-transit-card:last-child {
    margin-bottom: 0;
}

.profile-alert-top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.profile-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
}

.profile-alert-name {
    font-size: 12px;
    font-weight: 700;
    color: var(--primary, #6750a4);
}

.profile-alert-text {
    font-size: 12px;
    color: var(--ink-3);
    line-height: 1.4;
}

.profile-alert-text strong {
    color: var(--ink-1);
}

.sade-sati-badge {
    font-size: 11px;
    font-weight: 600;
    color: var(--warn);
    margin-top: 4px;
}

/* Best Days / Muhurta scroll */
.muhurta-scroll {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
}

.muhurta-scroll::-webkit-scrollbar { display: none; }

.muhurta-card {
    min-width: 130px;
    background: var(--surface-2, var(--surface-1));
    border: 1px solid var(--border-soft);
    border-radius: 10px;
    padding: 12px;
    flex-shrink: 0;
}

.muhurta-activity {
    font-size: 12px;
    font-weight: 700;
    color: var(--ink-1);
    margin-bottom: 4px;
}

.muhurta-best {
    font-size: 11px;
    color: var(--good);
    font-weight: 600;
}

.muhurta-reason {
    font-size: 10px;
    color: var(--ink-3);
    margin-top: 2px;
}

/* Good Days Calendar */
.cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-size: 10px;
    font-weight: 700;
    color: var(--ink-3);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
}

.cal-cell {
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--ink-2);
}

.cal-cell.cal-today {
    outline: 2px solid var(--primary, #6750a4);
    outline-offset: -2px;
}

.cal-cell.cal-good { background: var(--good-soft, rgba(46,125,50,0.10)); color: var(--good); }
.cal-cell.cal-neutral { background: var(--surface-2, var(--surface-1)); }
.cal-cell.cal-mixed { background: var(--warn-soft, rgba(230,81,0,0.08)); color: var(--warn); }
.cal-cell.cal-avoid { background: var(--bad-soft, rgba(198,40,40,0.08)); color: var(--bad); }
.cal-cell.cal-empty { background: none; }

.cal-legend {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-top: 10px;
    flex-wrap: wrap;
}

.cal-legend-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    color: var(--ink-3);
    font-weight: 500;
}

.cal-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.cal-dot--good { background: var(--good); }
.cal-dot--neutral { background: var(--ink-3); opacity: 0.4; }
.cal-dot--mixed { background: var(--warn); }
.cal-dot--avoid { background: var(--bad); }
