
:root{
  --green:#173d2f;
  --green2:#2f604b;
  --gold:#b99a58;
  --cream:#fffaf0;
  --paper:#fffdf7;
  --text:#20362b;
  --muted:#6c766f;
  --danger:#9b2d2d;
  --ok:#2e6f42;
  --shadow:0 18px 45px rgba(20,45,32,.16);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:linear-gradient(160deg,#123629,#315c46);color:var(--text)}
body{padding:env(safe-area-inset-top) 0 calc(88px + env(safe-area-inset-bottom));overflow-x:hidden}
.app{width:100%;max-width:560px;margin:0 auto;background:var(--cream);min-height:100vh;box-shadow:var(--shadow);position:relative}
.hero{position:relative;padding:14px 14px 0}
.hero img{display:block;width:100%;height:235px;object-fit:cover;border-radius:0 0 30px 30px;box-shadow:0 12px 28px rgba(0,0,0,.16)}
.hero .badge{position:absolute;left:28px;bottom:18px;background:rgba(23,61,47,.86);color:#fff;padding:10px 14px;border-radius:999px;font-weight:800;border:1px solid rgba(255,255,255,.3)}
.content{padding:24px 20px 34px}
.kicker{letter-spacing:.35em;text-transform:uppercase;color:var(--green2);font-weight:900;font-size:13px;margin-bottom:10px}
h1{font-size:44px;line-height:.98;margin:0 0 14px;color:var(--green2);letter-spacing:-1px}
h2{font-size:34px;line-height:1;margin:0 0 12px;color:var(--green2)}
p{font-size:18px;line-height:1.42;color:var(--muted);margin:0 0 18px}
.card{background:var(--paper);border:1px solid rgba(185,154,88,.35);border-radius:26px;padding:18px;box-shadow:0 10px 25px rgba(0,0,0,.05);margin:16px 0}
.big-grid{display:grid;gap:14px;margin-top:20px}
.big-btn,.submit-btn,.ghost-btn{
  width:100%;border:0;border-radius:24px;padding:20px 18px;font-size:21px;font-weight:900;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:12px;text-align:center
}
.big-btn{background:linear-gradient(135deg,var(--green2),var(--green));color:white;box-shadow:0 12px 24px rgba(23,61,47,.24)}
.big-btn.secondary{background:#fff;color:var(--green);border:2px dashed var(--gold)}
.big-btn.gold{background:linear-gradient(135deg,#d7bd78,#a98238);color:#fff}
.submit-btn{background:linear-gradient(135deg,var(--green2),var(--green));color:#fff;margin-top:16px}
.ghost-btn{background:white;color:var(--green);border:1px solid rgba(185,154,88,.55);font-size:17px;padding:15px}
input,textarea{
  width:100%;border:1.5px solid rgba(185,154,88,.65);border-radius:18px;background:white;padding:16px;font-size:18px;outline:none;color:var(--text);margin:6px 0 16px
}
textarea{min-height:110px;resize:vertical}
label{font-weight:900;color:#1d382d;font-size:17px}
.file-zone{border:2px dashed var(--gold);border-radius:24px;padding:18px;text-align:center;background:rgba(255,255,255,.65);margin:13px 0}
.file-zone input{display:none}
.file-zone label{display:flex;justify-content:center;align-items:center;gap:10px;min-height:66px;font-size:20px}
.preview-list{display:grid;gap:10px;margin:14px 0}
.preview-item{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid rgba(185,154,88,.3);border-radius:18px;padding:10px}
.preview-item img,.preview-item video{width:64px;height:64px;object-fit:cover;border-radius:13px;background:#eee}
.preview-meta{font-size:14px;color:var(--muted);line-height:1.25;overflow:hidden}
.notice{border-radius:22px;padding:16px;font-size:17px;font-weight:800;margin:14px 0}
.notice.ok{background:#e4f2df;color:var(--ok)}
.notice.err{background:#ffe1dc;color:var(--danger)}
.bottom-nav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:100%;max-width:560px;background:rgba(255,253,247,.96);backdrop-filter:blur(18px);display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:10px 8px calc(10px + env(safe-area-inset-bottom));border-top:1px solid rgba(185,154,88,.35);z-index:30}
.bottom-nav a{text-decoration:none;color:var(--green);font-size:12px;font-weight:900;text-align:center;padding:8px 3px;border-radius:16px}
.bottom-nav span{display:block;font-size:24px;line-height:1.05;margin-bottom:3px}
.bottom-nav a.active{background:#e9efdf}
.gear{position:fixed;right:14px;bottom:calc(92px + env(safe-area-inset-bottom));z-index:40;width:52px;height:52px;border-radius:50%;background:white;border:1px solid rgba(185,154,88,.55);box-shadow:0 8px 22px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:26px}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.tile{background:white;border-radius:18px;overflow:hidden;border:1px solid rgba(185,154,88,.25);box-shadow:0 8px 18px rgba(0,0,0,.07)}
.tile img,.tile video{width:100%;aspect-ratio:1/1.15;object-fit:cover;display:block;background:#eee}
.tile .cap{padding:11px;font-size:14px;color:var(--text);line-height:1.25}
.task{font-weight:900;color:var(--green)}
.upload-overlay{position:fixed;inset:0;background:rgba(20,37,30,.58);display:none;align-items:center;justify-content:center;z-index:100;padding:30px}
.upload-box{background:white;border-radius:28px;padding:28px 22px;text-align:center;max-width:320px;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.spinner{width:58px;height:58px;border-radius:50%;border:6px solid #e9e1cd;border-top-color:var(--green);animation:spin 1s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.progress-wrap{height:12px;background:#eee6d4;border-radius:20px;overflow:hidden;margin-top:16px}
.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--green2),var(--gold));transition:.2s}
.back{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:white;background:rgba(23,61,47,.86);padding:9px 13px;border-radius:999px;font-weight:900;position:absolute;left:24px;top:24px;z-index:3}
.admin-panel{max-width:560px;margin:0 auto;background:var(--cream);min-height:100vh;padding:28px 20px}
.small{font-size:14px;color:var(--muted)}
@media (max-width:380px){
  h1{font-size:38px}
  h2{font-size:30px}
  .content{padding-left:16px;padding-right:16px}
  .hero img{height:215px}
}
