/* accounts/static/accounts/css/master_dashboard.css
   Coaches Office page-only styles (no generic .grid/.card collisions).
*/

/* section header */
.sx-section-h{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--muted);
  margin:18px 2px 12px;
}
.sx-section-h .title{ font-weight:950; color:var(--text); }

/* ==========================
   App bar (top toolbar)
   ========================== */

.sx-appbar{
  display:grid;
  grid-template-columns:repeat(4, minmax(200px, 1fr));
  gap:12px;
  margin:12px 0 18px;
}
@media (max-width:1200px){
  .sx-appbar{ grid-template-columns:repeat(3, minmax(180px,1fr)); }
}
@media (max-width:720px){
  .sx-appbar{ grid-template-columns:repeat(2, minmax(160px,1fr)); }
}

.sx-appcard{
  position:relative;
  border-radius:16px;
  border:1px solid var(--ring);
  background:
    radial-gradient(140% 160% at 0% 0%, rgba(58,166,255,.10), transparent 55%),
    radial-gradient(140% 160% at 100% 100%, rgba(226,75,122,.08), transparent 55%),
    var(--panel);
  box-shadow:var(--shadow);
  padding:12px;
  display:flex;
  align-items:center;
  gap:10px;
  min-height:72px;
  transition:transform .14s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
}
.sx-appcard:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(0,0,0,.55);
  border-color:color-mix(in oklab, var(--accent) 55%, var(--ring));
}

.sx-appiconbox{
  width:46px;height:46px;
  border-radius:14px;
  display:grid;place-items:center;
  border:1px solid var(--ring);
  background:#0c1016;
  flex:0 0 auto;
  font-weight:950;
}

.sx-appmeta{ min-width:0; }
.sx-appname{
  font-weight:950;
  letter-spacing:.2px;
  font-size:13px;
  margin:0;
}
.sx-apptag{
  margin:5px 0 0;
  font-size:12px;
  color:var(--muted);
}

.sx-appbadge{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--ring);
  font-size:11px;
  font-weight:950;
  color:var(--muted);
  background:rgba(255,255,255,.02);
  white-space:nowrap;
}

/* Active apps: full color */
.sx-appcard.is-on{
  border-color:color-mix(in oklab, var(--green) 30%, var(--ring));
}
.sx-appcard.is-on .sx-appiconbox{
  background:linear-gradient(135deg, rgba(58,166,255,.25), rgba(61,220,151,.18));
  border-color:color-mix(in oklab, var(--accent) 50%, var(--ring));
}
.sx-appcard.is-on .sx-appbadge{
  border-color: rgba(61,220,151,.35);
  color: rgba(61,220,151,.95);
}

/* Inactive apps: attention */
.sx-appcard.is-off{
  border-color: rgba(251,191,36,.32);
  background:
    radial-gradient(140% 160% at 0% 0%, rgba(251,191,36,.10), transparent 55%),
    radial-gradient(140% 160% at 100% 100%, rgba(226,75,122,.08), transparent 55%),
    var(--panel);
}
.sx-appcard.is-off .sx-appiconbox{
  border-color: rgba(251,191,36,.38);
  background: rgba(251,191,36,.07);
}
.sx-appcard.is-off .sx-appbadge{
  border-color: rgba(251,191,36,.30);
  color: rgba(251,191,36,.95);
}

@media (prefers-reduced-motion: no-preference){
  .sx-appcard.is-off{ animation: sxPulse 2.2s ease-in-out infinite; }
  @keyframes sxPulse{
    0%,100%{ filter:brightness(1); }
    50%{ filter:brightness(1.07); }
  }
}

/* ==========================
   Dashboard grids
   ========================== */

/* top two cards */
.sx-dashboard-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(320px, 1fr));
  gap:14px;
  margin-top:14px;
}
@media (max-width:900px){
  .sx-dashboard-grid{ grid-template-columns:1fr; }
}

/* products area */
.sx-products-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(240px, 1fr));
  gap:14px;
}
@media (max-width:1100px){
  .sx-products-grid{ grid-template-columns:repeat(2, minmax(220px, 1fr)); }
}
@media (max-width:620px){
  .sx-products-grid{ grid-template-columns:1fr; }
}

/* ==========================
   Product tiles (avoid .card collisions)
   ========================== */

.sx-tile{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--ring);
  background:
    radial-gradient(140% 160% at 0% 0%, rgba(58,166,255,.12), transparent 55%),
    radial-gradient(140% 160% at 100% 100%, rgba(226,75,122,.10), transparent 55%),
    var(--panel);
  box-shadow:var(--shadow);
  transition:transform .18s ease-out, box-shadow .18s ease-out, border-color .18s ease-out;
}
.sx-tile:hover{
  transform:translateY(-3px) scale(1.01);
  box-shadow:0 18px 40px rgba(0,0,0,.55);
  border-color:var(--accent);
}

.sx-tile-in{
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:200px;
}
.sx-tile-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.sx-tile-title{
  font-weight:950;
  letter-spacing:.2px;
  font-size:14px;
  margin:0;
}
.sx-tile-desc{
  margin:0;
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
  min-height:34px;
}

.sx-tile-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:auto;
}
.sx-tile-actions .sx-btn{ padding:9px 10px; border-radius:12px; font-size:12px; }
.sx-tile-actions .sx-btn.primary{ padding:9px 10px; }

/* Make Django forms (form.as_p) look consistent if used here */
.sx-form-as-p p{ margin:0 0 10px; }
.sx-form-as-p label{ display:block; font-size:12px; color:#b7c0d1; margin:6px 2px; }
.sx-form-as-p input, .sx-form-as-p select, .sx-form-as-p textarea{
  width:100%;
  background:#0c1117;
  color:var(--text);
  border:1px solid var(--ring);
  padding:10px 12px;
  border-radius:12px;
  outline:none;
}

/* =========================
   Sportology Apps tiles (logo + name)
   ========================= */

   .sx-app-tiles{
    display:grid;
    grid-template-columns:repeat(6, minmax(150px, 1fr));
    gap:14px;
    align-items:stretch;
    margin-top:12px;
    padding-bottom:12px;
    border-bottom:1px solid white;
  }
  
  @media (max-width:1100px){ .sx-app-tiles{ grid-template-columns:repeat(4, minmax(150px,1fr)); } }
  @media (max-width:820px){ .sx-app-tiles{ grid-template-columns:repeat(3, minmax(150px,1fr)); } }
  @media (max-width:560px){ .sx-app-tiles{ grid-template-columns:repeat(2, minmax(150px,1fr)); } }
  
  .sx-app-tile{
    position:relative;
    border-radius:18px;              /* square-ish, slightly rounded */
    border:1px solid var(--ring);
    background:rgba(255,255,255,.02);
    padding:16px 14px 14px;
    min-height:170px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:10px;
    box-shadow:0 10px 26px rgba(0,0,0,.25);
    overflow:hidden;
    transition:transform .14s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease, opacity .18s ease;
  }
  
  .sx-app-tile:hover{
    transform:translateY(-2px);
    box-shadow:var(--shadow);
    border-color:rgba(58,166,255,.45);
  }
  
  /* logo holder */
  .sx-app-logo{
    width:64px;
    height:64px;
    display:grid;
    place-items:center;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(12,16,22,.75);
    overflow:hidden;
  }
  
  .sx-app-logo img{
    width:44px;
    height:44px;
    object-fit:contain;
    display:block;
  }
  
  .sx-app-name{
    font-weight:950;
    letter-spacing:.2px;
    text-align:center;
    margin-top:2px;
    font-size:14px;
  }
  
  /* ACTIVE: full color gradient + reflection sheen */
  .sx-app-tile.is-on{
    border-color:rgba(61,220,151,.35);
    background:
      radial-gradient(120% 140% at 15% 10%, rgba(58,166,255,.18), transparent 55%),
      radial-gradient(120% 140% at 85% 20%, rgba(226,75,122,.12), transparent 60%),
      linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01)),
      rgba(21,26,34,.95);
  }
  
  .sx-app-tile.is-on::before{
    content:"";
    position:absolute;
    left:-40%;
    top:-30%;
    width:120%;
    height:60%;
    transform:rotate(-10deg);
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
    opacity:.55;
    pointer-events:none;
  }
  
  .sx-app-tile.is-on .sx-app-logo{
    border-color:rgba(58,166,255,.35);
    background:linear-gradient(135deg, rgba(58,166,255,.18), rgba(61,220,151,.12));
    box-shadow:0 10px 22px rgba(58,166,255,.10);
  }
  
  /* INACTIVE: grayed out */
  .sx-app-tile.is-off{
    border-color:rgba(255,255,255,.14);
    filter:grayscale(1) brightness(.78);
    opacity:.82;
  }
  
  .sx-app-tile.is-off::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(10,12,16,.42);
    pointer-events:none;
  }
  
  /* === OVERRIDE: make Sportology app tiles perfect squares + centered === */
.sx-app-tile{
  /* square */
  aspect-ratio: 1 / 1;   /* ensures width == height */
  width: 100%;
  min-height: 0;         /* kill the tall min-height */
  height: auto;

  /* layout */
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center; /* center vertically so no bottom dead space */
  gap:12px;

  /* keep your look */
  padding:18px 14px;
  border-radius:22px;
  text-decoration:none;
  color:inherit;
}

/* tighten logo + title so it feels clean */
.sx-app-logo{
  width:70px;
  height:70px;
  border-radius:18px;
}
.sx-app-logo img{
  width:46px;
  height:46px;
}
.sx-app-name{
  margin:0;
  line-height:1.1;
  font-size:18px;
  font-weight:950;
}

/* === Playbook tile background image test === */
.sx-tile--playbook .sx-tile-in{
  position:relative;
  overflow:hidden;
}

/* Background photo */
.sx-tile--playbook .sx-tile-in::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("{% static 'assets/Crocker.jpg' %}");
  background-size:cover;
  background-position:center;
  opacity:.22;                 /* faint photo */
  transform:scale(1.03);
  z-index:0;
}

/* Transparent dark layer to soften + improve readability */
.sx-tile--playbook .sx-tile-in::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(10,12,16,.55);   /* dark veil */
  z-index:1;
}

/* Keep content above overlays */
.sx-tile--playbook .sx-tile-in > *{
  position:relative;
  z-index:2;
}


/* --- Staff Roster form controls --- */
.sx-card input[type="text"],
.sx-card input[type="email"],
.sx-card input[type="number"],
.sx-card input[type="tel"],
.sx-card input[type="url"],
.sx-card input[type="password"],
.sx-card select,
.sx-input,
.sx-select{
  appearance: none;
  -webkit-appearance: none;

  height: 44px;
  padding: 10px 12px;
  border-radius: 12px;

  color: rgba(255,255,255,.92);
  background: rgba(10, 14, 20, .55);
  border: 1px solid rgba(255,255,255,.14);

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 0 0 1px rgba(0,0,0,.15);

  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.sx-card input::placeholder,
.sx-input::placeholder{
  color: rgba(255,255,255,.45);
}

.sx-card input:focus,
.sx-card select:focus,
.sx-input:focus,
.sx-select:focus{
  border-color: rgba(124, 214, 255, .55);
  box-shadow:
    0 0 0 4px rgba(124, 214, 255, .15),
    inset 0 1px 0 rgba(255,255,255,.06);
  background: rgba(10, 14, 20, .68);
}

/* select caret */
.sx-card select,
.sx-select{
  padding-right: 38px;
  background-image: linear-gradient(45deg, transparent 50%, rgba(255,255,255,.65) 50%),
                    linear-gradient(135deg, rgba(255,255,255,.65) 50%, transparent 50%);
  background-position: calc(100% - 18px) 18px, calc(100% - 12px) 18px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

/* sizes */
.sx-input--xs{ width: 80px; }
.sx-input--wide{ min-width: 240px; }

/* optional: keep control spacing nice inside tight rows */
.sx-row-actions form{
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

/* Keep staff row actions on one line */
.sx-row-actions{
  flex-wrap: nowrap;      /* stop wrapping */
  align-items: center;
  gap: 10px;
}

/* Make each action form a single horizontal “chip” */
.sx-row-actions form{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
}

/* Shrink controls inside row-actions only */
.sx-row-actions .sx-input,
.sx-row-actions .sx-select{
  height: 36px;
  padding: 7px 10px;
  border-radius: 10px;
  font-size: 14px;
}

/* Shrink buttons inside row-actions only */
.sx-row-actions .sx-btn{
  height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: 14px;
  white-space: nowrap;
}

/* Keep the title field from being huge */
.sx-row-actions input[name="position_title"]{
  width: 160px;      /* tweak: 140–200 */
  min-width: 140px;
}

/* Keep role select compact */
.sx-row-actions select[name="role"]{
  width: 120px;      /* tweak: 110–140 */
}

/* Invite coach: keep email + role horizontal */
.sx-card form[action*="staff_invite_send"]{
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center;
  gap: 10px;
}

.sx-card form[action*="staff_invite_send"] input[type="email"]{
  flex: 1 1 auto;
  min-width: 260px;
}

.sx-card form[action*="staff_invite_send"] select[name="role"]{
  width: 140px;
  flex: 0 0 auto;
}

.sx-card form[action*="staff_invite_send"] .sx-btn{
  flex: 0 0 auto;
  white-space: nowrap;
}
/* Subcards inside sx-card (Invite vs Active list separation) */
.sx-subcard{
  border:1px solid var(--ring);
  border-radius:16px;
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  overflow:hidden;
}

.sx-subcard-h{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(58,166,255,.10), transparent 55%),
    rgba(10, 14, 20, .35);
}

.sx-subhint{
  font-size:12px;
  color: var(--muted);
  white-space:nowrap;
}

.sx-subcard-b{
  padding:14px;
}

/* Invite row aligns nicely */
.sx-invite-row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
}

/* Staff rows (inside active staff block) */
.sx-staff-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background: rgba(10, 14, 20, .28);
}

.sx-staff-meta{
  min-width:220px;
}

/* === Playbook tile background image (faded + blended) === */
.sx-tile--playbook .sx-tile-in{
  position:relative;
  overflow:hidden;
}

/* Background photo */
.sx-tile--playbook .sx-tile-in::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--sx-tile-bg);
  background-size:cover;
  background-position:center;
  opacity:.18;                 /* <- lower = more subtle */
  transform:scale(1.03);
  z-index:0;
  filter:saturate(.85) contrast(.95);
}

/* Transparent layer to soften + blend into the dark UI */
.sx-tile--playbook .sx-tile-in::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(15,19,26,.55), rgba(15,19,26,.72));
  z-index:1;
}

/* Keep content above overlays */
.sx-tile--playbook .sx-tile-in > *{
  position:relative;
  z-index:2;
}

/* Apply background treatment to ANY tile that defines --sx-tile-bg */
.sx-tile .sx-tile-in{
  position: relative;
  overflow: hidden;
}

.sx-tile .sx-tile-in::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--sx-tile-bg);
  background-size: cover;
  background-position: center;
  opacity: .50;              /* tweak for “faded” */
  transform: scale(1.03);
  z-index: 0;
  filter: saturate(.85) contrast(.95);
}

.sx-tile .sx-tile-in::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(15,19,26,.55), rgba(15,19,26,.72));
  z-index: 1;
}

.sx-tile .sx-tile-in > *{
  position: relative;
  z-index: 2;
}
