:root{
  --bg:#ecfbff;
  --panel:rgba(255,255,255,.82);
  --panel-soft:rgba(255,255,255,.70);
  --line:rgba(26,99,130,.12);
  --text:#1b4d63;
  --title:#0b6d87;
  --muted:#5a7d8e;
  --shadow:0 14px 36px rgba(15,96,125,.12);
  --rowShadow:0 8px 18px rgba(10,94,122,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg)}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.public-page{min-height:100vh;overflow:hidden}
.tv-wall{position:fixed;inset:0;background:url('beach-tv.jpg') center/cover no-repeat;transform:scale(1.02)}
.tv-overlay{position:fixed;inset:0;background:linear-gradient(180deg,rgba(239,251,255,.62),rgba(244,253,255,.40) 42%,rgba(255,247,227,.58));backdrop-filter:saturate(1.04)}
.wrap{position:relative;z-index:1;width:min(1220px,calc(100% - 22px));margin:0 auto;padding:8px 0}
.panel{background:var(--panel);border:1px solid rgba(255,255,255,.62);border-radius:20px;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.soft-panel{background:var(--panel-soft)}
.eyebrow{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#1d8bb0}
.topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:12px 14px;margin-bottom:8px}
.topbar h1,.admin-header h1{margin:4px 0 2px;font-size:28px;line-height:1;color:var(--title)}
.tv-lead{margin:0;font-size:12px;font-weight:700;color:#267898;max-width:640px}
.topbar-side{display:flex;gap:8px;align-items:stretch}
.clock-box{min-width:190px;background:rgba(255,255,255,.72);border:1px solid rgba(26,99,130,.08);border-radius:16px;padding:8px 12px;text-align:right}
.clock-label,.auto-refresh{font-size:10px;font-weight:700;color:var(--muted)}
.live-clock{font-size:24px;font-weight:800;color:#0b6988;line-height:1.05;margin:2px 0}
.live-clock small{display:block;font-size:11px;color:#557c8f;font-weight:700;margin-top:2px;text-transform:capitalize}
.backroom-link,.btn{display:inline-flex;align-items:center;justify-content:center;border:0;padding:10px 14px;border-radius:14px;font-weight:800;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease;box-shadow:0 10px 18px rgba(67,164,205,.10)}
.backroom-link:hover,.btn:hover{transform:translateY(-1px)}
.backroom-link{background:#ffffffde;color:#125b77}
.btn-primary{background:#0f86a8;color:#fff}
.btn-secondary{background:#fff;color:#0f86a8}
.btn-danger{background:#f04461;color:#fff}
.btn-small{padding:8px 12px;border-radius:12px;font-size:12px}
.board-head,.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.board-head h2,.section-head h2{margin:2px 0 0;font-size:21px;color:#0c6580}
.board-pill{display:inline-flex;align-items:center;justify-content:center;min-width:96px;padding:8px 10px;border-radius:999px;background:#ffffffd9;color:#166783;font-weight:800;font-size:13px;box-shadow:0 8px 18px rgba(19,105,134,.10)}
.tv-board-panel{padding:12px 14px 14px}
.tv-table{display:grid;gap:4px}
.tv-head,.tv-row{display:grid;grid-template-columns:52px minmax(210px,1.5fr) minmax(160px,1fr) 265px;column-gap:10px;align-items:center}
.tv-head{padding:0 8px 3px;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#5b8091}
.tv-row{min-height:54px;padding:5px 8px;border-radius:16px;background:rgba(255,255,255,.76);border:1px solid rgba(255,255,255,.56);box-shadow:var(--rowShadow)}
.tv-avatar-wrap{display:flex;align-items:center;justify-content:center}
.avatar{display:grid;place-items:center;border-radius:50%;overflow:hidden;box-shadow:inset 0 0 0 3px rgba(255,255,255,.55)}
.tv-avatar{width:40px;height:40px;background:#fff}

.tv-avatar img{width:100%;height:100%;object-fit:cover}
.tv-name-col{min-width:0}
.tv-name{font-size:18px;font-weight:800;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tv-note{margin-top:2px;font-size:11px;color:#648293;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tv-date{font-size:15px;font-weight:800;white-space:nowrap;color:#195f78}
.tv-counter{display:flex;justify-content:flex-end;align-items:center;min-width:0}
.countdown{font-variant-numeric:tabular-nums lining-nums}
.countdown.big,.countdown.compact,.tv-counter.js-countdown,.js-countdown.tv-counter,.tv-row .js-countdown{display:flex;gap:4px;justify-content:flex-end;align-items:center}
.count-item{min-width:58px;padding:6px 5px 5px;border-radius:12px;background:rgba(255,255,255,.90);border:1px solid rgba(18,108,138,.10);text-align:center;box-shadow:0 6px 12px rgba(16,96,126,.06)}
.count-item strong{display:block;font-size:19px;line-height:1;font-weight:900;color:#0d6986}
.count-item span{display:block;margin-top:3px;font-size:9px;font-weight:800;color:#5c7e8d;text-transform:uppercase;letter-spacing:.04em}
.countdown-ended{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:12px;background:#ffffffd9;color:#0d6986;font-weight:900;white-space:nowrap;font-size:13px}
.empty-state{padding:24px 16px;text-align:center;color:#24596f}
.empty-state h2{margin:0 0 8px;font-size:24px}
.empty-state p{margin:0;font-size:14px}
.footer{display:none}
/* admin */
.admin-page{min-height:100vh;background:linear-gradient(180deg,#ecfbff,#fff7ec);color:var(--text)}
.site-bg{position:fixed;inset:0;background:radial-gradient(circle at top left,rgba(126,220,255,.35),transparent 40%),radial-gradient(circle at right bottom,rgba(255,212,138,.3),transparent 36%);z-index:0}
.admin-wrap{position:relative;z-index:1;padding-bottom:24px}
.admin-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;margin-bottom:14px}
.flash{padding:14px 18px;border-radius:16px;margin-bottom:14px;font-weight:700}
.flash.ok{background:#e9fff3;color:#16603d;border:1px solid #b8ebca}
.flash.ko{background:#fff0f2;color:#a11c34;border:1px solid #f4b5c0}
.login-box,.admin-card{padding:18px 20px}
.admin-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:14px;margin-bottom:14px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid .full,.form-stack{display:grid;gap:12px}
label{display:grid;gap:6px;font-size:14px;font-weight:700;color:#255b70}
input,textarea,select{width:100%;padding:12px 13px;border-radius:14px;border:1px solid rgba(17,89,115,.18);background:rgba(255,255,255,.92);font:inherit;color:var(--text)}
textarea{resize:vertical;min-height:110px}
.actions-inline,.hero-actions,.table-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hint{margin:4px 0 0;font-size:13px;color:#5b7b8a}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:13px 10px;border-bottom:1px solid rgba(17,89,115,.12);text-align:left;vertical-align:top}
thead th{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#5b7b8a}
@media (max-width: 1180px){
  .wrap{width:min(1180px,calc(100% - 18px))}
  .tv-head,.tv-row{grid-template-columns:48px minmax(180px,1.4fr) minmax(145px,1fr) 245px}
  .tv-avatar{width:38px;height:38px}
  .tv-name{font-size:17px}
  .tv-date{font-size:14px}
  .count-item{min-width:54px}
  .count-item strong{font-size:17px}
}
@media (max-width: 980px){
  .admin-grid{grid-template-columns:1fr}
  .topbar{flex-direction:column}
  .topbar-side{width:100%;justify-content:space-between}
  .tv-head,.tv-row{grid-template-columns:46px minmax(150px,1.2fr) minmax(126px,1fr) 220px}
  .tv-name{font-size:16px}
  .tv-date{font-size:13px}
  .count-item{min-width:48px;padding:5px 4px}
  .count-item strong{font-size:16px}
}


.tv-avatar{border:0;cursor:pointer;padding:0}
.tv-avatar:focus{outline:3px solid rgba(11,109,135,.35);outline-offset:3px}
.avatar-modal[hidden]{display:none !important}
.avatar-modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px}
.avatar-modal-backdrop{position:absolute;inset:0;background:rgba(10,53,69,.58);backdrop-filter:blur(4px)}
.avatar-modal-dialog{position:relative;z-index:1;max-width:min(86vw,560px);width:100%}
.avatar-modal-card{background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.72);border-radius:28px;box-shadow:0 20px 50px rgba(6,57,74,.28);padding:22px 22px 16px;text-align:center}
.avatar-modal-image{display:block;width:min(100%,420px);max-height:68vh;margin:0 auto;border-radius:24px;object-fit:cover;box-shadow:0 14px 30px rgba(8,77,99,.14);background:#fff}
.avatar-modal-caption{margin-top:14px;font-size:22px;font-weight:800;color:#0c6580}
.avatar-modal-close{position:absolute;top:-10px;right:-10px;width:42px;height:42px;border:0;border-radius:50%;background:#ffffff;box-shadow:0 10px 24px rgba(6,57,74,.22);font-size:28px;line-height:1;cursor:pointer;color:#0c6580}
.modal-open{overflow:hidden}
.day-emoji {
    font-size: 28px;
}
.day-text {
    font-size: 16px;
}
.day-mood-box {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 6px;
}
.day-mood-title {
    font-size: 12px;
    font-weight: 700;
    opacity: 0.7;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.day-mood {
    height: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 6px 12px;
	margin-bottom: 8px;

    border-radius: 14px;
    background: rgba(255,255,255,0.75);
    backdrop-filter: blur(4px);
}

.day-line-1 {
    font-size: 12px;
    font-weight: 700;
    opacity: 0.7;
    margin-bottom: 2px;
}

.day-line-2 {
    font-size: 16px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 6px;
}