:root{color:#182033;font-synthesis:none;text-rendering:optimizelegibility;background:#f3f7fb;font-family:Arial,Malgun Gothic,sans-serif}*{box-sizing:border-box}body{margin:0}body[data-device=mobile]{background:#f6f9fc}button,input,textarea{font:inherit}button{transition:transform .16s,box-shadow .16s,background .16s}button:not(:disabled):hover{transform:translateY(-1px)}.login-page{background:linear-gradient(90deg,#0e21397a,#0c192b24),url(/assets/campus.jpg) 50%/cover;place-items:center;min-height:100vh;padding:32px;display:grid}.login-page.is-loading{animation:1.1s ease-in-out infinite alternate login-focus}.login-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;border:1px solid #ffffffb3;border-radius:24px;grid-template-columns:1.05fr .95fr;align-items:center;gap:36px;width:min(880px,100%);padding:34px;display:grid;position:relative;overflow:hidden;box-shadow:0 26px 70px #0d1d3152}.login-panel.is-loading:before{content:"";pointer-events:none;background:linear-gradient(110deg,#0000 0%,#147dbe1f 42%,#ffffff80 50%,#147dbe1f 58%,#0000 100%);animation:1.25s ease-in-out infinite panel-sweep;position:absolute;inset:0;transform:translate(-100%)}.login-logo{width:min(292px,100%);height:auto;margin-bottom:26px}.eyebrow{color:#1265a8;letter-spacing:0;text-transform:uppercase;margin:0 0 8px;font-size:13px;font-weight:900}.login-copy h1{white-space:nowrap;max-width:520px;margin:0;font-size:34px;line-height:1.14}.login-description{color:#4b5870;max-width:390px;margin:16px 0 0;font-size:17px;font-weight:700;line-height:1.55}.login-form{background:#f7fbff;border:1px solid #d8e4f1;border-radius:18px;gap:14px;padding:24px;display:grid}.form-title{margin-bottom:4px;font-size:20px}.login-form input{color:#111827;background:#fff;border:1px solid #bfd0e2;border-radius:12px;outline:none;width:100%;height:52px;padding:0 16px;font-size:17px;font-weight:400}.login-form input:focus,.submit-panel input:focus,.submit-panel textarea:focus{border-color:#1682cc;box-shadow:0 0 0 4px #1682cc26}.primary-button,.secondary-button,.vote-button,.icon-button,.tabs button{cursor:pointer;font-weight:900}.primary-button,.secondary-button{border:0;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:46px;display:inline-flex}.primary-button{color:#fff;background:#147dbe;padding:0 24px;box-shadow:0 10px 22px #147dbe40}.loading-button{background:#0f6fae;box-shadow:0 0 0 4px #147dbe24,0 14px 28px #147dbe47}.button-spinner{border:2px solid #ffffff73;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}.secondary-button{color:#135c94;background:#e8f3fb;padding:0 20px}.primary-button:disabled,.vote-button:disabled{opacity:.55;cursor:not-allowed}.helper-text{color:#64748b;text-align:center;font-size:13px;font-weight:700}.login-message{color:#c1121f;text-align:center;margin:2px 0 0;font-size:14px;font-weight:800}.text-link{color:#315f8a;cursor:pointer;text-underline-offset:3px;background:0 0;border:0;font-weight:800;text-decoration:underline}.privacy-link{justify-self:center;margin-top:2px;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes panel-sweep{to{transform:translate(100%)}}@keyframes login-focus{0%{background-position:50%}to{background-position:50% 48%}}.app-shell{background:#f3f7fb;min-height:100vh}.topbar{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid #dce7f1;justify-content:space-between;align-items:center;height:58px;padding:0 28px;display:flex;position:sticky;top:0}.topbar img{width:162px;height:auto}.topbar-user{color:#26344d;align-items:center;gap:10px;font-weight:900;display:flex}.icon-button{color:#28425f;background:#edf4fb;border:0;border-radius:50%;place-items:center;width:38px;height:38px;display:grid}.hero{color:#fff;background:linear-gradient(90deg,#071426c7,#07142652 58%,#0714261a),url(/assets/campus.jpg) 50% 45%/cover;grid-template-columns:minmax(0,1fr) 260px;align-items:center;gap:28px;min-height:332px;padding:58px max(28px,50vw - 560px) 38px;display:grid}.hero-content{max-width:690px}.hero .eyebrow{color:#b7dcff}.hero h1{max-width:690px;margin:0;font-size:48px;line-height:1.12}.hero p:not(.eyebrow){color:#e7f2ff;max-width:560px;margin:16px 0 0;font-size:18px;font-weight:700;line-height:1.55}.hero-actions{flex-wrap:wrap;gap:10px;margin-top:26px;display:flex}.hero .secondary-button{color:#fff;background:#ffffff29;box-shadow:inset 0 0 0 1px #ffffff57}.hero-stats{align-self:center;gap:10px;display:grid}.hero-stats div{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #ffffff47;border-radius:18px;align-content:center;min-height:98px;padding:18px;display:grid}.hero-stats strong{font-size:32px;line-height:1}.hero-stats span{color:#e8f5ff;margin-top:8px;font-weight:800}.tabs{z-index:2;background:#fffffff5;border:1px solid #dce7f1;border-radius:18px;grid-template-columns:repeat(3,1fr);gap:8px;width:min(820px,100% - 32px);margin:-23px auto 0;padding:8px;display:grid;position:relative;box-shadow:0 16px 30px #182a431f}.tabs.admin-tabs{grid-template-columns:repeat(4,1fr)}.tabs.compact-tabs{grid-template-columns:repeat(2,1fr)}.tabs button{color:#56657b;background:0 0;border:0;border-radius:12px;justify-content:center;align-items:center;gap:7px;min-height:44px;display:inline-flex}.tabs button.active{color:#fff;background:#147dbe;box-shadow:0 8px 18px #147dbe38}.vote-meter{color:#26344d;background:#fff;border:1px solid #d7e2ee;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;width:min(820px,100% - 32px);min-height:42px;margin:12px auto 0;padding:0 18px;display:flex;box-shadow:0 8px 22px #1b2d4612}.vote-meter strong{color:#147dbe}.vote-meter span{color:#64748b;font-weight:800}.content-grid{grid-template-columns:repeat(auto-fit,minmax(294px,1fr));gap:22px;max-width:1120px;margin:30px auto 0;padding:0 22px 54px;display:grid}.submission-card{background:#fff;border:1px solid #d7e2ee;border-radius:18px;grid-template-rows:auto auto 1fr auto;display:grid;overflow:hidden;box-shadow:0 14px 30px #1b2d461a}.submission-card header{color:#25334a;justify-content:space-between;align-items:center;gap:12px;min-height:50px;padding:0 16px;font-size:14px;display:flex}.submission-card header span{color:#718096;font-size:13px;font-weight:800}.submission-card figure{aspect-ratio:4/3;background:#cfe5f4;margin:0;position:relative;overflow:hidden}.image-stack{width:100%;height:100%;display:grid}.image-stack.two-images{grid-template-columns:repeat(2,minmax(0,1fr))}.submission-card .image-stack img{object-fit:cover;width:100%;height:100%;display:block}.expand-button{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ab8;border:0;border-radius:999px;justify-content:center;align-items:center;gap:6px;min-width:106px;height:40px;padding:0 12px;font-size:14px;font-weight:900;display:inline-flex;position:absolute;bottom:12px;right:12px}.description{align-content:start;gap:8px;min-height:132px;padding:18px 18px 12px;display:grid}.description h2{color:#12233c;margin:0;font-size:19px;line-height:1.32}.description p{color:#52627a;margin:0;font-weight:700;line-height:1.5}.submission-card footer{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px 16px;display:flex}.card-actions{align-items:center;gap:8px;display:inline-flex}.vote-count{color:#176ca5;background:#edf5fc;border-radius:999px;justify-content:center;align-items:center;min-height:34px;padding:0 13px;font-weight:900;display:inline-flex}.vote-button{color:#fff;background:#147dbe;border:0;border-radius:999px;justify-content:center;align-items:center;gap:6px;min-width:104px;min-height:38px;display:inline-flex;box-shadow:0 9px 18px #147dbe33}.vote-button.voted{background:#243b5a}.delete-button{color:#c1121f;cursor:pointer;background:#fff0f0;border:0;border-radius:50%;place-items:center;width:38px;height:38px;display:inline-grid}.pin-button{color:#176ca5;cursor:pointer;background:#eef6ff;border:0;border-radius:50%;place-items:center;width:38px;height:38px;display:inline-grid}.submit-panel,.settings-panel{background:#fff;border:1px solid #d7e2ee;border-radius:20px;gap:18px;width:min(780px,100% - 32px);margin:32px auto 56px;padding:26px;display:grid;box-shadow:0 16px 34px #1b2d461a}.section-heading h2{margin:0;font-size:28px}.section-heading p:not(.eyebrow){color:#64748b;margin:8px 0 0;font-weight:800}.submit-panel label,.settings-panel label{color:#26344d;gap:8px;font-weight:900;display:grid}.submit-panel input,.submit-panel textarea,.settings-panel input{color:#182033;background:#fbfdff;border:1px solid #cddbe8;border-radius:12px;outline:none;width:100%;padding:13px 14px}.settings-checkbox{grid-template-columns:20px 1fr;align-items:center}.settings-checkbox input{accent-color:#147dbe;width:18px;height:18px;padding:0}.notice{color:#9a4f00;background:#fff4e6;border-radius:12px;margin:0;padding:12px 14px;font-weight:900}.submit-panel textarea{resize:vertical;min-height:118px}.character-counter{color:#64748b;justify-self:end;margin-top:-2px;font-size:12px;font-weight:800}.file-box{color:#176ca5;text-align:center;cursor:pointer;background:#f3f9fe;border:1.5px dashed #7fb6dc;border-radius:16px;place-items:center;min-height:126px}.file-box input{display:none}.file-counter{color:#315f8a;font-size:12px;font-weight:900}.agreement-box{background:#f8fbff;border:1px solid #d7e2ee;border-radius:14px;gap:10px;padding:14px;display:grid}.agreement-box label{color:#334155;grid-template-columns:20px 1fr;align-items:start;gap:10px;font-size:14px;line-height:1.5}.agreement-box input{accent-color:#147dbe;width:18px;height:18px;margin:2px 0 0}.ranking{gap:12px;width:min(820px,100% - 32px);margin:32px auto 56px;display:grid}.ranking .section-heading{margin-bottom:8px}.rank-row{background:#fff;border:1px solid #d7e2ee;border-radius:16px;grid-template-columns:48px 92px 1fr;align-items:center;gap:14px;min-height:92px;padding:12px;display:grid;box-shadow:0 10px 24px #1b2d4614}.rank-number{color:#176ca5;background:#edf5fc;border-radius:50%;place-items:center;width:38px;height:38px;font-size:20px;font-weight:900;display:grid}.rank-row img{object-fit:cover;border-radius:10px;width:92px;height:68px}.rank-row strong,.rank-row p{margin:0}.rank-row p{color:#64748b;margin-top:5px;font-weight:800}.empty-state{text-align:center;color:#52627a;grid-column:1/-1;margin:44px 0;font-weight:900}.preview-overlay{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#071426b8;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.preview-dialog{background:#fff;border-radius:18px;grid-template-rows:minmax(0,1fr) auto;width:min(980px,100%);max-height:calc(100vh - 48px);display:grid;position:relative;overflow:hidden;box-shadow:0 28px 70px #00000059}.preview-images{background:#0f172a;gap:1px;display:grid}.preview-images.multiple{grid-template-columns:repeat(2,minmax(0,1fr))}.preview-images img{object-fit:contain;background:#0f172a;width:100%;max-height:calc(100vh - 150px);display:block}.preview-dialog div{padding:16px 18px}.preview-dialog strong,.preview-dialog p{margin:0}.preview-dialog p{color:#64748b;margin-top:4px;font-weight:800}.preview-close{color:#0f172a;cursor:pointer;z-index:2;background:#ffffffeb;border:0;border-radius:50%;place-items:center;width:42px;height:42px;display:grid;position:absolute;top:12px;right:12px}.topbar-link{color:#31506e;cursor:pointer;background:#f8fbff;border:1px solid #d5e4f0;border-radius:999px;min-height:34px;padding:0 12px;font-size:13px;font-weight:900}.app-footer{text-align:center;padding:0 18px 28px;display:none}.policy-overlay{z-index:70;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#071426a8;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.policy-dialog{background:#fff;border-radius:20px;grid-template-rows:auto minmax(0,1fr);width:min(860px,100%);max-height:calc(100vh - 48px);display:grid;overflow:hidden;box-shadow:0 28px 76px #04122461}.policy-header{border-bottom:1px solid #dce7f1;justify-content:space-between;align-items:flex-start;gap:18px;padding:24px 26px 18px;display:flex}.policy-header h2{color:#111827;margin:0;font-size:28px}.policy-header p:not(.eyebrow){color:#53647a;margin:8px 0 0;font-weight:800}.policy-close{color:#243b55;cursor:pointer;background:#edf4fb;border:0;border-radius:50%;flex:none;place-items:center;width:42px;height:42px;display:grid}.policy-content{padding:22px 26px 28px;overflow-y:auto}.policy-content section+section{margin-top:20px}.policy-content h3{color:#13223a;margin:0 0 8px;font-size:18px}.policy-content p{color:#41516a;margin:0;font-size:15px;font-weight:700;line-height:1.75}@media (width<=820px){.login-panel{grid-template-columns:1fr;padding:24px}.login-copy h1{white-space:normal;font-size:30px}.hero{grid-template-columns:1fr;align-items:start;padding-top:44px}.hero h1{font-size:34px}.hero-stats{grid-template-columns:repeat(2,1fr)}.tabs{grid-template-columns:1fr;margin-top:16px}}@media (width<=560px){.login-page,.login-form{padding:18px}.topbar{height:auto;min-height:56px;padding:8px 12px}.topbar img{width:118px}.topbar-user{gap:6px;min-width:0}.topbar-user span{text-overflow:ellipsis;white-space:nowrap;max-width:96px;overflow:hidden}.topbar-link{display:none}.app-footer{display:block}.hero{padding-inline:20px}.hero h1{font-size:30px}.hero-stats{grid-template-columns:1fr}.content-grid{grid-template-columns:1fr;padding-inline:16px}.rank-row{grid-template-columns:38px 76px 1fr}.rank-row img{width:76px;height:60px}}body[data-device=mobile] .login-page{align-items:end;min-height:100svh;padding:14px}body[data-device=mobile] .login-panel{border-radius:22px;gap:18px;width:100%;padding:20px;box-shadow:0 18px 48px #0d1d3157}body[data-device=mobile] .login-logo{width:210px;margin-bottom:18px}body[data-device=mobile] .login-copy h1{white-space:normal;font-size:28px}body[data-device=mobile] .login-description{font-size:15px}body[data-device=mobile] .login-form{padding:16px}body[data-device=mobile] .login-form input,body[data-device=mobile] .primary-button,body[data-device=mobile] .secondary-button{min-height:52px}body[data-device=mobile] .topbar{gap:8px;min-height:54px;position:sticky}body[data-device=mobile] .icon-button{width:36px;height:36px}body[data-device=mobile] .hero{gap:18px;min-height:auto;padding:30px 18px 28px}body[data-device=mobile] .hero h1{font-size:34px}body[data-device=mobile] .hero p:not(.eyebrow){font-size:15px}body[data-device=mobile] .hero-stats{grid-template-columns:repeat(3,1fr);gap:8px}body[data-device=mobile] .hero-stats div{border-radius:14px;min-height:76px;padding:12px 10px}body[data-device=mobile] .hero-stats strong{font-size:24px}body[data-device=mobile] .hero-stats span{font-size:12px}body[data-device=mobile] .tabs,body[data-device=mobile] .tabs.admin-tabs,body[data-device=mobile] .tabs.compact-tabs{border-radius:16px;grid-template-columns:1fr;width:calc(100% - 24px);margin-top:12px}body[data-device=mobile] .tabs button{min-height:48px}body[data-device=mobile] .vote-meter{width:calc(100% - 24px);min-height:46px;font-size:14px}body[data-device=mobile] .content-grid{gap:16px;margin-top:18px;padding:0 12px 36px}body[data-device=mobile] .submission-card{border-radius:16px}body[data-device=mobile] .submission-card header{min-height:46px}body[data-device=mobile] .description{min-height:auto;padding:16px}body[data-device=mobile] .submission-card footer{align-items:stretch}body[data-device=mobile] .card-actions{gap:6px}body[data-device=mobile] .vote-button{min-width:96px;min-height:42px}body[data-device=mobile] .delete-button,body[data-device=mobile] .pin-button{width:42px;height:42px}body[data-device=mobile] .expand-button{min-width:112px;height:44px;bottom:10px;right:10px}body[data-device=mobile] .submit-panel,body[data-device=mobile] .settings-panel,body[data-device=mobile] .ranking{border-radius:18px;width:calc(100% - 24px);margin-top:18px;padding:18px}body[data-device=mobile] .agreement-box label{font-size:13px}body[data-device=mobile] .preview-overlay{padding:10px}body[data-device=mobile] .preview-dialog{border-radius:16px;max-height:calc(100svh - 20px)}body[data-device=mobile] .preview-images{grid-template-columns:1fr;overflow-y:auto}body[data-device=mobile] .preview-images img{max-height:calc(100svh - 118px)}body[data-device=mobile] .policy-overlay{padding:10px}body[data-device=mobile] .policy-dialog{border-radius:18px;max-height:calc(100svh - 20px)}body[data-device=mobile] .policy-header{padding:20px 18px 14px}body[data-device=mobile] .policy-header h2{font-size:24px}body[data-device=mobile] .policy-content{padding:18px}body[data-device=mobile] .policy-content p{font-size:14px}
