@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0A0A12;--bg-surface: #12121C;--bg-card: #1A1A28;--bg-card-hover: #1E1E30;--bg-elevated: #222235;--border: rgba(255, 255, 255, .07);--border-light: rgba(255, 255, 255, .13);--overlay: rgba(0, 0, 0, .7);--gold: #F5A623;--gold-dim: rgba(245, 166, 35, .15);--gold-glow: rgba(245, 166, 35, .35);--gold-text: #0D0A00;--orange: #E05B2B;--orange-dim: rgba(224, 91, 43, .15);--rose: #D4596A;--teal: #3BBFA3;--indigo: #7C83E0;--text-primary: #F0EDE8;--text-secondary:#A09C95;--text-muted: #6B6760;--text-inverse: #0A0A12;--header-bg: rgba(10, 10, 18, .88);--month-label-bg: #0A0A12;--font-head: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 8px 32px rgba(0,0,0,.4);--shadow-lg: 0 20px 60px rgba(0,0,0,.55);--shadow-gold: 0 0 24px rgba(245,166,35,.25);color-scheme:dark}[data-theme=light]{--bg-base: #F7F5F0;--bg-surface: #FFFFFF;--bg-card: #FFFFFF;--bg-card-hover: #FBF9F5;--bg-elevated: #F0EDE6;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .14);--overlay: rgba(0, 0, 0, .45);--gold: #D4861A;--gold-dim: rgba(212, 134, 26, .12);--gold-glow: rgba(212, 134, 26, .25);--gold-text: #FFFFFF;--orange: #C44E22;--orange-dim: rgba(196, 78, 34, .12);--rose: #B8344A;--teal: #1E9E7E;--indigo: #4C54B8;--text-primary: #1A1614;--text-secondary:#5A5450;--text-muted: #9A9490;--text-inverse: #FFFFFF;--header-bg: rgba(247, 245, 240, .92);--month-label-bg: #F7F5F0;--shadow-sm: 0 2px 8px rgba(0,0,0,.08);--shadow-md: 0 8px 32px rgba(0,0,0,.12);--shadow-lg: 0 20px 60px rgba(0,0,0,.18);--shadow-gold: 0 0 24px rgba(212,134,26,.2);color-scheme:light}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);min-width:320px;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh;padding-bottom:env(safe-area-inset-bottom)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-base);transition:background-color .3s ease}.header{position:sticky;top:0;z-index:200;background:var(--header-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:0 1rem;height:60px;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:env(safe-area-inset-top);height:calc(60px + env(safe-area-inset-top))}.header-brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.header-logo{width:36px;height:36px;border-radius:10px;object-fit:cover;box-shadow:var(--shadow-gold);flex-shrink:0;display:block}.header-title{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap}.header-title span{color:var(--gold)}.header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.view-tab-bar{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.view-tab{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;font-family:var(--font-body);font-size:.75rem;font-weight:600;transition:all .2s ease;white-space:nowrap}.view-tab svg{width:14px;height:14px;flex-shrink:0}.view-tab:hover{color:var(--text-secondary)}.view-tab.active{background:var(--bg-card);color:var(--gold);box-shadow:var(--shadow-sm)}.lang-toggle{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.lang-btn{padding:.3rem .6rem;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;font-family:var(--font-body);font-size:.73rem;font-weight:600;transition:all .2s ease;min-width:32px;text-align:center}.lang-btn:hover{color:var(--text-secondary)}.lang-btn.active{background:var(--gold);color:var(--gold-text);box-shadow:0 2px 8px var(--gold-glow)}.theme-btn{width:34px;height:34px;border:1px solid var(--border);background:var(--bg-elevated);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease;flex-shrink:0}.theme-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.theme-btn svg{width:15px;height:15px}.main-content{position:relative;z-index:1;flex:1;display:flex;flex-direction:column}.calendar-view{padding:1.25rem 1rem;max-width:900px;margin:0 auto;width:100%}.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.month-nav-title{font-family:var(--font-head);font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em}.month-nav-title .month-year-sub{font-size:.78rem;font-weight:500;color:var(--text-muted);display:block;font-family:var(--font-body);letter-spacing:.05em;text-transform:uppercase;margin-top:2px}.month-nav-btn{width:38px;height:38px;border:1px solid var(--border);background:var(--bg-card);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.month-nav-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.month-nav-btn svg{width:17px;height:17px}.month-nav-btns{display:flex;gap:.4rem}.cal-grid{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm)}.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border)}.cal-dow-cell{padding:.65rem 0;text-align:center;font-family:var(--font-body);font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.cal-dow-cell.sunday{color:var(--rose)}.cal-days-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-cell{min-height:76px;padding:.5rem .35rem .4rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:default;transition:background .15s ease;display:flex;flex-direction:column;align-items:center;gap:3px;position:relative}.cal-cell:nth-child(7n){border-right:none}.cal-cell.other-month{opacity:.2}.cal-cell.has-event{cursor:pointer}.cal-cell.has-event:hover{background:var(--bg-elevated)}.cal-cell.is-selected{background:var(--gold-dim)}.cal-cell.is-today .cal-date-num{background:var(--gold);color:var(--gold-text);box-shadow:var(--shadow-gold)}.cal-cell.sunday .cal-date-num{color:var(--rose)}.cal-cell.is-today.sunday .cal-date-num{color:var(--gold-text)}.cal-date-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.82rem;font-weight:600;color:var(--text-primary);flex-shrink:0;transition:all .15s ease}.cal-event-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.cal-event-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}.cal-event-dot.festival{background:var(--gold)}.cal-event-dot.fasting{background:var(--indigo)}.cal-event-dot.temple{background:var(--orange)}.cal-event-dot.special{background:var(--teal)}.cal-event-icon{width:18px;height:18px;color:var(--gold);opacity:.75}.event-popup-backdrop{position:fixed;inset:0;background:var(--overlay);z-index:500;display:flex;align-items:center;justify-content:center;padding:1.25rem;animation:backdropIn .2s ease}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.event-popup{background:var(--bg-card);border:1px solid var(--border-light);width:100%;max-width:460px;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);animation:popupZoomIn .22s cubic-bezier(.34,1.3,.64,1);max-height:85vh;display:flex;flex-direction:column}@keyframes popupZoomIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.event-popup-drag-handle{display:none}.event-popup-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.25rem .75rem;flex-shrink:0}.event-popup-date{font-family:var(--font-body);font-size:.72rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.1em}.event-popup-close{width:30px;height:30px;border:1px solid var(--border);background:var(--bg-elevated);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease;flex-shrink:0}.event-popup-close:hover{background:var(--rose);border-color:var(--rose);color:#fff}.event-popup-close svg{width:14px;height:14px}.event-popup-body{padding:0 1.25rem 1.5rem;overflow-y:auto;flex:1}.event-popup-list{display:flex;flex-direction:column;gap:.55rem}.event-popup-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-surface);border-radius:var(--radius-md);border-left:3px solid transparent}.event-popup-item.festival{border-left-color:var(--gold)}.event-popup-item.fasting{border-left-color:var(--indigo)}.event-popup-item.temple{border-left-color:var(--orange)}.event-popup-item.special{border-left-color:var(--teal)}.event-popup-icon{width:30px;height:30px;flex-shrink:0}.event-popup-item.festival .event-popup-icon{color:var(--gold)}.event-popup-item.fasting .event-popup-icon{color:var(--indigo)}.event-popup-item.temple .event-popup-icon{color:var(--orange)}.event-popup-item.special .event-popup-icon{color:var(--teal)}.event-popup-name{flex:1;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--text-primary);line-height:1.45}.event-popup-badge{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .55rem;border-radius:20px;flex-shrink:0}.event-popup-badge.festival{background:var(--gold-dim);color:var(--gold)}.event-popup-badge.fasting{background:#7c83e026;color:var(--indigo)}.event-popup-badge.temple{background:var(--orange-dim);color:var(--orange)}.event-popup-badge.special{background:#3bbfa326;color:var(--teal)}.scroll-view{padding:1.25rem 1rem 4rem;max-width:680px;margin:0 auto;width:100%}.filter-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.filter-btn{padding:.4rem 1rem;border:1px solid var(--border);background:transparent;color:var(--text-muted);border-radius:20px;cursor:pointer;font-family:var(--font-body);font-size:.78rem;font-weight:600;transition:all .2s ease;letter-spacing:.03em}.filter-btn:hover{border-color:var(--border-light);color:var(--text-secondary)}.filter-btn.active{background:var(--gold);border-color:var(--gold);color:var(--gold-text);box-shadow:0 2px 12px var(--gold-glow)}.month-section{margin-bottom:.25rem}.month-section-header{position:sticky;top:calc(60px + env(safe-area-inset-top));z-index:50;padding:.5rem 0;margin-bottom:.6rem}.month-section-label{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;background:var(--month-label-bg);padding-right:.75rem}.month-section-label:after{content:"";display:block;height:1px;width:50px;background:var(--border-light)}.event-card{display:flex;align-items:flex-start;gap:.9rem;padding:.9rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:.6rem;transition:all .2s ease;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}.event-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.event-card.festival:before{background:var(--gold)}.event-card.fasting:before{background:var(--indigo)}.event-card.temple:before{background:var(--orange)}.event-card.special:before{background:var(--teal)}.event-card:active{background:var(--bg-card-hover);transform:scale(.99)}@media(hover:hover){.event-card:hover{background:var(--bg-card-hover);border-color:var(--border-light);transform:translate(3px);box-shadow:var(--shadow-md)}}.event-card-date{display:flex;flex-direction:column;align-items:center;min-width:44px;flex-shrink:0}.event-card-day-num{font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.04em}.event-card-month-abbr{font-family:var(--font-body);font-size:.6rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.event-card-dow{font-family:var(--font-body);font-size:.58rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}.event-card-divider{width:1px;background:var(--border);align-self:stretch;flex-shrink:0}.event-card-icon-wrap{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.event-card-icon-wrap.festival{background:var(--gold-dim)}.event-card-icon-wrap.fasting{background:#7c83e01f}.event-card-icon-wrap.temple{background:var(--orange-dim)}.event-card-icon-wrap.special{background:#3bbfa31f}.event-card-icon{width:20px;height:20px}.event-card-icon-wrap.festival .event-card-icon{color:var(--gold)}.event-card-icon-wrap.fasting .event-card-icon{color:var(--indigo)}.event-card-icon-wrap.temple .event-card-icon{color:var(--orange)}.event-card-icon-wrap.special .event-card-icon{color:var(--teal)}.event-card-content{flex:1;min-width:0}.event-card-title{font-family:var(--font-body);font-size:.88rem;font-weight:600;color:var(--text-primary);line-height:1.45;margin-bottom:.3rem}.event-card-badge{display:inline-block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.18rem .55rem;border-radius:20px}.event-card-badge.festival{background:var(--gold-dim);color:var(--gold)}.event-card-badge.fasting{background:#7c83e026;color:var(--indigo)}.event-card-badge.temple{background:var(--orange-dim);color:var(--orange)}.event-card-badge.special{background:#3bbfa326;color:var(--teal)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state-icon{width:44px;height:44px;margin:0 auto 1rem;opacity:.3}.empty-state p{font-family:var(--font-body);font-size:.9rem}@media(max-width:480px){.header{padding:0 .75rem}.header-title{font-size:.95rem}.view-tab{padding:.3rem .55rem;font-size:.7rem;gap:.25rem}.view-tab span{display:none}.lang-btn{padding:.28rem .45rem;font-size:.68rem;min-width:28px}.theme-btn{width:30px;height:30px}.calendar-view{padding:1rem .75rem}.cal-cell{min-height:52px;padding:.4rem .2rem .3rem}.cal-date-num{width:24px;height:24px;font-size:.72rem}.cal-event-icon{display:none}.month-nav-title{font-size:1.2rem}.scroll-view{padding:1rem .75rem 4rem}.event-card{gap:.65rem;padding:.8rem .85rem}.event-card-day-num{font-size:1.3rem}.event-card-title{font-size:.82rem}}@media(min-width:481px)and (max-width:768px){.header{padding:0 1.25rem}.calendar-view{padding:1.25rem}.scroll-view{padding:1.25rem 1.25rem 4rem}}
