:root{font-family:Fira Sans,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root,:root.light{--color-primary: #ff6b35;--color-primary-hover: #e55a2e;--color-secondary: #ffa726;--color-accent: #ff8a65;--color-background: #ffffff;--color-surface: #f8f9fa;--color-surface-variant: #f1f3f4;--color-text: #212529;--color-text-secondary: #6c757d;--color-text-muted: #adb5bd;--color-border: #dee2e6;--color-border-light: #e9ecef;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--backdrop: rgba(255, 255, 255, .9);--backdrop-blur: rgba(255, 255, 255, .7)}:root.dark{--color-primary: #ff7043;--color-primary-hover: #ff5722;--color-secondary: #ffb74d;--color-accent: #ffab91;--color-background: #121212;--color-surface: #1e1e1e;--color-surface-variant: #2d2d2d;--color-text: #ffffff;--color-text-secondary: #b3b3b3;--color-text-muted: #757575;--color-border: #404040;--color-border-light: #333333;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .4);--backdrop: rgba(18, 18, 18, .9);--backdrop-blur: rgba(18, 18, 18, .7)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-background);color:var(--color-text);transition:background-color .3s ease,color .3s ease}a{font-weight:500;color:var(--color-primary);text-decoration:inherit;transition:color .3s ease}a:hover{color:var(--color-primary-hover)}h1,h2,h3,h4,h5,h6{font-family:Fraunces,serif;color:var(--color-text);margin:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid var(--color-border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-primary);color:var(--color-background);cursor:pointer;transition:all .3s ease}button:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}button:focus,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:active{transform:translateY(0)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.rrule-display{margin:2rem 0 1rem}.rrule-display h4{margin:0 0 .75rem;color:var(--color-text);font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.rrule-display h4:before{content:"⏰";font-size:.9rem}.no-rules,.no-upcoming{color:var(--color-text-muted);font-style:italic;margin:0;font-size:.9rem;text-align:center;padding:1rem;background:var(--color-surface-variant);border-radius:8px;border:1px dashed var(--color-border)}.rules-list{display:flex;flex-direction:column;gap:.875rem}.rule-item{background:var(--color-surface-variant);border-radius:12px;padding:1rem;border-left:4px solid var(--color-primary);transition:all .3s ease;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.rule-item:hover{background:var(--color-surface);border-left-color:var(--color-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.rule-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:1rem;position:relative}.rule-name{font-weight:600;color:var(--color-text);font-size:.95rem;line-height:1.4}.next-occurrence{font-size:.7rem;color:var(--color-primary);font-weight:600;background:var(--color-primary);color:var(--color-background);padding:.25rem .6rem;border-radius:16px;flex-shrink:0;width:fit-content;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow-sm);position:absolute;top:-2rem;right:-2rem}.next-occurrence.happening-now{background:#22c55e;color:#fff;animation:pulse 2s infinite;border:2px solid #16a34a}@keyframes pulse{0%,to{box-shadow:0 0 5px #22c55e66}50%{box-shadow:0 0 15px #22c55ecc}}.rule-details{display:flex;gap:.75rem;align-items:center;margin-bottom:.375rem;flex-wrap:wrap}.rule-schedule{color:var(--color-text-secondary);font-size:.85rem;font-weight:500;background:var(--color-surface);padding:.25rem .5rem;border-radius:6px;border:1px solid var(--color-border)}.rule-description{color:var(--color-text-muted);font-size:.8rem;font-style:italic;margin-top:.375rem;line-height:1.4;padding-left:1rem;border-left:2px solid var(--color-border)}.time-nowrap{white-space:nowrap}.rule-item:hover .rule-name{color:var(--color-primary)}.rule-item:hover .rule-schedule{background:var(--color-primary);color:var(--color-background);border-color:var(--color-primary)}@media (max-width: 768px){.rule-header{flex-direction:column;align-items:flex-start;gap:.5rem}.next-occurrence{align-self:flex-end;font-size:.65rem}.rule-details{flex-direction:column;align-items:flex-start;gap:.5rem}.rule-item{padding:.875rem}}@media (max-width: 480px){.rule-item{padding:.75rem}.rule-name{font-size:.9rem}.rule-schedule{font-size:.8rem;padding:.2rem .4rem}.rule-description{font-size:.75rem;margin-top:.25rem;padding-left:.75rem}.next-occurrence{font-size:.6rem;padding:.2rem .5rem}}.venue-card{border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin:1rem 0;background:var(--color-surface);box-shadow:var(--shadow-md);transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;min-height:200px;border-left:4px solid var(--color-primary);position:relative;overflow:hidden}.venue-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary),var(--color-accent));opacity:0;transition:opacity .3s ease}.venue-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-left-color:var(--color-secondary);background:var(--color-surface-variant)}.venue-card:hover:before{opacity:1}.venue-card h3{margin:0;color:var(--color-text);font-size:1.25rem;line-height:1.3;font-weight:600;transition:color .3s ease}.venue-card:hover h3{color:var(--color-primary)}.venue-city{font-size:1rem;color:var(--color-text-secondary);margin:.25rem 0 0;font-weight:500;transition:color .3s ease}.venue-address-link{align-items:flex-start;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.4rem;outline:none;text-decoration-color:transparent;text-decoration:underline;transition:all .3s ease;color:var(--color-text-muted);margin-top:.5rem}.venue-address-link:hover,.venue-address-link:focus{text-decoration-color:var(--color-primary);color:var(--color-primary);transform:translate(2px)}.venue-address-icon{margin-top:.1rem;flex-shrink:0;color:inherit;transition:transform .3s ease}.venue-address-link:hover .venue-address-icon{transform:scale(1.1)}.venue-card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}@media (min-width: 1200px){.venue-card{min-height:240px;padding:1.5rem;border-radius:16px}.venue-card h3{font-size:1.4rem}.venue-city{font-size:1.1rem}.venue-address-link{font-size:.95rem}}@media (min-width: 768px) and (max-width: 1199px){.venue-card{min-height:220px;padding:1.375rem;border-radius:14px}.venue-card h3{font-size:1.3rem}.venue-city{font-size:1.05rem}}@media (max-width: 767px){.venue-card{min-height:180px;padding:1rem;margin:.75rem 0;border-radius:10px}.venue-card h3{font-size:1.2rem}.venue-city{font-size:.95rem}.venue-address-link{font-size:.85rem}}@media (max-width: 480px){.venue-card{min-height:160px;padding:.875rem;border-radius:8px}.venue-card h3{font-size:1.1rem}.venue-city{font-size:.9rem}.venue-address-link{font-size:.8rem}}.venue-list-container{max-width:100%;margin:0 auto;padding:2rem;background:var(--color-surface);color:var(--color-text);transition:all .3s ease}.venue-list-container h2{color:var(--color-text);margin-bottom:2rem;text-align:center;font-weight:600;text-shadow:var(--shadow-sm);font-size:2rem;position:relative}.venue-list-container h2:after{content:"";position:absolute;bottom:-.5rem;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:2px}.venue-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;max-width:1400px;margin:0 auto}.loading,.error{text-align:center;padding:2rem;font-size:1.1rem;border-radius:12px;margin:2rem auto;max-width:500px}.loading{color:var(--color-primary);background:var(--color-surface-variant);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;gap:1rem}.loading:before{content:"";width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{color:var(--color-primary);background:var(--color-surface-variant);border:2px solid var(--color-primary);box-shadow:var(--shadow-md)}.empty-state{text-align:center;padding:3rem;color:var(--color-text-muted);background:var(--color-surface-variant);border-radius:16px;border:2px dashed var(--color-border);margin:2rem auto;max-width:600px}.empty-state p{font-size:1.1rem;margin:0;line-height:1.6}.empty-state:before{content:"🍻";display:block;font-size:3rem;margin-bottom:1rem;opacity:.5}@media (min-width: 1200px){.venue-grid{grid-template-columns:repeat(4,1fr);gap:2rem}.venue-list-container{padding:2.5rem}.venue-list-container h2{font-size:2.25rem}}@media (min-width: 992px) and (max-width: 1199px){.venue-grid{grid-template-columns:repeat(3,1fr);gap:1.75rem}.venue-list-container h2{font-size:2.1rem}}@media (min-width: 768px) and (max-width: 991px){.venue-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.venue-list-container h2{font-size:1.9rem}}@media (max-width: 767px){.venue-list-container{padding:1.5rem 1rem}.venue-grid{grid-template-columns:1fr;gap:1rem;max-width:500px}.venue-list-container h2{font-size:1.7rem;margin-bottom:1.5rem}.empty-state{padding:2rem 1.5rem}}@media (max-width: 480px){.venue-list-container{padding:1rem .75rem}.venue-grid{gap:.75rem}.venue-list-container h2{font-size:1.5rem}.empty-state{padding:2rem 1rem}.loading,.error{padding:1.5rem;font-size:1rem}}.app{min-height:100vh;font-family:Fira Sans,system-ui,Avenir,Helvetica,Arial,sans-serif;background:var(--color-background);color:var(--color-text);transition:all .3s ease;position:relative}.app-header{margin:0 auto;max-width:1440px;padding:2rem;text-align:center;background:var(--backdrop-blur);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.logo-container{margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center}.logo{height:300px;width:auto;max-width:300px;object-fit:contain;transition:all .3s ease}.logo:hover{transform:scale(1.05)}.app-header h1{margin:0 0 .5rem;color:var(--color-primary);font-size:3rem;font-weight:700;text-shadow:var(--shadow-sm);font-family:Fraunces,serif;letter-spacing:-.02em}.app-header p{margin:0;color:var(--color-text-secondary);font-size:1.1rem;font-weight:500;font-family:Fira Sans,sans-serif;letter-spacing:.05em;text-transform:uppercase}main{background:var(--color-surface);min-height:calc(100vh - 200px);max-width:1440px;margin:0 auto;border-radius:16px 16px 0 0;box-shadow:var(--shadow-lg);overflow:hidden;position:relative}.app:before{content:"";position:fixed;top:0;left:0;right:0;height:50vh;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 50%,var(--color-accent) 100%);opacity:.05;z-index:-1;transition:opacity .3s ease}:root.dark .app:before{opacity:.1}@media (max-width: 768px){.app-header{padding:1.5rem 1rem}.logo{height:210px}.app-header h1{font-size:2.2rem}.app-header p{font-size:1rem}main{border-radius:12px 12px 0 0}}@media (max-width: 480px){.app-header{padding:1rem}.logo{height:210px}.app-header h1{font-size:1.8rem}.app-header p{font-size:.9rem}main{border-radius:8px 8px 0 0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-header{animation:fadeIn .6s ease-out}main{animation:fadeIn .8s ease-out .2s both}
