/* ==========================================================
   Task Sheet Stylesheet
   File: plugins/task-sheet/assets/task-sheet.css
   ========================================================== */

/* ---------- Theme Variables ---------- */
:root {
  --blue:    #0a57c6;
  --blue-2:  #0f6ff0;
  --red:     #df2a43;
  --mint:    #33d1a0;
  --yellow:  #ffd166;
  --bg:      #f5f9ff;
  --ink:     #0f2145;
  --card:    #ffffff;
  --shadow:  0 10px 24px rgba(13,52,128,.16);
  --radius:  22px;
}

/* ---------- Base Layout ---------- */
.task-sheet-root,
#task-sheet-app {
  min-height: 100%;
}

html, body {
  height: auto;
}

body.task-sheet-page {
  background: var(--bg);
  color: var(--ink);
}

/* ---------- Header / Hero ---------- */
header.hero {
  position: sticky;
  top: 0;
  margin-top: -24px;
  z-index: 50;
  display: flex;
  align-items: center;
  min-height: 150px;
  padding: 24px 28px 24px 300px;
  color: #fff;
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-2) 100%);
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
  overflow: hidden;
}

.hero:before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .15;
  pointer-events: none;
  background:
    radial-gradient(12px 12px at 12% 22%, #fff 35%, transparent 36%) repeat,
    radial-gradient(10px 10px at 60% 40%, #fff 35%, transparent 36%) repeat,
    radial-gradient(8px 8px at 35% 75%, #fff 35%, transparent 36%) repeat,
    radial-gradient(14px 14px at 85% 20%, #fff 35%, transparent 36%) repeat;
  background-size: 180px 120px, 220px 160px, 200px 150px, 240px 140px;
  mix-blend-mode: screen;
}

.hero h1 {
  font-family: "Baloo 2", cursive;
  font-size: 56px;
  margin: 0;
  letter-spacing: .5px;
}

.subtitle { margin: 8px 0 0; font-size: 16px; }
.tag      { margin-top: 6px; padding: 6px 12px; border-radius: 999px;
            display: inline-block; font-weight: 700;
            background: rgba(255,255,255,.18);
            border: 2px dashed rgba(255,255,255,.4); }

/* ---------- Sidebar ---------- */
.sidebar {
  position: fixed;
  left: 0; top: 0; bottom: 0;
  z-index: 60;
  width: 310px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: #fff;
  background: linear-gradient(160deg, var(--blue) 0%, var(--blue-2) 100%);
}

.brand { display: flex; gap: 10px; align-items: center; }
.brand .bot {
  width: 46px; height: 46px;
  border-radius: 12px;
  background: #fff;
  display: grid; place-items: center;
  box-shadow: var(--shadow);
}
.brand .bot:before { content: "\01F916"; font-size: 26px; }
.brand h2 { font-family: "Baloo 2", cursive; font-size: 26px; margin: 0; }

.players { flex: 1; overflow: auto; padding-right: 6px; }

/* Player list items */
.player {
  display: flex; align-items: center; gap: 10px;
  padding: 10px;
  border-radius: 16px;
  cursor: pointer;
  transition: transform .08s ease, background .2s ease;
}
.player:hover   { transform: translateY(-1px); background: rgba(255,255,255,.12); }
.player.active  { background: #fff; color: var(--ink); box-shadow: var(--shadow); }

.avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, #fff, #dff2ff);
  color: var(--blue);
  font-weight: 900;
  display: grid; place-items: center;
}
.pname { font-weight: 900; letter-spacing: .3px; font-size: 1.5em; }

.badge {
  margin-left: auto; min-width: 46px;
  padding: 4px 10px; border-radius: 999px;
  background: #fff; color: var(--blue);
  font-weight: 900; font-size: 1.75em;
  text-align: center;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.4);
}

/* Delete button inside players */
.icon {
  width: 28px; height: 28px; border-radius: 999px;
  border: none; margin-left: 8px;
  display: grid; place-items: center;
  font-size: 16px; font-weight: 900; line-height: 1;
  cursor: pointer;
  transition: transform .08s ease, background .2s ease;
}
.player .icon.del { background: rgba(255,255,255,.18); color: #fff; }
.player.active .icon.del { background: #ffdfe2; color: #df2a43; }
.player .icon.del:hover  { transform: scale(1.05); background: #ffebee; color: #df2a43; }

.add-player {
  border: none; border-radius: 16px;
  background: #fff; color: var(--blue);
  padding: 10px 12px;
  font-weight: 900;
  box-shadow: var(--shadow);
  cursor: pointer;
}
.add-player:hover { filter: brightness(1.05); }

.player-input { display: flex; gap: 8px; }
.player-input input { flex: 1; }

/* ---------- Main Content ---------- */
.page          { padding: 24px; padding-left: 170px; }
.stacked-cards { display: grid; grid-template-columns: 1fr; gap: 22px; }
.grid          { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 22px; }

/* Scrollable prize list */
#prizes{
  max-height:50vh;
  overflow:auto;
  padding-right:6px; /* matches History */
}


@media (max-width:1000px){
  header.hero { padding-left: 270px; }
  .grid       { grid-template-columns: 1fr; }
}

/* Cards */
.card {
  background: var(--card);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
}
.card h3 { margin: 0 0 12px; font-family: "Baloo 2", cursive; font-size: 26px; }

/* Toolbars */
.toolbar {
  display: grid; gap: 12px; align-items: center;
  grid-template-columns: 150px 1fr 120px 140px;
}
.toolbar input[type="text"] { font-size: 16px; }
.toolbar .desc { grid-column: 2 / span 2; }

/* Inputs & buttons */
input, textarea {
  width: 100%;
  padding: 10px 14px;
  border-radius: 14px;
  border: 2px solid #e3edff;
  background: #f7fbff;
  font-family: inherit; font-size: 15px;
  outline: none;
}
.btn {
  border: none; border-radius: 14px;
  padding: 12px 16px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--shadow);
}
.btn       { background: var(--mint); color: #08323a; }
.btn.blue  { background: var(--blue); color: #fff; }
.btn.red   { background: var(--red); color: #fff; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---------- Lists ---------- */
.item {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center; gap: 14px;
  margin: 10px 0;
  padding: 12px 14px;
  border-radius: 16px;
  background: #fbfdff;
  border: 2px dashed #e8f0ff;
}
.title { font-weight: 700; }
.meta  { opacity: .7; font-size: 12px; }

/* Selected player card */
.selected { display: flex; align-items: center; gap: 16px; }
.bigpoints { font-size: 42px; font-weight: 900; color: var(--blue); }

/* History */
.history {
  max-height: 260px;
  overflow: auto;
  padding-left: 6px;
}
.history .entry {
  display: flex; gap: 8px; align-items: center;
  padding: 8px 0;
  border-bottom: 1px dashed #e9f0ff;
}

/* Pills */
.pill       { padding: 4px 10px; border-radius: 999px; font-weight: 700; }
.pill.add   { background: #e7fff6; color: #0a6e55; }
.pill.out   { background: #ffeaea; color: #a11616; }

/* ---------- Animations ---------- */
.fly { position: fixed; z-index: 99; pointer-events: none;
       font-weight: 900; font-size: 20px; color: #19c37d;
       text-shadow: 0 2px 0 rgba(0,0,0,.1);
       animation: floatUp 1s ease-out forwards; }
@keyframes floatUp {
  0%   { opacity: 0; transform: translateY(10px) scale(.7); }
  15%  { opacity: 1; }
  100% { opacity: 0; transform: translateY(-60px) scale(1.2); }
}
.coin { position: fixed; z-index: 99; width: 14px; height: 14px; border-radius: 50%;
        background: radial-gradient(circle at 30% 30%, #fff 10%, #ffe082 11%, #ffca28 60%, #ffb300 100%);
        box-shadow: 0 3px 8px rgba(0,0,0,.2); }
.chip { position: fixed; z-index: 98; width: 8px; height: 8px; border-radius: 50%; opacity:.9; }

.pulse  { animation: pulse .6s ease-out; }
@keyframes pulse { 0%{transform:scale(1)} 60%{transform:scale(1.25)} 100%{transform:scale(1)} }
.bounce { animation: bounce .5s ease-out; }
@keyframes bounce { 0%{transform:translateY(0)} 40%{transform:translateY(-6px)} 100%{transform:translateY(0)} }
.shake  { animation: shake .4s linear; }
@keyframes shake {
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-6px)}
  40%{transform:translateX(6px)}
  60%{transform:translateX(-4px)}
  80%{transform:translateX(4px)}
}

.note { font-size: 14px; opacity: .85; }

/* Migrate notice box */
#task-sheet-migrate {
  display: none;
  margin: 14px; padding: 12px 14px;
  border-radius: 14px;
  background: #fff;
  border-left: 4px solid var(--blue);
  box-shadow: var(--shadow);
}

/* ---------- Responsive ---------- */

/* Fluid typography */
.hero h1     { font-size: clamp(28px, 6vw, 56px); }
.pname       { font-size: clamp(18px, 3.8vw, 24px); }
.bigpoints   { font-size: clamp(26px, 7vw, 42px); }

/* Sidebar toggle + overlay */
.nav-toggle {
  position: absolute; top: 18px; left: 12px;
  width: 42px; height: 42px; border-radius: 12px;
  border: none; background: #fff; color: var(--blue);
  font-size: 22px; line-height: 1;
  display: none; place-items: center;
  box-shadow: var(--shadow);
  cursor: pointer;
}

/* Off-canvas sidebar ≤1024px */
@media (max-width: 1024px){
  .nav-toggle { display: inline-grid; }
  .sidebar {
    width: min(86vw, 320px);
    transform: translateX(-105%);
    transition: transform .25s ease;
    box-shadow: var(--shadow);
  }
  .sidebar.open { transform: translateX(0); }
  .overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.35);
    backdrop-filter: blur(1.5px);
    z-index: 55;
  }
  header.hero { padding-left: 68px; }
  .page { padding-left: 16px; padding-right: 16px; }
}

/* Tablet adjustments ≤900px */
@media (max-width: 900px){
  .grid { grid-template-columns: 1fr; }
  .toolbar { grid-template-columns: 1fr; }
  .toolbar .desc { grid-column: auto; }
  .item { grid-template-columns: 1fr auto auto; align-items: start; gap: 10px; }
  .btn { padding: 12px 14px; }
  .history { max-height: 40vh; }
}

/* Small phones ≤560px */
@media (max-width: 560px){
  header.hero { padding: 18px 16px 18px 64px; }
  .players { padding-right: 0; }
  .card { padding: 14px; border-radius: 18px; }
  .badge { min-width: 40px; font-size: 1.4em; }
  .avatar { width: 34px; height: 34px; }

  /* Full width cards on phones */
  .page { padding-left: 0; padding-right: 0; }
  .card { border-radius: 0; }
  .pill { width: 55px; }
  #addTaskCard #taskPoints { max-width: 92px; }
}

/* ==========================================================
   Tablet layout (clean actions) — Tasks list
   Keeps pill + text + two compact buttons on one row
   ========================================================== */
@media (min-width: 561px) and (max-width: 900px){
  #addTaskCard .item,
  #prizeCard .item{
    /* switch from grid to a neat single row */
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
  }

  /* points pill never stretches */
  #addTaskCard .item .pill,
  #prizeCard .item .pill{
    flex: 0 0 auto;
    white-space: nowrap;
  }

  /* text block (title + date) gets the flexible space */
  #addTaskCard .item > div,
  #prizeCard .item > div{
    flex: 1 1 auto;
    min-width: 0;                /* enables ellipsis */
  }
  #addTaskCard .item .title,
  #prizeCard .item .title{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* compact action buttons, sit at the right side */
  #addTaskCard .item .btn,
  #prizeCard .item .btn{
    flex: 0 0 auto;
    padding: 8px 12px;           /* smaller */
    border-radius: 12px;
    font-size: 14px;
    min-width: 88px;             /* prevents tiny tap targets */
  }

  #addTaskCard .item .btn.blue{  /* Complete */
    order: 3;
  }
  #addTaskCard .item .btn.red{   /* Delete */
    order: 4;
    margin-left: 8px;
  }
}
/* ---------- Misc Fixes ---------- */

/* Respect iOS safe areas */
@supports (padding: max(0px)){
  header.hero { padding-top: max(18px, env(safe-area-inset-top)); }
  .sidebar    { padding-top: max(18px, env(safe-area-inset-top)); }
}

/* WordPress admin bar spacing */
body.admin-bar header.hero { top: 32px; }
@media (max-width: 782px){
  body.admin-bar header.hero { top: 46px; }
}

/* Task list scrollable */
#addTaskCard #taskPoints { max-width: 120px; }
#addTaskCard #tasks {
  max-height: 50vh;
  overflow: auto;
  padding-right: 6px;
}

/* Selected player in sticky header */
.selbar {
  margin-top: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  display: inline-block;
  font-weight: 900;
  background: rgba(255,255,255,.18);
  border: 2px dashed rgba(255,255,255,.4);
}
.selbar .label { margin-right: 6px; opacity: .8; font-weight: 700; }
