*{box-sizing:border-box;margin:0}:root{--ink: #14406b;--ink-soft: #3a6a96;--card: rgba(255, 255, 255, .82);--gold: #f6b93b;--coral: #ff8a5c;--good: #10ac84;--bad: #e55039}html,body{height:100%}body{font-family:"Baloo Bhaijaan 2",system-ui,sans-serif;color:var(--ink);overflow-x:hidden}.scene{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;background:linear-gradient(180deg,#8ed8f8,#bfeafc 45%,#e8f9ff 60%)}.sun{position:absolute;top:6%;left:10%;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,#fff3b0 20%,#ffd166 60%,#ffd16600 72%);animation:sun-glow 5s ease-in-out infinite}@keyframes sun-glow{0%,to{transform:scale(1);opacity:.95}50%{transform:scale(1.12);opacity:1}}.cloud{position:absolute;font-size:56px;opacity:.9;animation:drift-cloud linear infinite}.cloud-1{top:8%;animation-duration:70s}.cloud-2{top:18%;font-size:40px;animation-duration:95s;animation-delay:-40s}.cloud-3{top:4%;font-size:32px;animation-duration:110s;animation-delay:-70s}@keyframes drift-cloud{0%{right:-120px}to{right:110%}}.bird{position:absolute;font-size:22px;animation:fly 38s linear infinite}.bird-1{top:14%}@keyframes fly{0%{right:-40px;transform:translateY(0)}50%{transform:translateY(-30px)}to{right:105%;transform:translateY(0)}}.sea{position:absolute;bottom:0;left:0;right:0;height:38%}.wave-layer{position:absolute;bottom:0;left:0;width:200%;height:100%;display:flex;animation-name:wave-slide;animation-timing-function:linear;animation-iteration-count:infinite}.wave-layer svg{width:50%;height:100%;flex-shrink:0}.wave-back{opacity:.55;height:110%}.wave-mid{opacity:.75;height:90%}.wave-front{height:72%}@keyframes wave-slide{0%{transform:translate(0)}to{transform:translate(-50%)}}.ship{position:absolute;bottom:58%;left:7%;width:clamp(130px,17vw,230px);animation:bob 4.5s ease-in-out infinite;transform-origin:center bottom}@keyframes bob{0%,to{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(10px) rotate(1.5deg)}}.pier{position:absolute;bottom:62%;left:0;width:14%;min-width:80px}.pier-deck{height:14px;background:repeating-linear-gradient(90deg,#9c6b3c 0,#9c6b3c 26px,#8a5c30 26px,#8a5c30 30px);border-radius:0 8px 8px 0;box-shadow:0 3px 6px #00000026}.pier-post{position:absolute;top:10px;width:10px;height:60px;background:linear-gradient(#8a5c30,#6e4724);border-radius:0 0 5px 5px}.pier-post:nth-child(2){right:12%}.pier-post:nth-child(3){right:50%}.pier-post:nth-child(4){right:88%}.sand{position:absolute;bottom:0;left:0;right:0;height:9%;background:linear-gradient(180deg,#f4d8a8,#eccb91)}.sand-star{position:absolute;width:42px;animation:twinkle 4s ease-in-out infinite}.sand-star.s1{right:12%;top:18%;transform:rotate(20deg)}.sand-star.s2{right:70%;top:35%;width:30px;animation-delay:1.4s}.shell{position:absolute;right:40%;top:22%;font-size:24px}@keyframes twinkle{0%,to{filter:brightness(1)}50%{filter:brightness(1.25)}}.page{max-width:880px;margin:0 auto;padding:16px 16px 140px;min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.brand{display:flex;align-items:center;gap:12px}.brand-icon{font-size:44px;display:inline-block;animation:bob 4.5s ease-in-out infinite}.brand h1{font-size:34px;font-weight:800;line-height:1;color:var(--ink);text-shadow:0 2px 0 rgba(255,255,255,.6)}.brand p{color:var(--ink-soft);font-size:14px}.nav-link{background:var(--card);padding:8px 18px;border-radius:999px;text-decoration:none;color:var(--ink);font-weight:700;box-shadow:0 4px 14px #14406b1f;transition:transform .15s}.nav-link:hover{transform:translateY(-2px)}.footer{text-align:center;margin-top:32px;color:var(--ink-soft);font-weight:600}.hero{text-align:center;margin:10px 0 18px}.hero h2{font-size:30px;font-weight:800}.hero p{color:var(--ink-soft);font-weight:600}.family-row{display:flex;gap:10px;overflow-x:auto;padding:6px 2px 12px}.family-card{--fc: #888;flex:1;min-width:104px;border:3px solid var(--fc);background:var(--card);border-radius:18px;padding:10px 8px;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:2px;box-shadow:0 4px 14px #14406b1a}.family-card.active{background:var(--fc)}.family-card.active .family-card-name,.family-card.active .family-card-stars{color:#fff}.family-card-name{font-weight:800;font-size:17px;color:var(--fc)}.family-card-stars{font-weight:700;font-size:14px;color:var(--ink-soft)}.podium{display:flex;align-items:flex-end;justify-content:center;gap:14px;margin:18px 0 24px}.podium-spot{position:relative;background:var(--card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:20px 20px 0 0;padding:14px 10px 0;text-align:center;width:min(180px,30vw);box-shadow:0 8px 24px #14406b29;display:flex;flex-direction:column;align-items:center;gap:4px}.podium-medal{font-size:44px}.sparkle{position:absolute;font-size:16px;pointer-events:none;animation:twinkle-spark 1.8s ease-in-out infinite}.sp1{top:8px;right:10px}.sp2{top:48px;left:8px;animation-delay:.6s}.sp3{top:-12px;left:42%;animation-delay:1.1s;font-size:13px}.confetti{position:absolute;top:35%;right:50%;pointer-events:none;z-index:5}.confetti span{position:absolute;font-size:18px}@keyframes twinkle-spark{0%,to{opacity:.15;transform:scale(.7) rotate(0)}50%{opacity:1;transform:scale(1.15) rotate(20deg)}}.podium-name{font-weight:800;font-size:16px;overflow-wrap:anywhere}.podium-stars{font-weight:800;font-size:20px;color:var(--gold);text-shadow:0 1px 0 rgba(0,0,0,.08)}.podium-base{width:100%;margin-top:8px;font-size:26px;font-weight:800;color:#fff;border-radius:12px 12px 0 0}.place-1 .podium-base{background:linear-gradient(#ffd54f,#f6b93b);padding:22px 0}.place-2 .podium-base{background:linear-gradient(#cfd8dc,#a7b6bd);padding:12px 0}.place-3 .podium-base{background:linear-gradient(#e59866,#ca6f1e);padding:6px 0}.search-wrap{display:flex;gap:10px;align-items:center;margin-bottom:12px}.search{flex:1;width:100%;padding:12px 18px;border-radius:999px;border:2px solid rgba(20,64,107,.15);background:var(--card);font-family:inherit;font-size:16px;font-weight:600;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}.search:focus{border-color:#2e86de;box-shadow:0 0 0 4px #2e86de26}.clear-filter{border:none;background:var(--ink);color:#fff;font-family:inherit;font-weight:700;padding:10px 16px;border-radius:999px;cursor:pointer}.board{display:flex;flex-direction:column;gap:8px}.row{display:flex;align-items:center;gap:12px;background:var(--card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:16px;padding:10px 16px;box-shadow:0 3px 12px #14406b1a}.row-top{border:2px solid var(--gold);background:linear-gradient(90deg,#fff4d6f2,#ffffffd9)}.row-rank{width:38px;text-align:center;font-weight:800;font-size:19px;flex-shrink:0}.row-name{flex:1;font-weight:700;font-size:17px;overflow-wrap:anywhere}.row-stars{font-weight:800;font-size:18px;color:var(--ink);white-space:nowrap}.row-delete{border:none;background:none;font-size:18px;cursor:pointer}.family-badge{color:#fff;font-size:13px;font-weight:700;padding:3px 12px;border-radius:999px;white-space:nowrap}.empty,.hint{text-align:center;color:var(--ink-soft);font-weight:600;padding:14px}.center{display:flex;justify-content:center;padding-top:8vh}.card{background:var(--card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:22px;padding:22px;box-shadow:0 10px 32px #14406b24}.card h3{margin:18px 0 10px}.card h3:first-child{margin-top:0}.card h4{margin:14px 0 8px;color:var(--ink-soft)}.login-card{width:min(380px,92vw);text-align:center;display:flex;flex-direction:column;gap:12px}.login-icon{font-size:52px}.login-card input{padding:12px 16px;border-radius:14px;border:2px solid rgba(20,64,107,.15);font-family:inherit;font-size:16px;text-align:center}.error{color:var(--bad);font-weight:700}.tabs{display:flex;gap:8px;margin-bottom:14px}.tab{flex:1;border:none;background:var(--card);font-family:inherit;font-weight:700;font-size:16px;padding:10px;border-radius:14px;cursor:pointer;color:var(--ink-soft);box-shadow:0 3px 10px #14406b14}.tab.active{background:var(--ink);color:#fff}.tab.logout{flex:0 0 auto;padding:10px 18px;color:var(--bad)}.btn{border:none;font-family:inherit;font-weight:700;font-size:15px;padding:12px 16px;border-radius:14px;cursor:pointer;transition:transform .12s,filter .12s}.btn:hover{filter:brightness(1.06);transform:translateY(-1px)}.btn.primary{background:var(--ink);color:#fff}.btn.add{background:var(--good);color:#fff}.btn.deduct{background:var(--bad);color:#fff}.btn.disabled{opacity:.6;pointer-events:none}.selected-student{margin-top:14px;border-top:2px dashed rgba(20,64,107,.15);padding-top:12px}.selected-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:18px}.selected-stars{margin-inline-start:auto;font-weight:800;font-size:20px;color:var(--gold)}.criteria-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px}.log-title{margin-top:24px}.log{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.log-row{display:flex;align-items:center;gap:10px;background:#fff;border-radius:12px;padding:7px 12px;font-size:14px}.log-points{font-weight:800;width:42px;text-align:center;border-radius:8px;flex-shrink:0}.log-points.pos{color:var(--good);background:#10ac841f}.log-points.neg{color:var(--bad);background:#e550391f}.log-name{font-weight:700}.log-label{color:var(--ink-soft);flex:1}.log-undo{border:none;background:none;cursor:pointer;font-size:16px}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.chip{--fc: #888;border:2px solid var(--fc);color:var(--fc);background:#fff;border-radius:999px;padding:5px 14px;font-family:inherit;font-weight:700;font-size:14px;cursor:pointer;transition:transform .12s}.chip:hover{transform:translateY(-1px)}.chip.active{background:var(--fc);color:#fff}.close-chip{--fc: var(--bad);padding:3px 10px}.student-pick,.students-list{max-height:340px;overflow-y:auto;margin-top:12px}.row.clickable{cursor:pointer;transition:transform .12s}.row.clickable:hover{transform:translateY(-1px)}.row.selected{border:2px solid var(--ink)}.row-action{border:none;background:none;font-size:18px;cursor:pointer;flex-shrink:0}.log-by{color:var(--ink-soft);font-size:13px;white-space:nowrap}.log-date{color:#9bb3c7;font-size:12px;white-space:nowrap}.history{max-height:240px}.greeting{color:var(--ink-soft);font-weight:700;margin:-6px 4px 10px}.admin-phone{flex:1;color:var(--ink-soft);font-weight:600;direction:ltr;text-align:right}.hint-inline{color:#9bb3c7;font-size:13px;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a284673;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.modal{width:min(560px,100%);max-height:80vh;overflow-y:auto}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.modal-close{border:none;background:none;font-size:20px;cursor:pointer;color:var(--ink-soft)}.add-form{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.add-form input,.add-form select{padding:11px 14px;border-radius:12px;border:2px solid rgba(20,64,107,.15);font-family:inherit;font-size:15px}.add-form input{flex:2;min-width:180px}.add-form select{flex:1;min-width:120px}.file-btn{display:inline-block}.import-result{margin:10px 0;font-weight:600}.import-result details{color:var(--ink-soft)}.toast{position:fixed;bottom:24px;right:50%;transform:translate(50%);background:var(--good);color:#fff;font-weight:800;font-size:16px;padding:13px 26px;border-radius:999px;box-shadow:0 10px 30px #00000040;z-index:50}.toast.warn{background:var(--bad)}@media (max-width: 560px){.brand h1{font-size:26px}.podium{gap:8px}.podium-medal{font-size:32px}.criteria-grid{grid-template-columns:1fr 1fr}.tab{font-size:14px;padding:8px 6px}.log-date{display:none}.sun{width:70px;height:70px;left:3%;top:3%}.family-row{flex-wrap:wrap}.family-card{flex:1 1 30%;min-width:30%}}
