@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-primary:#0f1014;--bg-secondary:#1a1d24;--bg-tertiary:#242830;--bg-card:#1a1d24;--bg-card-hover:#242830;--bg-overlay:#0f1014d9;--accent:#f5c518;--accent-dim:#f5c51826;--accent-hover:#ffd740;--text-primary:#fff;--text-secondary:#89a;--text-muted:#5a6677;--text-accent:#f5c518;--rating-excellent:#00c853;--rating-good:#7cb342;--rating-average:#ffb300;--rating-poor:#ff5722;--gold:gold;--silver:silver;--bronze:#cd7f32;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:50%;--shadow-card:0 4px 24px #0006;--shadow-elevated:0 8px 40px #0009;--shadow-glow:0 0 20px #f5c51833;--nav-height:72px;--safe-bottom:env(safe-area-inset-bottom,0px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:var(--accent);text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea,select{border:none;outline:none;font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:2px}.page{padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-lg));flex:1;width:100%;max-width:600px;margin:0 auto}.page-header{text-align:center;padding:var(--space-md) 0 var(--space-lg)}.page-header .brand{letter-spacing:3px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:var(--space-xs);font-size:.75rem;font-weight:700}.page-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:800}.bottom-nav{height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);-webkit-backdrop-filter:blur(20px);z-index:1000;background:#0f1014bf;border-top:1px solid #ffffff0f;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);letter-spacing:.5px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-transform:uppercase;background:0 0;flex-direction:column;align-items:center;gap:4px;font-size:.65rem;font-weight:500;transition:all .2s;display:flex;position:relative}.nav-item.active{color:var(--accent)}.nav-item.active:before{content:"";background:var(--accent);border-radius:1px;width:24px;height:2px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.nav-item svg,.nav-item .nav-icon{width:22px;height:22px;font-size:20px}.card{background:var(--bg-card);border-radius:var(--radius-md);transition:transform .2s,box-shadow .2s;overflow:hidden}.card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.top-carousel{gap:var(--space-md);scroll-snap-type:x mandatory;padding:var(--space-sm) var(--space-xs);margin:0 calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md);-ms-overflow-style:none;scrollbar-width:none;display:flex;overflow-x:auto}.top-carousel::-webkit-scrollbar{display:none}.top-card{scroll-snap-align:center;border-radius:var(--radius-lg);cursor:pointer;flex-shrink:0;width:200px;height:280px;transition:transform .3s;position:relative;overflow:hidden}.top-card:hover{transform:scale(1.03)}.top-card.first{width:240px;height:310px}.top-card-bg{background-position:50%;background-size:cover;position:absolute;inset:0}.top-card-overlay{background:linear-gradient(#0000001a 0%,#0000004d 50%,#000000e6 100%);position:absolute;inset:0}.top-card-badge{top:var(--space-sm);left:var(--space-sm);color:var(--text-primary);border-radius:var(--radius-sm);background:#000000b3;align-items:center;gap:4px;padding:4px 10px;font-size:.85rem;font-weight:800;display:flex;position:absolute}.top-card-badge.gold{color:var(--gold);border:1px solid var(--gold)}.top-card-badge.silver{color:var(--silver);border:1px solid var(--silver)}.top-card-badge.bronze{color:var(--bronze);border:1px solid var(--bronze)}.top-card-content{padding:var(--space-md);text-align:center;position:absolute;bottom:0;left:0;right:0}.top-card-score{margin-bottom:4px;font-size:2.2rem;font-weight:900;line-height:1}.top-card-score span{color:var(--text-secondary);font-size:1rem;font-weight:500}.top-card .restaurant-name{text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-sm);font-size:.8rem;font-weight:700}.top-card .restaurant-meta{color:var(--text-secondary);margin-top:2px;font-size:.65rem}.top-card .view-btn{margin-top:var(--space-sm);background:var(--accent);color:#000;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;padding:6px 16px;font-size:.7rem;font-weight:700;display:inline-block}.ranking-list{gap:var(--space-sm);flex-direction:column;display:flex}.ranking-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);cursor:pointer;transition:background .2s;display:flex}.ranking-item:hover{background:var(--bg-card-hover)}.ranking-position{color:var(--text-secondary);min-width:32px;font-size:1rem;font-weight:800}.ranking-item-photo{border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-tertiary);width:48px;height:48px}.ranking-item-info{flex:1}.ranking-item-name{font-size:.9rem;font-weight:700}.ranking-item-score{color:var(--accent);font-size:1.2rem;font-weight:800}.ranking-item-score span{color:var(--text-secondary);font-size:.75rem}.current-block{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);margin-top:var(--space-lg);border:1px solid #f5c51833}.current-block-label{text-transform:uppercase;letter-spacing:2px;color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.7rem;font-weight:700}.current-block-name{margin-bottom:4px;font-size:1.1rem;font-weight:800}.current-block-subtitle{color:var(--text-secondary);font-size:.8rem}.current-block-date{color:var(--accent);margin-top:var(--space-sm);align-items:center;gap:6px;font-size:.8rem;display:inline-flex}.current-block-status{margin-top:var(--space-sm);border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:600;display:inline-block}.current-block-status.pending{color:var(--rating-average);background:#ffb30026}.current-block-status.complete{color:var(--rating-excellent);background:#00c85326}.btn-rate{margin-top:var(--space-md);background:var(--accent);color:#000;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;padding:10px 24px;font-size:.85rem;font-weight:700;transition:all .2s;display:inline-block}.btn-rate:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.restaurant-list{gap:var(--space-md);flex-direction:column;display:flex}.restaurant-card{gap:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);cursor:pointer;transition:background .2s,transform .2s;display:flex;overflow:hidden}.restaurant-card:hover{background:var(--bg-card-hover);transform:translate(4px)}.restaurant-card-photo{background:var(--bg-tertiary);object-fit:cover;flex-shrink:0;width:100px;min-height:100px}.restaurant-card-body{padding:var(--space-md) var(--space-md) var(--space-md) 0;flex-direction:column;flex:1;justify-content:center;display:flex}.restaurant-card .visited-badge{color:var(--rating-excellent);text-transform:uppercase;letter-spacing:.5px;background:#00c85326;border-radius:4px;width:fit-content;margin-bottom:4px;padding:2px 8px;font-size:.6rem;font-weight:700;display:inline-block}.restaurant-card .not-visited-badge{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:#ffffff0d;border-radius:4px;width:fit-content;margin-bottom:4px;padding:2px 8px;font-size:.6rem;font-weight:700;display:inline-block}.restaurant-card-name{font-size:.95rem;font-weight:700}.restaurant-card-address{color:var(--text-secondary);align-items:center;gap:4px;margin-top:2px;font-size:.75rem;display:flex}.restaurant-card-score{color:var(--accent);margin-top:4px;font-size:1.1rem;font-weight:800}.restaurant-card-score span{color:var(--text-secondary);font-size:.7rem}.detail-hero{width:calc(100% + 2 * var(--space-md));margin-left:calc(-1 * var(--space-md));margin-top:calc(-1 * var(--space-md));background:var(--bg-tertiary);height:240px;position:relative;overflow:hidden}.detail-hero img{object-fit:cover;width:100%;height:100%}.detail-hero-overlay{background:linear-gradient(to top, var(--bg-primary) 0%, transparent 60%);position:absolute;inset:0}.detail-back-btn{top:var(--space-md);left:var(--space-md);border-radius:var(--radius-full);color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2;background:#00000080;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex;position:absolute}.detail-rating-section{text-align:center;z-index:2;margin-top:-40px;position:relative}.rating-circle{border-radius:var(--radius-full);border:3px solid;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto;font-size:2rem;font-weight:900;display:inline-flex}.rating-circle.excellent{border-color:var(--rating-excellent);color:var(--rating-excellent);background:#00c8531a}.rating-circle.good{border-color:var(--rating-good);color:var(--rating-good);background:#7cb3421a}.rating-circle.average{border-color:var(--rating-average);color:var(--rating-average);background:#ffb3001a}.rating-circle.poor{border-color:var(--rating-poor);color:var(--rating-poor);background:#ff57221a}.rating-circle span{font-size:.9rem;font-weight:500}.detail-name{margin-top:var(--space-md);text-transform:uppercase;letter-spacing:1px;font-size:1.4rem;font-weight:800}.detail-subtitle{color:var(--text-secondary);margin-top:4px;font-size:.8rem}.detail-address{margin-top:var(--space-md);border-radius:var(--radius-sm);color:var(--accent);background:#ffffff0d;align-items:center;gap:6px;padding:8px 16px;font-size:.8rem;transition:background .2s;display:inline-flex}.detail-address:hover{background:#ffffff1a}.section-title{color:var(--text-primary);margin:var(--space-lg) 0 var(--space-md);align-items:center;gap:var(--space-sm);font-size:.9rem;font-weight:700;display:flex}.rating-history{gap:var(--space-sm);flex-direction:column;display:flex}.rating-history-item{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:background .2s}.rating-history-item:hover{background:var(--bg-card-hover)}.rating-history-header{align-items:center;gap:var(--space-md);display:flex}.rating-user-avatar{border-radius:var(--radius-full);background:var(--bg-tertiary);object-fit:cover;width:40px;height:40px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.rating-user-info{flex:1}.rating-user-name{font-size:.85rem;font-weight:600}.rating-user-score{color:var(--accent);font-size:1rem;font-weight:800}.rating-breakdown{margin-top:var(--space-md);padding-top:var(--space-md);gap:var(--space-sm);border-top:1px solid #ffffff0f;grid-template-columns:1fr 1fr;animation:.3s slideDown;display:grid}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:200px}}.breakdown-item{background:#ffffff08;border-radius:6px;justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.breakdown-label{color:var(--text-secondary);font-size:.7rem}.breakdown-value{color:var(--text-primary);font-size:.85rem;font-weight:700}.stars{gap:2px;font-size:.85rem;display:inline-flex}.star{color:var(--text-muted)}.star.filled{color:var(--accent)}.star.half{color:var(--text-muted);position:relative}.form-group{margin-bottom:var(--space-md)}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm);font-size:.75rem;font-weight:600;display:block}.form-input{background:var(--bg-tertiary);width:100%;color:var(--text-primary);border-radius:var(--radius-sm);border:1px solid #ffffff0f;padding:12px 16px;font-size:.9rem;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{resize:vertical;min-height:80px}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;padding:12px 24px;font-size:.85rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:#ffffff26}.btn-danger{color:var(--rating-poor);background:#ff572226}.btn-full{width:100%}.btn-sm{padding:8px 16px;font-size:.75rem}.fab{bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-xl));right:var(--space-md);border-radius:var(--radius-full);background:var(--accent);color:#000;width:56px;height:56px;box-shadow:var(--shadow-elevated);z-index:100;justify-content:center;align-items:center;font-size:1.5rem;transition:transform .2s;display:flex;position:fixed}.fab:hover{transform:scale(1.1)}.user-grid{gap:var(--space-sm);flex-direction:column;display:flex}.user-card{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);transition:background .2s;display:flex}.user-card:hover{background:var(--bg-card-hover)}.user-avatar{border-radius:var(--radius-full);background:var(--bg-tertiary);object-fit:cover;width:48px;height:48px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-info{flex:1}.user-name{font-size:.95rem;font-weight:600}.user-attendance{color:var(--text-secondary);font-size:.75rem}.user-actions{gap:var(--space-sm);display:flex}.slider-group{margin-bottom:var(--space-lg)}.slider-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.slider-label{font-size:.85rem;font-weight:600}.slider-value{color:var(--accent);text-align:right;min-width:30px;font-size:1.1rem;font-weight:800}.slider-input{appearance:none;background:var(--bg-tertiary);border-radius:3px;outline:none;width:100%;height:6px}.slider-input::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:24px;height:24px;box-shadow:0 2px 8px #f5c5184d}.slider-input::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:24px;height:24px;box-shadow:0 2px 8px #f5c5184d}.app-footer{margin-top:var(--space-xl);padding:var(--space-xl) var(--space-md) calc(var(--nav-height) + var(--space-xl));text-align:center;justify-content:center;align-items:center;gap:var(--space-sm);opacity:.7;flex-direction:column;display:flex}.footer-logo img{opacity:.8;width:auto;height:20px;transition:filter .2s,opacity .2s}.footer-logo img:hover{filter:grayscale(0%);opacity:1}.footer-powered{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.75rem}.footer-powered a{color:var(--text-muted);font-weight:700;text-decoration:none;transition:color .2s}.footer-powered a:hover{color:var(--text-primary)}.footer-copyright{color:var(--text-muted);letter-spacing:.5px;font-size:.65rem}.login-page{min-height:100dvh;padding:var(--space-xl);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";filter:blur(8px);z-index:-1;background-image:linear-gradient(#000c,#000c),url(/assets/background-DWRJrJUU.jpg);background-position:50%;background-size:cover;background-attachment:fixed;width:100%;height:100%;position:absolute;top:0;left:0;transform:scale(1.1)}.login-page>*{z-index:1;position:relative}.login-logo{color:var(--accent);margin-bottom:var(--space-xs);letter-spacing:3px;font-size:2rem;font-weight:900}.login-subtitle{color:var(--text-secondary);margin-bottom:var(--space-2xl);font-size:.85rem}.login-users{gap:var(--space-md);width:100%;max-width:360px;margin-bottom:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.login-user-btn{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);color:var(--text-primary);flex-direction:column;font-size:.75rem;font-weight:500;transition:all .2s;display:flex}.login-user-btn:hover,.login-user-btn.selected{background:var(--accent-dim);border:1px solid var(--accent)}.login-user-btn .user-avatar{width:56px;height:56px}.pin-input{gap:var(--space-sm);margin-bottom:var(--space-lg);display:flex}.pin-digit{text-align:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);width:48px;height:56px;color:var(--text-primary);border:2px solid #0000;font-size:1.4rem;font-weight:700;transition:border-color .2s}.pin-digit:focus{border-color:var(--accent)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;padding-bottom:calc(var(--nav-height) + var(--safe-bottom));background:#000000b3;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:85vh;padding:var(--space-lg);animation:.3s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:1.1rem;font-weight:700}.modal-close{border-radius:var(--radius-full);background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-primary);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.search-bar{align-items:center;gap:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);padding:10px 16px;display:flex}.search-bar input{color:var(--text-primary);background:0 0;flex:1;font-size:.85rem}.search-bar input::placeholder{color:var(--text-muted)}.search-icon{color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-md);color:var(--text-muted)}.empty-state-icon{margin-bottom:var(--space-md);font-size:3rem}.empty-state-text{margin-bottom:var(--space-lg);font-size:.9rem}.photo-upload{border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;width:100px;height:100px;margin-bottom:var(--space-md);border:2px dashed #ffffff1a;justify-content:center;align-items:center;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.photo-upload:hover{border-color:var(--accent)}.photo-upload input{opacity:0;cursor:pointer;position:absolute;inset:0}.photo-upload img{object-fit:cover;width:100%;height:100%}.photo-upload-icon{color:var(--text-muted);font-size:1.5rem}@media (width>=768px){.page{max-width:700px}.top-card{width:240px;height:310px}.top-card.first{width:280px;height:340px}.login-users{max-width:420px}}@media (width>=1024px){.page{max-width:800px}.bottom-nav{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:500px;left:50%;transform:translate(-50%)}}.action-row{gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.toast{bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-lg));background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-primary);z-index:3000;box-shadow:var(--shadow-elevated);border:1px solid #ffffff1a;padding:12px 24px;font-size:.85rem;font-weight:500;animation:.3s fadeIn;position:fixed;left:50%;transform:translate(-50%)}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-card-hover) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.divider{height:1px;margin:var(--space-lg) 0;background:#ffffff0f}
