:root{
  --bg:#0b0f10;
  --bg-2:#0e1415;
  --sidebar:#0b3e43;
  --sidebar-2:#0e4d54;
  --card:#121819;
  --card-2:#172021;
  --card-3:#1d292b;
  --line:rgba(255,255,255,.095);
  --line-strong:rgba(255,255,255,.15);
  --text:#f6f8f8;
  --muted:#a7b4b6;
  --soft:#718084;
  --brand:#3e7176;
  --brand-light:#9ad2d6;
  --ok:#00b686;
  --warn:#f6b042;
  --bad:#ff4d5a;
  --radius-xl:30px;
  --radius-lg:24px;
  --radius-md:18px;
  --shadow:0 26px 80px rgba(0,0,0,.35);
  --font:"Inter Tight", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:var(--font);
  background:
    radial-gradient(circle at 35% -10%, rgba(62,113,118,.25), transparent 35rem),
    radial-gradient(circle at 80% 100%, rgba(0,182,134,.11), transparent 28rem),
    var(--bg);
  color:var(--text);
}
button,input{font:inherit}
button{cursor:pointer}
a{color:inherit}
img{display:block;max-width:100%}

.eyebrow{
  margin:0 0 10px;
  color:var(--brand-light);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
  font-weight:600;
}

.subtitle{
  margin:6px 0 0;
  color:var(--muted);
  font-size:17px;
  font-weight:400;
  line-height:1.4;
}

/* ================= LOGIN ================= */

.login-screen{
  min-height:100vh;
  display:grid;
  grid-template-columns:280px 1fr;
}

.login-brand-panel,
.sidebar{
  background:linear-gradient(180deg, var(--sidebar), #082e32);
  border-right:1px solid rgba(255,255,255,.12);
}

.login-brand-panel{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:28px;
}

.brand-lockup{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-lockup img{
  width:52px;
  height:52px;
  object-fit:contain;
}

.brand-lockup strong{
  display:block;
  font-size:24px;
  line-height:1;
  font-weight:600;
  letter-spacing:-.04em;
}

.brand-lockup small{
  display:block;
  margin-top:5px;
  color:#c7dddd;
  font-size:13px;
  font-weight:500;
  letter-spacing:.01em;
}

.support-block{
  display:flex;
  align-items:center;
  gap:12px;
  color:#fff;
}

.support-block > span{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.4);
  color:#d9eeee;
}

.support-block strong{
  display:block;
  font-size:13px;
  font-weight:500;
}

.support-block a{
  color:#bef4f0;
  font-size:13px;
  font-weight:400;
}

.login-content{
  display:grid;
  place-items:center;
  padding:42px;
}

.login-center{
  width:min(850px,100%);
  text-align:center;
}

.welcome-icon{
  width:76px;
  height:76px;
  display:grid;
  place-items:center;
  margin:0 auto 26px;
  border-radius:50%;
  border:1px solid rgba(154,210,214,.5);
  background:rgba(62,113,118,.22);
  font-size:36px;
}

.login-center h1{
  margin:0;
  font-size:clamp(48px,6vw,82px);
  line-height:.92;
  letter-spacing:-.065em;
  font-weight:600;
}

.login-copy{
  max-width:560px;
  margin:18px auto 26px;
  color:var(--muted);
  font-size:18px;
  line-height:1.45;
  font-weight:400;
}

.search{
  width:min(520px,100%);
  height:58px;
  margin:0 auto 28px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:0 18px;
  border:1px solid var(--line-strong);
  border-radius:999px;
  background:rgba(255,255,255,.035);
}

.search span{
  color:var(--soft);
  font-size:22px;
}

.search input{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  color:#fff;
  font-size:16px;
  font-weight:400;
}

.people-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.person-option{
  min-height:170px;
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018));
  color:#fff;
  display:grid;
  place-items:center;
  padding:22px;
  transition:.18s ease;
}

.person-option:hover{
  transform:translateY(-3px);
  border-color:rgba(154,210,214,.55);
  background:linear-gradient(180deg, rgba(62,113,118,.3), rgba(255,255,255,.03));
}

.person-option .avatar{
  margin-bottom:14px;
}

.person-option strong{
  font-size:20px;
  font-weight:500;
  letter-spacing:-.025em;
}

.person-option small{
  margin-top:5px;
  color:var(--muted);
  font-size:14px;
  font-weight:400;
}

.privacy-note{
  margin:26px 0 0;
  color:var(--soft);
  font-size:14px;
  font-weight:400;
}

/* ================= APP LAYOUT ================= */

.app-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
}

.sidebar{
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  flex-direction:column;
  padding:26px 22px;
}

.side-nav{
  display:grid;
  gap:9px;
  margin-top:42px;
}

.nav-btn{
  height:54px;
  display:flex;
  align-items:center;
  gap:14px;
  border:0;
  border-radius:16px;
  background:transparent;
  color:#d4e3e4;
  padding:0 18px;
  text-align:left;
  font-size:18px;
  font-weight:500;
}

.nav-btn span{
  width:22px;
  color:#d3f3f0;
  opacity:.9;
}

.nav-btn:hover,
.nav-btn.active{
  color:#fff;
  background:rgba(255,255,255,.12);
}

.sidebar-support{
  margin-top:auto;
  margin-bottom:20px;
}

.user-card{
  width:100%;
  min-height:72px;
  display:grid;
  grid-template-columns:52px 1fr auto;
  align-items:center;
  gap:12px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:20px;
  background:rgba(255,255,255,.07);
  color:#fff;
  padding:12px;
  text-align:left;
}

.user-card strong{
  display:block;
  font-size:16px;
  font-weight:500;
}

.user-card small{
  color:#c1d7d8;
  font-size:13px;
  font-weight:400;
}

.user-card b{
  font-size:16px;
  color:#cfeaea;
  font-weight:400;
}

.main{
  width:min(1280px,100%);
  margin:0 auto;
  padding:34px clamp(24px,4vw,58px) 52px;
}

.topbar-app{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  margin-bottom:28px;
}

.topbar-app h1{
  margin:0;
  font-size:clamp(42px,4.7vw,66px);
  line-height:.94;
  letter-spacing:-.065em;
  font-weight:600;
}

.top-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.circle-btn,
.profile-chip{
  border:1px solid var(--line);
  background:var(--card-2);
  color:#fff;
  border-radius:999px;
}

.circle-btn{
  position:relative;
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  font-size:20px;
}

.circle-btn i{
  position:absolute;
  top:-7px;
  right:-5px;
  width:22px;
  height:22px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#00a9b8;
  color:#fff;
  font-style:normal;
  font-size:12px;
  font-weight:600;
}

.profile-chip{
  height:46px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 12px;
  font-size:24px;
}

.view{display:none}
.view.active{display:block}

/* ================= CARDS ================= */

.dashboard-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(340px,.8fr);
  gap:20px;
}

.card{
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:rgba(18,24,25,.88);
  box-shadow:0 22px 60px rgba(0,0,0,.18);
}

.next-card{
  min-height:285px;
  padding:28px;
  background:
    radial-gradient(circle at top left, rgba(62,113,118,.42), transparent 28rem),
    linear-gradient(145deg, rgba(30,45,47,.95), rgba(18,24,25,.92));
}

.next-card h2{
  margin:0;
  max-width:650px;
  font-size:clamp(46px,5.4vw,76px);
  line-height:.9;
  letter-spacing:-.065em;
  font-weight:600;
}


.next-info-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:30px;
  max-width:640px;
}

.next-info-item{
  min-height:64px;
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 14px;

  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;

  background:rgba(255,255,255,.045);
}

.next-info-icon{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;

  border-radius:14px;
  background:rgba(154,210,214,.10);
  border:1px solid rgba(154,210,214,.18);

  color:var(--brand-light);
  font-size:18px;
  line-height:1;
}

.next-info-item small{
  display:block;
  margin-bottom:4px;

  color:var(--muted);
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.next-info-item strong{
  display:block;

  color:var(--text);
  font-size:16px;
  font-weight:600;
  letter-spacing:-.01em;
}


.my-card{
  padding:26px;
}

.card-title{
  margin:0 0 20px;
  font-size:24px;
  line-height:1;
  letter-spacing:-.035em;
  font-weight:600;
}

.my-assignment-empty{
  margin:0 0 22px;
  color:var(--muted);
  font-size:18px;
  line-height:1.45;
  font-weight:400;
}

.action-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;

}

.btn-ok,
.btn-bad,
.btn-muted{
  min-height:48px;
  border:0;
  border-radius:14px;
  padding:0 18px;
  color:#fff;
  font-size:15px;
  font-weight:500;
}

.btn-ok{background:var(--ok)}
.btn-bad{background:var(--bad)}
.btn-muted{background:var(--card-3); color:#d7e4e5; border:1px solid var(--line)}

.teams-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-top:20px;
}

.visual-team-card{
  padding:26px;
}

.visual-team-card header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:22px;
}

.visual-team-card h3{
  margin:0;
  font-size:25px;
  letter-spacing:-.035em;
  font-weight:600;
}

.team-title-icon{
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.team-roster{
  display:flex;
  align-items:flex-start;
  gap:18px;
  flex-wrap:wrap;
}

.roster-person{
  width:74px;
  text-align:center;
}

.avatar{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:linear-gradient(180deg,#ffd977,#f0b94f);
  color:#111;
  font-size:34px;
  margin:0 auto;
}

.avatar.small{
  width:48px;
  height:48px;
  font-size:26px;
}

.roster-person strong{
  display:block;
  margin-top:8px;
  font-size:14px;
  line-height:1;
  font-weight:500;
}

.roster-person small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
  line-height:1.05;
  font-weight:400;
}

.status-dot{
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  margin:8px auto 0;
  border-radius:50%;
  border:2px solid currentColor;
  font-size:10px;
  font-weight:600;
}

.status-dot.confirmed{color:var(--ok)}
.status-dot.pending{color:var(--warn)}
.status-dot.cant{color:var(--bad)}

.more-pill{
  align-self:center;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.09);
  color:#d8e3e3;
  padding:10px 14px;
  font-size:15px;
  font-weight:500;
}

.lower-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:20px;
  margin-top:20px;
}

.list-card{
  padding:24px;
}

.clean-list{
  display:grid;
  gap:14px;
}

.clean-item{
  display:grid;
  grid-template-columns:44px 1fr auto;
  align-items:center;
  gap:14px;
  padding:12px;
  border-radius:18px;
  background:rgba(255,255,255,.035);
  border:1px solid var(--line);
}

.clean-icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:var(--card-3);
  color:var(--brand-light);
  font-weight:500;
}

.clean-item strong{
  display:block;
  font-size:16px;
  font-weight:500;
  letter-spacing:-.015em;
}

.clean-item small{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:13px;
  font-weight:400;
}

.badge{
  border-radius:999px;
  padding:8px 11px;
  background:var(--card-3);
  font-size:12px;
  font-weight:500;
}

.badge.confirmed{color:var(--ok)}
.badge.pending{color:var(--warn)}
.badge.cant{color:var(--bad)}

.full-card{
  padding:28px;
}

.section-heading{
  margin:0 0 22px;
}

.section-heading h2{
  margin:0;
  font-size:38px;
  letter-spacing:-.045em;
  font-weight:600;
}

.section-heading p{
  margin:8px 0 0;
  color:var(--muted);
  font-weight:400;
}

.assignment-list{
  display:grid;
  gap:12px;
}

.assignment-row{
  display:grid;
  grid-template-columns:54px 1fr auto;
  align-items:center;
  gap:14px;
  padding:13px;
  border-radius:18px;
  background:var(--card-2);
  border:1px solid var(--line);
}

.assignment-row .avatar{
  width:54px;
  height:54px;
  font-size:28px;
}

.assignment-row strong{
  font-weight:500;
  letter-spacing:-.015em;
}

.assignment-row small{
  display:block;
  color:var(--muted);
  margin-top:4px;
  font-weight:400;
}

/* ================= MOBILE ================= */

.mobile-nav{display:none}

@media (max-width:800px){
  body{
    background:
      radial-gradient(circle at top, rgba(62,113,118,.24), transparent 22rem),
      var(--bg);
  }

  .login-screen{
    display:block;
  }

  .login-brand-panel{
    display:none;
  }

  .login-content{
    min-height:100vh;
    padding:22px 14px;
    place-items:start;
  }

  .login-center{
    text-align:left;
    margin:0 auto;
  }

  .welcome-icon{
    margin:22px 0 24px;
    width:62px;
    height:62px;
    font-size:30px;
  }

  .login-center h1{
    font-size:54px;
  }

  .login-copy{
    margin:14px 0 22px;
    font-size:16px;
  }

  .search{
    width:100%;
    margin-bottom:16px;
  }

  .people-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .person-option{
    min-height:78px;
    display:grid;
    grid-template-columns:52px 1fr auto;
    gap:12px;
    place-items:center start;
    text-align:left;
    border-radius:18px;
    padding:12px 14px;
  }

  .person-option .avatar{
    width:52px;
    height:52px;
    font-size:28px;
    margin:0;
  }

  .person-option::after{
    content:"›";
    color:var(--muted);
    font-size:28px;
  }

  .app-shell{
    display:block;
    padding-bottom:92px;
  }

  .sidebar{
    display:none;
  }

  .main{
    padding:20px 14px 24px;
  }

  .topbar-app{
    align-items:center;
    margin-bottom:20px;
  }

  .topbar-app h1{
    font-size:40px;
  }

  .top-actions{
    gap:9px;
  }

  .circle-btn{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  font-size:18px;
}

.profile-chip{
  height:42px;
}

  .dashboard-grid,
  .teams-preview,
  .lower-grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .next-card{
    min-height:250px;
    padding:22px;
    border-radius:26px;
  }

  .next-card h2{
    font-size:48px;
  }
  
  .next-info-list{
    grid-template-columns:1fr;
    margin-top:24px;
  }

  .next-info-item{
    min-height:58px;
  }



  .card{
    border-radius:24px;
  }

  .my-card,
  .visual-team-card,
  .list-card,
  .full-card{
    padding:20px;
  }

  .team-roster{
    gap:16px;
  }

  .roster-person{
    width:66px;
  }

  .avatar{
    width:58px;
    height:58px;
    font-size:30px;
  }

  .clean-item,
  .assignment-row{
    grid-template-columns:48px 1fr;
  }

  .clean-item .badge,
  .assignment-row .badge{
    grid-column:2;
    justify-self:start;
  }

  .mobile-nav{
    position:fixed;
    left:12px;
    right:12px;
    bottom:12px;
    z-index:50;
    display:grid;
    grid-template-columns:repeat(5,1fr);
    padding:8px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:24px;
    background:linear-gradient(180deg, rgba(14,77,84,.96), rgba(8,46,50,.96));
    backdrop-filter:blur(20px);
    box-shadow:0 18px 50px rgba(0,0,0,.38);
  }

  .mobile-nav-btn{
    min-height:54px;
    border:0;
    border-radius:17px;
    background:transparent;
    color:#d5e8e8;
    display:grid;
    place-items:center;
    gap:2px;
    font-weight:500;
  }

  .mobile-nav-btn span{
    font-size:19px;
  }

  .mobile-nav-btn small{
    font-size:10px;
  }

  .mobile-nav-btn.active{
    background:rgba(255,255,255,.13);
    color:#fff;
  }

  /* Emoji picker mobile */

  .emoji-screen{
    padding:14px;
    align-items:start;
  }

  .emoji-card{
    border-radius:28px;
    padding:22px;
    margin-top:10px;
  }

  .emoji-brand{ margin-bottom:38px; }

  .emoji-hero{ text-align:left; }

  .emoji-hero h1{ font-size:54px; }

  .emoji-grid{
    grid-template-columns:repeat(4,1fr);
    gap:10px;
  }

  .emoji-option{
    height:66px;
    border-radius:18px;
    font-size:32px;
  }

}


/* ================= EMOJI PICKER ================= */

.emoji-screen{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px;
  background:
    radial-gradient(circle at top left, rgba(62,113,118,.34), transparent 32rem),
    radial-gradient(circle at bottom right, rgba(0,182,134,.12), transparent 28rem),
    var(--bg);
}

.emoji-card{
  width:min(860px,100%);
  border:1px solid var(--line);
  border-radius:36px;
  background:rgba(18,24,25,.92);
  box-shadow:var(--shadow);
  padding:34px;
}

.emoji-brand{ margin-bottom:46px; }

.emoji-hero{
  text-align:center;
  margin-bottom:28px;
}

.emoji-hero h1{
  margin:0;
  font-size:clamp(46px,6vw,78px);
  line-height:.92;
  letter-spacing:-.065em;
  font-weight:600;
}

.emoji-grid{
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:12px;
  margin:30px auto 22px;
}

.emoji-option{
  height:72px;
  border:1px solid var(--line);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  font-size:34px;
  transition:.16s ease;
}

.emoji-option:hover{
  transform:translateY(-2px);
  border-color:rgba(154,210,214,.55);
  background:rgba(62,113,118,.28);
}

.skip-btn{
  display:block;
  margin:12px auto 0;
  height:44px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--card-2);
  color:var(--muted);
  padding:0 18px;
  font-weight:500;
}

/* ================= CONFIRMO ================= */

.confirmo-date-group{
  margin-top:36px;
}

.confirmo-date-group:first-child{
  margin-top:18px;
}

.confirmo-date-title{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:fit-content;
  margin:0 0 22px;
  padding:10px 18px;
  border-radius:999px;
  background:rgba(122,230,221,.10);
  border:1px solid rgba(122,230,221,.25);
  color:var(--brand-light);
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.confirmo-team-group{
  margin-bottom:34px;
}

.confirmo-team-title{
  margin:0 0 18px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:var(--text);
  font-size:28px;
  font-weight:700;
  letter-spacing:-.04em;
}

.confirmo-team-title::before{
  content:"";
  display:inline-block;
  width:4px;
  height:24px;
  margin-right:12px;
  border-radius:999px;
  background:var(--brand-light);
  vertical-align:middle;
}

.confirmo-team-group .assignment-list{
  gap:12px;
}

/* ================= CONFIRMO TABS ================= */

.confirmo-date-tabs{
  display:flex;
  gap:12px;
  margin:22px 0 26px;

  overflow-x:auto;
  flex-wrap:nowrap;
  padding-bottom:4px;

  scrollbar-width:none;
}

.confirmo-date-tabs::-webkit-scrollbar{
  display:none;
}

.confirmo-date-tab{
  flex-shrink:0;

  min-height:38px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0 16px;

  border-radius:999px;
  border:1px solid rgba(122,230,221,.18);

  background:rgba(255,255,255,.035);
  color:var(--muted);

  font-size:13px;
  font-weight:700;
  letter-spacing:.04em;

  cursor:pointer;
  transition:.2s;
}

.confirmo-date-tab:hover{
  border-color:rgba(122,230,221,.35);
}

.confirmo-date-tab.active{
  background:rgba(122,230,221,.13);
  border-color:rgba(122,230,221,.35);
  color:var(--brand-light);
}

/* ================= LOADER ================= */

.app-loading{
  min-height:100vh;
  display:grid;
  place-items:center;
  align-content:center;
  gap:18px;
  text-align:center;

  background:
    radial-gradient(circle at 35% -10%, rgba(62,113,118,.25), transparent 35rem),
    radial-gradient(circle at 80% 100%, rgba(0,182,134,.11), transparent 28rem),
    var(--bg);
}

.app-loading img{
  width:90px;
  height:90px;
  object-fit:contain;

  animation:logoFade .8s ease;
}

.app-loading strong{
  display:block;
  font-size:34px;
  font-weight:700;
  letter-spacing:-.03em;
}

.app-loading span{
  color:var(--muted);
  font-size:15px;
}

.loader-bar{
  width:min(420px,80vw);
  height:12px;

  background:rgba(255,255,255,.08);

  border-radius:999px;
  overflow:hidden;
}

.loader-fill{
  width:55%;
  height:100%;

  border-radius:999px;

  background:linear-gradient(
    90deg,
    var(--brand),
    var(--brand-light)
  );

  animation:loading 1s infinite ease-in-out;
}

@keyframes loading{
  0%{
    transform:translateX(-120%);
  }

  100%{
    transform:translateX(320%);
  }
}

@keyframes logoFade{
  from{
    opacity:0;
    transform:scale(.9);
  }

  to{
    opacity:1;
    transform:scale(1);
  }
}  

/* ================= VER TODAS LAS FECHAS ================= */

.all-dates-btn{
  width:100%;
  min-height:54px;

  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;

  border:none;
  border-radius:18px;

  background:linear-gradient(
    135deg,
    rgba(62,113,118,.95),
    rgba(84,163,171,.95)
  );

  color:#fff;

  font-size:16px;
  font-weight:700;

  cursor:pointer;
  transition:.2s;
}

.all-dates-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(84,163,171,.25);
}

.toast{
  position:fixed;
  left:50%;
  bottom:28px;
  z-index:999;

  transform:translateX(-50%);
  padding:14px 18px;
  border-radius:999px;

  background:rgba(18,24,25,.96);
  border:1px solid rgba(154,219,214,.24);
  color:#fff;

  font-size:15px;
  font-weight:700;

  box-shadow:0 18px 50px rgba(0,0,0,.35);

  animation:toastIn .25s ease;
}

@keyframes toastIn{
  from{
    opacity:0;
    transform:translate(-50%,20px);
  }

  to{
    opacity:1;
    transform:translate(-50%,0);
  }
}

.assignment-date{
  display:block;
  margin-top:4px;

  color:var(--brand-light);

  font-size:12px;
  font-weight:600;
}

.clickable-assignment{
  cursor:pointer;
  transition:.18s;
}

.clickable-assignment:hover{
  transform:translateY(-2px);
  border-color:rgba(154,219,214,.35);
}

.assignment-confirm-actions{
  display:flex;
  gap:10px;
}

.mini-confirm,
.mini-cant{
  width:44px;
  height:44px;

  border:none;
  border-radius:14px;

  cursor:pointer;

  display:flex;
  align-items:center;
  justify-content:center;

  font-size:18px;
  font-weight:700;

  transition:.18s;
}

.mini-confirm{
  background:rgba(0,182,134,.16);
  color:#00d6a0;
}

.mini-confirm:hover{
  background:#00b686;
  color:white;
  transform:translateY(-2px);
}

.mini-cant{
  background:rgba(255,91,91,.16);
  color:#ff5b5b;
}

.mini-cant:hover{
  background:#ff5b5b;
  color:white;
  transform:translateY(-2px);
}

.summary-assignment-row{
  grid-template-columns:54px 1fr auto;
}

.summary-assignment-row .badge{
  grid-column:auto;
  justify-self:end;
}

@media (max-width:800px){
  .summary-assignment-row{
    grid-template-columns:54px 1fr auto;
  }

  .summary-assignment-row .badge{
    grid-column:auto;
    justify-self:end;
  }
}

.quick-btn{
  width:100%;
  color:#fff;
  text-align:left;
  cursor:pointer;
}

.quick-btn strong{
  color:#fff;
}

.quick-btn small{
  color:rgba(205,232,236,.85);
}

.quick-btn:hover{
  border-color:rgba(154,219,214,.35);
  transform:translateY(-2px);
}

.btn-muted,
.more-pill{
  cursor:pointer;
}

.admin-panel {
  max-width: 1180px;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 26px;
}

.admin-card {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  background: var(--card-2);
}

.admin-card-icon {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(109, 221, 230, .12);
  font-size: 24px;
}

.admin-card h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.admin-card p {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 16px;
}

@media (max-width: 800px) {
  .admin-grid {
    grid-template-columns: 1fr;
  }

  .admin-card {
    padding: 18px;
  }

  .summary-stats {
    grid-template-columns: 1fr;
  }
}

.admin-card #sendConvocationEmailsBtn {
  margin-top: 6px;
}

#convocationEmailStatus {
  display: block;
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: .9rem;
  color: var(--muted);
  line-height: 1.5;
}

.admin-card-content {
  width: 100%;
}

.admin-summary {
  margin: 14px 0 16px;
}

.summary-main {
  margin-bottom: 12px;
}

.summary-main span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.summary-main strong {
  display: block;
  margin-top: 4px;
  font-size: 20px;
  letter-spacing: -.03em;
}

.summary-main small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
}

.summary-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.summary-stats div {
  min-width: 92px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.06);
}

.summary-stats span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.summary-stats strong {
  display: block;
  margin-top: 2px;
  font-size: 22px;
}

.summary-mode {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 12px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

.summary-mode.test {
  color: var(--warn);
  background: rgba(246,176,66,.12);
}

.summary-mode.live {
  color: var(--ok);
  background: rgba(0,182,134,.12);
}

.notifications-panel {
  position: absolute;
  top: 92px;
  right: 120px;
  z-index: 90;

  width: min(360px, calc(100vw - 28px));

  border: 1px solid rgba(255,255,255,.11);
  border-radius: 24px;

  background: rgba(18,24,25,.98);
  box-shadow: 0 28px 80px rgba(0,0,0,.45);

  overflow: hidden;

  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px) scale(.98);
  transition: .18s ease;
}

.notifications-panel.active {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.notifications-header {
  display: flex;
  align-items: center;
  justify-content: space-between;

  padding: 16px 18px;

  border-bottom: 1px solid rgba(255,255,255,.08);
}

.notifications-header strong {
  font-size: 18px;
  font-weight: 700;
}

.notifications-header button {
  width: 32px;
  height: 32px;

  border: 0;
  border-radius: 50%;

  background: rgba(255,255,255,.06);
  color: var(--text);

  font-size: 22px;
  line-height: 1;
}

.notifications-list {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.notification-item {
  width: 100%;

  display: grid;
  grid-template-columns: 42px 1fr;
  align-items: flex-start;
  gap: 12px;

  padding: 12px;

  border: 1px solid rgba(255,255,255,.06);
  border-radius: 18px;

  background: rgba(255,255,255,.025);
  color: var(--text);

  text-align: left;
}

.notification-item:hover {
  background: rgba(154,210,214,.08);
  border-color: rgba(154,210,214,.22);
}

.notification-item > span {
  width: 42px;
  height: 42px;

  display: grid;
  place-items: center;

  border-radius: 14px;
  background: rgba(109,221,230,.12);

  font-size: 22px;
}

.notification-item strong {
  display: block;
  margin-bottom: 4px;

  font-size: 15px;
  font-weight: 700;
}

.notification-item small {
  display: block;

  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.notification-empty {
  padding: 18px;
  text-align: center;
}

.notification-empty strong {
  display: block;
  margin-bottom: 5px;

  font-size: 16px;
}

.notification-empty small {
  color: var(--muted);
}

@media (max-width:800px){

  .top-actions{
    flex-shrink:0;
  }

  .notifications-panel{
    top:82px;
    left:14px;
    right:14px;
    width:auto;
  }
}

/* ================= CRONOGRAMA ================= */

#view-cronograma {
  display: none;
}

#view-cronograma.active {
  display: grid;
  gap: 20px;
}

#view-cronograma .card {
  padding: 28px;
}

.schedule-list {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}

.schedule-list hr {
  width: 100%;
  height: 1px;
  margin: 10px 0;
  border: 0;
  background: rgba(255,255,255,.1);
}

.schedule-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  align-items: center;
  gap: 14px;

  padding: 14px 16px;
  border-radius: 18px;

  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.07);
}

.schedule-row span {
  color: var(--brand-light);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .04em;
}

.schedule-row strong {
  color: var(--text);
  font-size: 17px;
  font-weight: 700;
}

.announcement-list {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.announcement-card {
  display: grid;
  gap: 5px;

  padding: 16px 18px;
  border-radius: 18px;

  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.07);
}

.announcement-card strong {
  font-size: 18px;
  font-weight: 700;
}

.announcement-card small {
  color: var(--muted);
  font-size: 14px;
}

@media (max-width:800px) {
  #view-cronograma.active {
    gap: 14px;
  }

  #view-cronograma .card {
    padding: 20px;
  }

  .schedule-row {
    grid-template-columns: 64px 1fr;
    padding: 13px 14px;
  }

  .schedule-row span {
    font-size: 13px;
  }

  .schedule-row strong {
    font-size: 16px;
  }

  .announcement-card {
    padding: 15px;
}
}

/* ================= ADMIN EDITOR ================= */

.admin-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.admin-form label {
  display: grid;
  gap: 7px;
}

.admin-form label span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.admin-form input,
.admin-form select {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 0 14px;
  outline: 0;
}

.admin-form button {
  align-self: end;
}

.admin-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 30px;
  margin-bottom: 14px;
}

.admin-list-header h3 {
  margin: 0;
  font-size: 24px;
}

.admin-edit-list {
  display: grid;
  gap: 10px;
}

.admin-edit-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
}

.admin-edit-row strong {
  display: block;
  font-size: 16px;
}

.admin-edit-row small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
}

@media (max-width:800px) {
  .admin-form {
    grid-template-columns: 1fr;
  }

  .admin-list-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .admin-edit-row {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* ================= SETLIST ================= */

.setlist-grid {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.setlist-card {
  display: grid;
  grid-template-columns: 52px 1fr;
  align-items: center;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  background: rgba(255,255,255,.035);
}

.setlist-number {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  background: rgba(147, 221, 226, .16);
  color: var(--brand-light);
  font-weight: 800;
  font-size: 18px;
}

.setlist-card strong {
  display: block;
  font-size: 22px;
  line-height: 1.1;
}

.setlist-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.setlist-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

@media (max-width:800px) {
  .setlist-card {
    grid-template-columns: 44px 1fr;
    padding: 16px;
  }

  .setlist-card strong {
    font-size: 19px;
  }
}

/* =========================================================
   SETLIST
========================================================= */

.playlist-button{
    width:100%;
    margin:22px 0 28px;
    padding:18px 22px;

    border:none;
    border-radius:18px;

    background:linear-gradient(
        90deg,
        var(--brand),
        var(--brand-light)
    );

    color:#fff;
    font-size:17px;
    font-weight:700;
    letter-spacing:.4px;

    cursor:pointer;
    transition:.25s;
}

.playlist-button:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 30px rgba(0,0,0,.28);
}

.setlist-lead{
    display:flex;
    align-items:center;
    gap:6px;
    margin-top:12px;

    color:var(--text-secondary);
    font-size:14px;
    font-weight:500;
}