
:root{
/* ===== Legacy theme vars (DB-driven) ===== */
--color1: #06162e;
--color2: #072d55;
--color3: #6c757d;
--color4: #ffffff;
--color5: #0e0f28;

/* ===== New glass theme vars (mapped from DB) ===== */
--brand: var(--color1);
--brand-2: var(--color1);
--bg0: var(--color2);
--ink: var(--color4);
--muted: var(--color3);
--glass: rgba(255,255,255,.06);
--glass-b: rgba(255,255,255,.18);
--glass-opaque: rgba(255,255,255,.96);
--glass-b-opaque: rgba(255,255,255,.78);
--glass-b-bullet-card: rgba(109, 184, 100, 0.78);
--glass-b-bullet-card-neg: rgba(187, 75, 75, 0.78);
--ring: rgba(6,22,46,.45);
--shadow: 0 20px 60px -20px rgba(0,0,0,.6);
--control-h: 48px;
}
/* Normalize native selects across browsers */
:root{ color-scheme: dark; } /* enables dark popups/scrollbars on supported UAs */

select, .form-select{
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

/* Force the dropdown list to dark as well (Edge/Chromium/Firefox) */
select option,
.form-select option{
background-color: #0a0f1b; /* or var(--bg0) if you prefer */
color: #fff;
}
select optgroup,
.form-select optgroup{
background-color: #0a0f1b;
color: #b7c4d6; /* slightly muted group label */
}

/* Windows High-Contrast / Forced Colors fallback */
@media (forced-colors: active){
select, .form-select{
forced-color-adjust: none;
background: Canvas;
color: CanvasText;
border-color: CanvasText;
}
select option{ background: Canvas; color: CanvasText; }
}

/* ===== Base / Background ===== */

body{
margin:0;
background:
radial-gradient(1200px 700px at 10% -10%, rgba(66,153,225,.08), transparent 60%),
radial-gradient(1000px 600px at 110% 0%, rgba(4,34,77,.18), transparent 55%),
linear-gradient(0deg, #0a0f1b 0%, var(--bg0) 60%);
color: var(--ink);
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
min-height:100vh;
min-width:100vw;
}
.wrapper { overflow: hidden; }

.theme-title{
color: var(--ink);
letter-spacing:.3px;
font-weight:800;
text-transform:uppercase;
display:inline-block;
padding-bottom:.25rem;
border-bottom: 2px solid rgba(255,255,255,.12);
}

/* ===== HERO (landing) ===== */
.hero {
position: relative;
min-height: clamp(520px, 68vh, 820px);
display: grid;
place-items: center;
text-align: center;
color: #fff;
background:
radial-gradient(80% 60% at 50% 40%, rgba(0, 0, 0, .35), rgba(0, 0, 0, .65)),
url('../assets/img/hero-bg.png') center/cover no-repeat;
isolation: isolate;
}
.hero::after {
content: "";
position: absolute; inset: 0;
background:
radial-gradient(700px 380px at 50% 30%, rgba(255, 255, 255, .08), transparent 60%),
radial-gradient(600px 360px at 10% 90%, rgba(4, 34, 77, .25), transparent 60%);
z-index: 0; pointer-events: none;
}
.hero-text {
position: relative; z-index: 1;
max-width: 900px; margin-inline: auto;
padding: clamp(32px, 6vw, 64px);
background: var(--glass);
border: 1px solid var(--glass-b);
border-radius: 20px;
box-shadow: var(--shadow);
backdrop-filter: blur(12px);
}
.hero h1 { font-size: clamp(2rem, 4.5vw, 3.5rem); font-weight: 900; letter-spacing: .2px; margin-bottom: .75rem; }
.hero h4 { color: #fff; opacity: .9; text-align: center; font-weight: 600; }

.section { padding: clamp(40px, 5vw, 72px) 20px; }
.section h2 { font-weight: 900; margin-bottom: 14px; text-align: center; }
.section h4 { color: var(--ink); opacity: .85; font-weight: 600; }

/* Side images */
.sideImg{
width: 100%;
border-radius: 16px;
background: rgba(255, 255, 255, .02);
border: 1px solid rgba(255, 255, 255, .08);
box-shadow: 0 20px 50px -24px rgba(0, 0, 0, .6);
transition: transform .35s ease, box-shadow .35s ease;
}
.sideImg:hover{ transform: translateY(-4px); box-shadow: 0 26px 70px -30px rgba(0,0,0,.7); }

/* ===== Modern "glass" surfaces ===== */
.easy-card{
border: 1px solid var(--glass-b);
background: linear-gradient(180deg, rgba(10,15,27,.75), rgba(10,15,27,.35)), var(--glass);
border-radius: 16px;
box-shadow: var(--shadow);
margin-bottom:0;
}
.no-margin {
margin:0 !important;
}

.no-focus:focus {
text-decoration:none !important;
outline:none;
box-shadow:none !important;
color:var(--color4) !important;
}
.card-opaque{
background-color: linear-gradient(180deg, rgba(10,15,27,.75), rgba(10,15,27,.35)), var(--glass-opaque) !important;
}
.hover-card{ transition: transform .18s ease, box-shadow .22s ease, border-color .18s ease, background .18s ease; }
.hover-card:hover{
transform: translateY(-4px);
box-shadow: 0 26px 70px -30px rgba(0,0,0,.7);
border-color: rgba(255,255,255,.26);
background: linear-gradient(180deg, rgba(10,15,27,.82), rgba(10,15,27,.4)), var(--glass);
}

/* ===== Inputs/selects/buttons: 4px radius (site-wide) ===== */
.form-control, .form-select{
border-radius: 4px !important;
border: 1px solid rgba(255,255,255,.25);
background: rgba(255,255,255,.08);
color:#fff;
height: var(--control-h);
line-height: 1.2;
padding: 0 1rem;
transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.form-control::placeholder{ color: rgba(255,255,255,.7); }
.form-control:focus, .form-select:focus{
border-color: var(--glass-b);
box-shadow: 0 0 0 4px var(--ring);
background: rgba(255,255,255,.12);
}
textarea.form-control{ height:auto; min-height: 120px; }

.btn, .btn-easyidp, .btn-easyidp-contrast, .btn-easyidp-danger, .btn-outline-danger, .btn-secondary{ border-radius: 4px !important; }

/* ===== Primary buttons ===== */
.btn-easyidp{border: 1px solid var(--glass-b); padding:.65rem 1rem;
font-weight:800; letter-spacing:.3px;
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff;
box-shadow: 0 10px 24px -8px rgba(4,34,77,.75);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
white-space: nowrap;
}
.btn-easyidp:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }

.btn-easyidp-contrast{
padding:.65rem 1rem; font-weight:800; letter-spacing:.3px; color:#fff;
background: rgba(255,255,255,.08); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.btn-easyidp-contrast:hover{ transform: translateY(-1px); background: rgba(255,255,255,.12); }

.btn-easyidp-danger{
padding:.65rem 1rem; font-weight:800; letter-spacing:.3px; color:#fff;
background: rgba(228, 12, 12, 0.75); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.btn-easyidp-danger:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }

.btn-easyidp-secondary{
padding:.65rem 1rem; font-weight:800; letter-spacing:.3px; color:#fff;
background: rgba(128, 128, 128, 0.75); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.btn-easyidp-secondary:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }

/* Input group icon chip */
.input-group-text{
border: 1px solid rgba(255,255,255,.25);
background: rgba(255,255,255,.08);
color:#fff;
height: var(--control-h);
display:flex; align-items:center;
padding: 0 14px;
border-radius: 4px 0 0 4px;
}
.input-group > .form-control{
border-top-left-radius: 0 !important;
border-bottom-left-radius: 0 !important;
}

/* Cards imagery: crop on tiles, contain on banners */
.card.hover-card{
border: 1px solid var(--glass-b);
background: linear-gradient(180deg, rgba(10,15,27,.75), rgba(10,15,27,.35)), var(--glass);
border-radius: 16px;
box-shadow: var(--shadow);
cursor:pointer;
overflow: hidden;
}
.hover-card .card-img-top{
height: 220px; object-fit: cover; width: 100%;
border-top-left-radius: 16px; border-top-right-radius: 16px;
border-bottom-left-radius: 16px; border-bottom-right-radius: 16px;
filter: saturate(.96) contrast(1.03);
}
/* full logo in glass banners */
.easy-card .card-img-top{
height: auto; width:100%; object-fit: contain; display:block;
border-radius: 16px;
background: rgba(255,255,255,.04);
}

/* ===== Logo loop ===== */
.logo-loop{
--gap: clamp(24px, 4vw, 56px);
--duration: 28s;
position: relative;
border-radius: 18px;
background: var(--glass);
border: 1px solid var(--glass-b);
box-shadow: var(--shadow);
padding: 18px 8px; margin: 12px auto 0;
max-width: 1060px; overflow: hidden;
}
.logo-loop::before, .logo-loop::after{
content:""; position:absolute; top:0; bottom:0; width:10%; pointer-events:none;
background: linear-gradient(to right, var(--bg0), rgba(5, 8, 15, 0)); z-index:2;
}
.logo-loop::after{ right:0; left:auto; transform: scaleX(-1); }
.logo-loop::before{ left:0; }
.logo-mask{ overflow: hidden; position: relative; z-index:1; }
.logo-track{
display:flex; gap: var(--gap); width: max-content;
will-change: transform; animation: logo-scroll var(--duration) linear infinite;
}
.logo-loop:hover .logo-track{ animation-play-state: paused; }
@media (prefers-reduced-motion: reduce){ .logo-track{ animation: none; } }
.logo-list{ display:flex; gap: var(--gap); align-items:center; margin:0; padding:0; list-style:none; }
.logo-item{ display:flex; align-items:center; justify-content:center; min-width: clamp(120px, 16vw, 240px); padding: 8px 12px; transition: transform .2s ease; transform: translateZ(0); }
.logo-item img{ max-height: 80px; width:auto; object-fit:contain; filter: drop-shadow(0 6px 16px rgba(0,0,0,.35)); opacity:.82; transition: transform .2s ease, filter .2s ease, opacity .2s ease; }
.logo-item:hover, .logo-item:focus-within{ transform: translateY(-2px); }
.logo-item:hover img, .logo-item:focus-within img{ opacity:1; transform: scale(1.06); cursor:pointer; }
@keyframes logo-scroll { from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
@media (max-width: 576px){
.logo-item{ min-width: clamp(100px, 40vw, 200px); }
.logo-item img{ max-height: 64px; }
}

/* Subscribe form (landing) */
.subscribe-form{ max-width: 720px; margin: 1rem auto 0; }
.input-row{ display:grid; grid-template-columns: 1fr 1fr auto; gap:.75rem; }
@media (max-width: 768px){ .input-row{ grid-template-columns: 1fr; } }
.form-control{
border-radius: 6px !important;
padding: .85rem 1rem;
border: 1px solid rgba(255, 255, 255, .25);
background: rgba(255, 255, 255, .08);
color:#fff;
outline:none;
transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.form-control::placeholder{ color: rgba(255,255,255,.7); }
.form-control:focus{ border-color: var(--glass-b); box-shadow: 0 0 0 4px var(--ring); background: rgba(255,255,255,.12); }

/* Social links */
.social-links{ text-align:center; margin: 20px 0 10px; }
.social-links a{
display:inline-flex; align-items:center; justify-content:center;
width:56px; height:56px; margin:0 8px; text-decoration:none; color:#fff;
border-radius:14px; background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
box-shadow: 0 10px 24px -12px rgba(0,0,0,.6);
transition: transform .15s ease, background .2s ease, border .2s ease;
}
.social-links a:hover{ transform: translateY(-2px); background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.22); }

/* Side panel glass */
.side-panel .card{
border: 1px solid var(--glass-b);
background: linear-gradient(180deg, rgba(10,15,27,.65), rgba(10,15,27,.28)), var(--glass);
border-radius: 16px;
box-shadow: var(--shadow);
}

/* Equal-height helpers */
.row.align-items-stretch > [class*="col-"]{ display:flex; }
.equal-card{ width:100%; height:100%; display:flex; flex-direction:column; }
.equal-card .card-body{ flex: 1 1 auto; }

/* No results helper */
.no-results{ text-align:center; color: var(--muted); padding: 18px 8px; }

/* Focus ring accessibility */
:focus-visible{ outline: 3px solid var(--ring); outline-offset: 2px; border-radius: 8px; }

/* Spacing */
.container-fluid.py-4{ padding-top: 28px !important; }

/* ===== Glassy Navbar (incorporated snippet) ===== */
.nav-glass{
position: sticky; top:0; z-index:1040;
background:
linear-gradient(180deg, rgba(10,15,27,.75), rgba(10,15,27,.35)),
var(--glass);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-bottom: 1px solid var(--glass-b);
box-shadow: 0 6px 24px -12px rgba(0,0,0,.55);
}
.nav-glass .navbar-brand{
font-weight: 900; letter-spacing:.3px; color:#fff !important;
}
.nav-glass .navbar-brand img{
height:48px; filter: drop-shadow(0 6px 16px rgba(0,0,0,.35));
}
.nav-glass .navbar-toggler{
border: 1px solid rgba(255,255,255,.18);
border-radius: 12px;
padding: .4rem .6rem;
color: #fff;
background: rgba(255,255,255,.06);
transition: background .2s ease, border .2s ease, transform .12s ease;
}
.nav-glass .navbar-toggler .navbar-toggler-icon{
display:flex;
align-items:center;
justiy-content-center;
width:100%;
}
.nav-glass .navbar-toggler:hover{
background: rgba(255,255,255,.1);
border-color: rgba(255,255,255,.28);
transform: translateY(-1px);
}
.nav-glass .navbar-toggler:focus{ outline: none; box-shadow: 0 0 0 4px var(--ring); }
.nav-glass .navbar-nav .nav-link{
color: var(--ink) !important; opacity:.9;
font-weight: 600; letter-spacing: .15px;
position: relative; transition: color .15s ease, opacity .15s ease;
}
.nav-glass .navbar-nav .nav-link:hover{ color:#fff !important; opacity:1; }
.nav-glass .navbar-nav .nav-link::after{
content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
background: linear-gradient(90deg, transparent, var(--brand), transparent);
transform: scaleX(0); transform-origin: center;
transition: transform .2s ease;
}
.nav-glass .navbar-nav .nav-link:hover::after,
.nav-glass .navbar-nav .nav-link.active::after{ transform: scaleX(1); }
.nav-glass .navbar-collapse.show .navbar-nav .nav-link:hover::after{ transform: scaleX(1)}
.nav-glass .navbar-collapse.show .navbar-nav .nav-link.active::after{ transform: scaleX(1)}
.nav-glass .navbar-collapse.show .navbar-nav .nav-link{
text-align:center
}

/* Bootstrap 5 and 4 compatibility */
.navbar-nav.me-auto .nav-item{ margin-right:.25rem; }
.navbar-nav.mr-auto .nav-item{ margin-right:.25rem; }

/* Dropdown (glass) */
.dropdown-menu.sub-nav{
position:absolute;
width:100%;
background: linear-gradient(180deg, rgba(10,15,27,.78), rgba(10,15,27,.42)), var(--glass);
border: 1px solid var(--glass-b);
border-radius: 12px;
box-shadow: var(--shadow);
padding:.35rem; min-width: 220px;
}
.dropdown-menu.sub-nav .dropdown-item{
color: var(--ink); border-radius:8px; font-weight:600;
}
.dropdown-menu.sub-nav .dropdown-item:hover{
background: rgba(255,255,255,.08); color:#fff;
}

/* Right side (welcome + icon) */
.fa-theme{
color: var(--ink) !important;
opacity:.9;
transition: transform .12s ease, opacity .15s ease;
}
.fa-theme:hover{ opacity:1; transform: translateY(-1px); }

/* Right side auth area buttons in nav */
.nav-auth .btn-easyidp{
border-radius: 4px; padding:.55rem 1rem; font-weight:800;
background: linear-gradient(180deg, var(--brand), #031938);
box-shadow: 0 10px 24px -8px rgba(4, 34, 77, .55);
color: #fff !important;
}

/* --- Themed account-expiry banner (incorporated snippet) --- */
.easy-banner{
background: linear-gradient(180deg, rgba(10,15,27,.78), rgba(10,15,27,.42)), var(--glass) !important;
border: 1px solid var(--glass-b) !important;
color: var(--ink) !important;
border-radius: 12px;
box-shadow: var(--shadow);
}
.easy-banner.alert-warning{ border-left: 4px solid #f0ad4e !important; }
.easy-banner.alert-danger{ border-left: 4px solid #dc3545 !important; }
.easy-banner a{ color:#9ec3ff; text-decoration:none; }
.easy-banner a:hover{ text-decoration: underline; }
.easy-banner .close{ color: var(--ink); opacity:.85; }
.easy-banner .close:hover{ opacity:1; }

/* ===== Cookie banner (legacy themed) ===== */
.ckie-banner{
position:fixed; bottom:0; left:0; right:0;
background: var(--color1); color: var(--color4) !important;
padding:1rem; z-index:10000; display:flex; justify-content:center; align-items:center;
opacity:1; visibility:visible; transition: opacity .4s ease, visibility .4s ease;
}
.ckie-banner.hidden{ opacity:0; visibility:hidden; }
.ckie-banner__content{ max-width:960px; width:100%; display:flex; justify-content:space-between; align-items:center; }
.ckie-banner p, .ckie-banner h4{ margin:0; color: var(--color4) !important; }
.ckie-banner__content a{ color:#4ea1ff; text-decoration: underline; }
.ckie-banner__btn{
transition:.1s; background: var(--color4); border:none; color: var(--color1);
padding:.5rem 1rem; font-size:.9rem; cursor:pointer; border-radius:4px; border:1px solid var(--color1);
}
.ckie-banner__btn:hover{ background: var(--color1); color: var(--color4); border:1px solid var(--color4); }

/* ===== Legacy rules preserved (mapped) ===== */
.bg-main { background-color: var(--color2); }
h1 { color: var(--color4); }
p, label, h4, .preset-container { color: var(--color4); }
.widgets .title, .title{ margin:30px 0; margin-left:30px; }
.preset-container.selected {color: var(--color3)}
/* Footer (legacy) */
footer{
bottom:0; position:static; width:100%;
margin-top:30px; padding-top:30px; border-top:#000 1px solid; text-align:center;
background-color: var(--color1);
}
.footer-nav a{ color: var(--color2); text-decoration:none; }
.footer-nav{ text-transform:uppercase; padding:15px 0; text-align:center; }
.footer-copyright{ margin:0 60px; padding:15px 0; border-top: var(--color2) 1px solid; color: var(--color2); }
.footer-contact{ text-align:center; font-size:.9rem; color: var(--muted); padding-bottom:40px; }

/* Navbar/links focus colors (legacy) */
.nav-link.show, .nav-link:focus{ color: var(--color4) !important; filter: saturate(.96) contrast(1.03); }
.navbar-toggler:focus{ box-shadow:none; }
nav i{ color: var(--color4) !important; }

/* Containers/cards (legacy aesthetic blended with glass) */
.container{ margin-top: 40px; margin-bottom: 40px; }
.card, .modal-content{
border: none;
border-radius: 16px;
box-shadow: var(--shadow);
}
.card-header{
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff;
border-top-left-radius: 16px;
border-top-right-radius: 16px;
}
.filter-card .card-header{
background: none;
color:#fff;
border-top-left-radius: 16px;
border-top-right-radius: 16px;
border:none;
}
.modal-header{
background-color: var(--color2);
color: #fff;
border-top-left-radius: 8px;
border-top-right-radius: 8px;
}

/* Player card hover (legacy) */
.player-card{ transition: transform 0.2s; }
.player-card:hover{ transform: scale(1.02); }
.player-card .card-body{ padding: 1rem; }
.player-card a{ color: var(--color1); text-decoration: none; }
.player-card a:hover{ text-decoration: underline; }

/* Header text inside card headers */
.card-header button, .card-header h2, .card-header h4{ color: var(--color4) !important; }
/* .fa-theme adjusted above */

/* Misc utility bars */
.actions-bar, .action-bar, .page-actions{ gap:.5rem; flex-wrap:wrap; }
@media (max-width: 992px){ .action-bar{ margin-top:.75rem; } }

/* ================================================================== */
/* ========== AUTH / LOGIN PAGE (scoped so it doesn’t affect app) === */
/* ================================================================== */

/* Optional blurred bg image behind auth pages */
.bg-image{
background: url('../assets/img/blurred_football_match.png') no-repeat center center / cover;
position: fixed; inset: 0; z-index: -1;
filter: blur(5px); opacity:.35;
}

/* Centered container for login page */
.login-container, .signin-container{
min-height: 100vh;
display:flex; align-items:center; justify-content:center;
padding: 24px 16px;
}

/* “Glass” auth card */
.auth-card{
width:100%; max-width: 460px;
background: linear-gradient(180deg, rgba(10,15,27,.75), rgba(10,15,27,.35)), var(--glass);
border: 1px solid var(--glass-b);
border-radius: 20px; box-shadow: var(--shadow);
backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
padding: 28px 24px;
}
.auth-card .helper{ color: var(--muted); }

/* Brand circle/logo */
.brand-circle{
width:160px; height:160px; border-radius:50%;
overflow:hidden; margin: 6px auto 18px auto;
border:1px solid rgba(255,255,255,.12);
background: var(--color1);
box-shadow: 0 20px 50px -24px rgba(0,0,0,.6);
}
.brand-circle img{ width:100%; height:100%; object-fit: contain; }

/* Page title inside auth card */
.auth-card h4.page-title{ text-align:center; margin-bottom:8px; font-weight:800; }

/* Segmented toggle (Coach / Player) */
.auth-card .mode-toggle{ display:flex; justify-content:center; margin-bottom:14px; }
.auth-card .toggle-pill{
display:inline-flex; padding:4px; border-radius:4px;
background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
}
.auth-card .toggle-pill a{
display:inline-block; min-width:110px; text-align:center; padding:.45rem .9rem;
font-weight:800; letter-spacing:.2px; color: var(--ink); text-decoration:none; border-radius:4px;
transition: background .15s ease, color .15s ease, transform .12s ease;
}
.auth-card .toggle-pill a.active{
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff; box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
}
.auth-card .toggle-pill a:not(.active):hover{ transform: translateY(-1px); }

/* Pill inputs in auth card */
.auth-card .form-group label{ color: var(--muted); margin-bottom:.25rem; }
.auth-card .form-control{
border-radius: 4px !important;
padding: .85rem 1.1rem;
border: 1px solid rgba(255,255,255,.25);
background: rgba(255,255,255,.08);
color:#fff;
transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.auth-card .form-control::placeholder{ color: rgba(255,255,255,.7); }
.auth-card .form-control:focus{
border-color: var(--glass-b);
box-shadow: 0 0 0 4px var(--ring);
background: rgba(255,255,255,.12);
}

/* Password field with eye icon */
.auth-card .input-with-icon{ position:relative; }
.auth-card .input-with-icon .toggle-eye{
position:absolute; right:14px; top:50%; transform: translateY(-50%);
color: rgba(255,255,255,.8); cursor:pointer; padding:6px; border-radius:8px;
transition: background .15s ease, transform .12s ease;
}
.auth-card .input-with-icon .toggle-eye:hover{ background: rgba(255,255,255,.08); transform: translateY(-50%) scale(1.05); }

/* CTA inside auth card (full width) */
.auth-card .btn-easyidp{
width:100%; border:0; border-radius:4px;
padding: .9rem 1.25rem;
font-weight:800; letter-spacing:.3px;
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff; box-shadow: 0 10px 24px -8px rgba(4,34,77,.75);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
}
.auth-card .btn-easyidp:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }
.auth-card .btn-easyidp:disabled{ opacity:.7; cursor:not-allowed; }

.auth-card .help-link a{ color:#9ec3ff; text-decoration:none; }
.auth-card .help-link a:hover{ text-decoration: underline; }
#error-message{ margin-top:.75rem; }

/* Accessibility */
@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }

/* ================================================================== */
/* ================== DASHBOARD WIDGETS — FIXED LAYOUT ============== */
/* ================================================================== */

/* Make each column a flex container so cards can equalize height */
.widgets .row > [class*="col"],
.widgets .row > .col {
display: flex;
}

/* The widget itself fills the column */
.widget {
display: flex;
width: 100%;
cursor: pointer;
margin-bottom:30px;
}

/* If the widget is an anchor or a button wrapping the card */
.widget > a,
.widget > button {
display: block;
width: 100%;
text-decoration: none;
background: transparent;
border: 0;
padding: 0;
}

/* Handle both cases: wrapper has .widget OR the card itself has .widget */
.widget .card,
.widget.card {
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
}

/* Consistent image sizing inside widget tiles */
.widget .card-img-top,
.widget.card .card-img-top {
width: 100%;
height: 200px; /* adjust 180–220px to taste */
object-fit: cover;
}

/* Let the body flex-fill the remaining space for equal heights */
.widget .card-body,
.widget.card .card-body, .widget.card .kv .k .card-body span {
flex: 1 1 auto;
display: flex;
flex-direction: column;
justify-content: start;
color:#fff;
}

/* Nice hover & glass look */
.widget .card,
.widget.card {
border: 1px solid var(--glass-b);
background: linear-gradient(180deg, rgba(10, 15, 27, .75), rgba(10, 15, 27, .35)), var(--glass);
border-radius: 16px;
box-shadow: var(--shadow);
transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease, background .2s ease;
overflow: hidden;
}
.widget .card:hover,
.widget.card:hover {
transform: translateY(-4px);
box-shadow: 0 26px 70px -30px rgba(0,0,0,.7);
border-color: rgba(255,255,255,.26);
background: linear-gradient(180deg, rgba(10, 15, 27, .82), rgba(10, 15, 27, .4)), var(--glass);
}
.widget .card.no-hover:hover,
.card.no-hover:hover,
.widget.card.no-hover:hover {
cursor:default;
transform: translateY(0);
box-shadow: 0 26px 70px -30px rgba(0,0,0,.7);
border-color: rgba(255,255,255,.26);
background: linear-gradient(180deg, rgba(10, 15, 27, .82), rgba(10, 15, 27, .4)), var(--glass);
}

/* Titles & text inside widget cards */
.widget .card-title,
.widget.card .card-title {
font-weight: 800;
letter-spacing: .2px;
margin-bottom: .25rem;
color: #fff !important;
}
.card-title{
color: #fff !important;
}
.widget .card-text,
.widget.card .card-text {
color: var(--muted);
margin: 0;
}

/* Responsive: each tile still fills its column on mobile */
@media (max-width: 767px) {
.widget .card,
.widget.card { width: 100% !important; }
}
/* ================================================================== */
/* ===================== PLAYER PAGE (view.player) =================== */
/* ================================================================== */

/* Accordéon en mode glass */
.accordion .card.card--glass {
background: linear-gradient(180deg, rgba(10,15,27,.65), rgba(10,15,27,.30)), var(--glass);
border: 1px solid var(--glass-b);
border-radius: 16px;
box-shadow: var(--shadow);
overflow: hidden;
}
.accordion .card-header {
background: linear-gradient(180deg, var(--brand), #031938);
color: #fff;
border: 0;
padding: .75rem 1rem;
}
.accordion .btn-link.accordion-toggle {
color: #fff;
text-decoration: none;
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
font-weight: 800;
letter-spacing: .2px;
}
.accordion .btn-link.accordion-toggle:hover { text-decoration: none; filter: brightness(1.05); }
.accordion .chev { transition: transform .2s ease; }
.accordion .btn[aria-expanded="true"] .chev { transform: rotate(180deg); }

/* Photos (player / team) avec cadre glass */
.photo-frame {
display: inline-flex;
align-items: center;
justify-content: center;
width: 100%;
max-width: 260px;
aspect-ratio: 1 / 1;
background: rgba(255,255,255,.04);
border: 1px solid var(--glass-b);
border-radius: 16px;
box-shadow: var(--shadow);
overflow: hidden;
}
.photo-frame img,
.player-photo,
.team-photo {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.photo-frame.empty { color: var(--muted); font-size: .9rem; }

/* Détails en grid (lecture + alignement) */
.info-grid p { margin-bottom: .4rem; }
.info-grid .monospace { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

/* Cartes internes (goals / questions) */
.goal-card .card,
.question-card .card {
border: 1px solid var(--glass-b);
background: linear-gradient(180deg, rgba(10,15,27,.65), rgba(10,15,27,.30)), var(--glass);
border-radius: 16px;
box-shadow: var(--shadow);
color:var(--color4);
}
.goal-card .card-header,
.question-card .card-header {
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff;
border:0;
}

/* List-group en mode dark glass */
.list-group-item {
background: rgba(255,255,255,.05);
color: var(--ink);
border-color: rgba(255,255,255,.12);
}

/* Pied de carte cohérent */
.card-footer {
background: rgba(255,255,255,.05);
border-top: 1px solid var(--glass-b);
}

/* Boutons de la page */
.page-actions .btn-easyidp { margin-right: .5rem; }
.btn.btn-easyidp-danger { border-radius: 4px !important; }

/* Drag‐and‐drop zone styling */
#dropZone {
border: 2px dashed var(--color4);
border-radius: 4px;
padding: 2rem;
text-align: center;
color: var(--color4);
transition: background 0.2s, border-color 0.2s;
margin-bottom: 1rem;
}

#dropZone.dragover {
background: rgba(0, 123, 255, 0.1);
border-color: #007bff;
color: #007bff;
}

textarea#jsonInput {
font-family: monospace;
resize: vertical;
}
.simplebar-content {
color: var(--color4);}
.coloris{
color: var(--color3);
}/* ==== Disabled / Read-only controls (glass theme) ==== */

/* Inputs & selects */
input:disabled,
textarea:disabled,
select:disabled,
.form-control:disabled,
.form-select:disabled,
.coloris:disabled,
input[readonly],
textarea[readonly],
.form-control[readonly] {
background: rgba(255,255,255,.12) !important;
border-color: rgba(255,255,255,.18) !important;
color: var(--muted) !important;
-webkit-text-fill-color: var(--muted) !important; /* Safari */
}

/* Cursors: blocked for disabled, default for readonly */
input:disabled,
textarea:disabled,
select:disabled,
.form-control:disabled,
.form-select:disabled,
.coloris:disabled {
cursor: not-allowed !important;
pointer-events: none; /* prevent color picker / popups */
}
input[readonly],
textarea[readonly],
.form-control[readonly] {
cursor: default !important;
}

/* Placeholders while disabled / readonly */
input:disabled::placeholder,
textarea:disabled::placeholder,
.form-control:disabled::placeholder,
input[readonly]::placeholder,
textarea[readonly]::placeholder,
.form-control[readonly]::placeholder {
color: rgba(255,255,255,.45) !important;
}

/* Kill focus/hover effects when disabled/readonly */
input:disabled:focus,
textarea:disabled:focus,
select:disabled:focus,
.form-control:disabled:focus,
.form-select:disabled:focus,
.coloris:disabled:focus,
input[readonly]:focus,
textarea[readonly]:focus,
.form-control[readonly]:focus {
box-shadow: none !important;
outline: none !important;
background: rgba(255,255,255,.12) !important;
border-color: rgba(255,255,255,.18) !important;
color: #fff;
}

/* Keep input-group icon subdued when the control is disabled */
.input-group-text:has(+ .form-control:disabled),
.input-group-text:has(+ .form-control[readonly]),
.input-group-text:has(+ .form-select:disabled) {
opacity: .6;
}

/* Buttons (general) */
.btn:disabled,
.btn-easyidp:disabled,
.btn-easyidp-contrast:disabled,
.btn-outline-danger:disabled,
.btn-secondary:disabled {
opacity: .65 !important;
filter: saturate(.7) !important;
cursor: not-allowed !important;
box-shadow: none !important;
}
.disabled-card-subclass{
  cursor: not-allowed !important;
  background: linear-gradient(180deg, rgba(125, 129, 138, 0.75), rgba(96, 99, 108, 0.35)), var(--glass) !important;
}

/* ===== Primary buttons ===== */
.tag-easyidp{border: 1px solid var(--glass-b); padding:.25rem .5rem;
  margin-bottom:5px;
  font-size:12px;
border-radius:5px;
font-weight:200; letter-spacing:.3px;
background: linear-gradient(180deg, var(--brand), #031938);
color:#fff;
box-shadow: 0 10px 24px -8px rgba(4,34,77,.75);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
white-space: nowrap;
}
.tag-easyidp:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }

.tag-easyidp-contrast{
border: 1px solid var(--glass-b); padding:.25rem .5rem;
margin-bottom:5px;
font-size:12px;
border-radius:5px;
padding:.25rem .5rem; font-weight:200; letter-spacing:.3px; color:#fff;
background: rgba(255,255,255,.08); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.tag-easyidp-contrast:hover{ transform: translateY(-1px); background: rgba(255,255,255,.12); }

.tag-easyidp-danger{
padding:.25rem .5rem; font-weight:200; letter-spacing:.3px; color:#fff;
background: rgba(228, 12, 12, 0.75); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.tag-easyidp-danger:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }

.tag-easyidp-secondary{
padding:.25rem .5rem; font-weight:200; letter-spacing:.3px; color:#fff;
background: rgba(128, 128, 128, 0.75); border: 1px solid var(--glass-b);
box-shadow: 0 10px 24px -8px rgba(4,34,77,.55);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.tag-easyidp-secondary:hover{ transform: translateY(-1px); filter: brightness(1.05); text-decoration:none }
.pwd-toggle .input-with-icon .toggle-eye{
position:absolute; right:20px; transform: translateY(-135%)  translateX(-10%);
color: rgba(255,255,255,.8); cursor:pointer; padding:6px; border-radius:8px;
transition: background .15s ease, transform .12s ease;
}
.pwd-toggle .input-with-icon .toggle-eye:hover{ background: rgba(255,255,255,.08); transform: translateY(-135%)  translateX(-10%); }

