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

/* ===== Requested EasyIDP palette ===== */
--easyidp-navy: #0b1648;
--easyidp-blue: #2c5f8e;
--easyidp-cyan: #61c7d3;
--easyidp-teal: #22b39d;
--easyidp-lime: #9af557;
--easyidp-white: #f6fbff;
--easyidp-danger: #ff9f9f;

/* ===== New glass theme vars (mapped from DB) ===== */
--brand: var(--easyidp-teal);
--brand-2: var(--easyidp-lime);
--bg0: var(--easyidp-blue);
--ink: var(--easyidp-white);
--muted: rgba(246, 251, 255, .72);
--glass: rgba(7,19,61,.8);
--glass-b: rgba(255,255,255,.16);
--glass-opaque: rgba(246,251,255,.96);
--glass-b-opaque: rgba(246,251,255,.78);
--glass-b-bullet-card: rgba(154, 245, 87, 0.78);
--glass-b-bullet-card-neg: rgba(255, 159, 159, 0.78);
--ring: rgba(97,199,211,.28);
--shadow: 0 24px 80px rgba(4,10,31,.38);
--shadower: 0 20px 60px -20px rgba(0,0,0,1);
--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(circle at 50% 30%, rgba(255,255,255,.05), transparent 32%),
url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 1024' preserveAspectRatio='none'%3E%3Crect width='1440' height='1024' fill='%232c5f8e'/%3E%3Cpath d='M0 232C203 201 423 151 638 99C933 28 1190 -13 1440 0V682C1166 786 883 826 627 782C365 738 161 652 0 564V232Z' fill='%230b1648'/%3E%3Cpath d='M0 652C213 720 417 770 642 812C931 865 1178 929 1440 918V1024H0V652Z' fill='%2322b39d'/%3E%3Cpath d='M0 822C256 855 518 901 776 952C1006 998 1221 1024 1440 1015V1024H0V822Z' fill='%239af557'/%3E%3C/svg%3E");
background-color: var(--bg0);
background-position: center;
background-repeat: no-repeat;
background-size: cover;
background-attachment: fixed;
color: var(--ink);
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
min-height:100vh;
min-width:100vw;
font-family: "Trebuchet MS", "Segoe UI", sans-serif;
overflow-x:hidden;
}
.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;
padding-inline: clamp(16px, 4vw, 40px);
}
.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;
width: min(100%, 1120px); margin-inline: auto;
padding: clamp(32px, 5vw, 60px);
background:
radial-gradient(circle at top right, rgba(73, 134, 207, 0.12), transparent 36%),
linear-gradient(180deg, rgba(14, 28, 84, 0.94), rgba(9, 19, 58, 0.9));
border: 1px solid rgba(160, 190, 235, 0.14);
border-radius: 30px;
box-shadow: 0 24px 60px rgba(4, 10, 31, 0.22);
backdrop-filter: blur(12px);
}
.hero-text::before{
content:"";
position:absolute;
inset:0;
pointer-events:none;
background: linear-gradient(180deg, rgba(255, 255, 255, .05), transparent 22%);
border-radius: inherit;
}
.hero h1 { font-size: clamp(2.3rem, 4.8vw, 4.2rem); font-weight: 900; letter-spacing: -.02em; margin-bottom: .9rem; }
.hero h4 { color: rgba(246, 251, 255, .84); opacity: 1; text-align: center; font-weight: 600; max-width: 70ch; margin-inline: auto; line-height: 1.65; }

.section { padding: clamp(44px, 5vw, 80px) clamp(16px, 4vw, 32px); }
.section h2 { font-weight: 900; margin-bottom: 14px; text-align: center; }
.section h4 { color: rgba(246, 251, 255, .84); opacity: 1; font-weight: 600; line-height: 1.65; }

/* 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: rgba(7, 19, 61, .8);
border-radius: 24px;
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(154,245,87,.28);
background: rgba(154,245,87,.05);
}

/* ===== Inputs/selects/buttons ===== */
.form-control, .form-select{
border-radius: 14px !important;
border: 1px solid rgba(97,199,211,.24);
background: rgba(246,251,255,.96);
color: var(--easyidp-navy);
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(11,22,72,.48); }
.form-control:focus, .form-select:focus{
border-color: var(--easyidp-cyan);
box-shadow: 0 0 0 .2rem rgba(97,199,211,.2);
background: rgba(246,251,255,1);
}
textarea.form-control{ height:auto; min-height: 120px; }

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

/* ===== Primary buttons ===== */
.btn-easyidp{border: 0; padding:.65rem 1rem;
font-weight:800; letter-spacing:.3px;
background: linear-gradient(135deg, var(--easyidp-teal) 0%, var(--easyidp-lime) 100%);
color: var(--easyidp-navy);
box-shadow: 0 14px 32px rgba(34,179,157,.3);
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: var(--easyidp-white);
background: rgba(246,251,255,.08); border: 1px solid rgba(255,255,255,.14);
box-shadow: 0 10px 24px -8px rgba(4,10,31,.32);
transition: transform .12s ease, box-shadow .2s ease, filter .2s ease, background .2s ease;
}
.btn-easyidp-contrast:hover{ transform: translateY(-1px); background: rgba(246,251,255,.12); color: var(--easyidp-white); }

.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(97,199,211,.24);
background: rgba(97,199,211,.15);
color: var(--easyidp-white);
height: var(--control-h);
display:flex; align-items:center;
padding: 0 14px;
border-radius: 14px 0 0 14px;
}
.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,
.form-select{
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-select{
padding-right: 2.75rem;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='rgba(255,255,255,0.84)' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.8' d='M3.5 6l4.5 4 4.5-4'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 1rem center;
background-size: 16px 12px;
}
.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); }

/* 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{
background-color: var(--color3);
border: none;
border-radius: 16px;
box-shadow: var(--shadower);
}
.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:
radial-gradient(circle at 50% 30%, rgba(255,255,255,.05), transparent 32%),
url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 1024' preserveAspectRatio='none'%3E%3Crect width='1440' height='1024' fill='%232c5f8e'/%3E%3Cpath d='M0 232C203 201 423 151 638 99C933 28 1190 -13 1440 0V682C1166 786 883 826 627 782C365 738 161 652 0 564V232Z' fill='%230b1648'/%3E%3Cpath d='M0 652C213 720 417 770 642 812C931 865 1178 929 1440 918V1024H0V652Z' fill='%2322b39d'/%3E%3Cpath d='M0 822C256 855 518 901 776 952C1006 998 1221 1024 1440 1015V1024H0V822Z' fill='%239af557'/%3E%3C/svg%3E") no-repeat center center / cover;
position: fixed; inset: 0; z-index: -1;
filter: none; opacity:1;
}

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

/* “Glass” auth card */
.auth-card,
.signin-card{
width:100%; max-width: 460px;
background: rgba(7, 19, 61, .8);
border: 1px solid var(--glass-b);
border-radius: 26px; box-shadow: var(--shadow);
backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
padding: 36px;
}
.auth-card .helper{ color: var(--muted); }
.signin-card .helper{ color: var(--muted); }

.selection-card{
max-width: 720px;
}

/* Brand circle/logo */
.brand-circle{
width:120px; height:120px; border-radius:28px;
overflow:hidden; margin: 6px auto 18px auto;
border:1px solid rgba(255,255,255,.12);
background: rgba(7, 19, 61, .72);
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,
.signin-card h4.page-title{ text-align:center; margin:12px 0 10px; font-weight:800; font-size: clamp(2rem, 5vw, 3rem); line-height:1; color: var(--easyidp-lime); }

/* 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:14px;
background: rgba(246,251,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:12px;
transition: background .15s ease, color .15s ease, transform .12s ease;
}
.auth-card .toggle-pill a.active{
background: linear-gradient(135deg, var(--easyidp-teal) 0%, var(--easyidp-lime) 100%);
color: var(--easyidp-navy); box-shadow: 0 10px 24px -8px rgba(34,179,157,.4);
}
.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: 14px !important;
padding: .85rem 1.1rem;
border: 1px solid rgba(97,199,211,.24);
background: rgba(246,251,255,.96);
color: var(--easyidp-navy);
transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.auth-card .form-control::placeholder{ color: rgba(11,22,72,.48); }
.auth-card .form-control:focus{
border-color: var(--easyidp-cyan);
box-shadow: 0 0 0 .2rem rgba(97,199,211,.2);
background: rgba(246,251,255,1);
}

/* 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(11,22,72,.72); cursor:pointer; padding:6px; border-radius:8px;
transition: background .15s ease, transform .12s ease;
}
.auth-card .input-with-icon .toggle-eye:hover{ background: rgba(97,199,211,.12); transform: translateY(-50%) scale(1.05); }

/* CTA inside auth card (full width) */
.auth-card .btn-easyidp{
width:100%; border:0; border-radius:14px;
padding: .9rem 1.25rem;
font-weight:800; letter-spacing:.3px;
background: linear-gradient(135deg, var(--easyidp-teal) 0%, var(--easyidp-lime) 100%);
color: var(--easyidp-navy); box-shadow: 0 14px 32px rgba(34,179,157,.3);
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,
.signin-card a,
.selection-card a{ color: var(--easyidp-cyan); text-decoration:none; }
.auth-card .help-link a:hover{ text-decoration: underline; }
#error-message{ margin-top:.75rem; }

.signin-card .form-group label,
.signin-card .form-text,
.signin-card p,
.signin-card small{
color: rgba(246, 251, 255, .82);
}

.signin-card .form-control{
border-radius: 14px !important;
padding: .85rem 1.1rem;
}

.signin-card .btn-easyidp-contrast,
.signin-card .submit{
width: 100%;
}

.action-form{
display: none;
}

.action-form.active{
display: block;
}

.toggle-password{
position: absolute;
right: 1rem;
top: 2.7rem;
cursor: pointer;
color: rgba(11, 22, 72, .62);
}

#back-to-selection{
display: inline-block;
margin-bottom: 1rem;
color: var(--easyidp-cyan);
}

#back-to-selection:hover{
text-decoration: underline;
}

.selection-grid{
display:grid;
grid-template-columns: minmax(0, 1fr) 1px minmax(0, 1fr);
gap: 0 24px;
align-items:stretch;
}

.col-left,
.col-right{
display:flex;
flex-direction:column;
gap: 18px;
}

.divider{
background: linear-gradient(180deg, rgba(97,199,211,.18), rgba(154,245,87,.32));
width: 1px;
height: 100%;
}

.sel-btn{
padding: 1.5rem;
font-size: 1.05rem;
border-radius: 18px !important;
min-height: 88px;
background: rgba(246,251,255,.08);
border: 1px solid rgba(255,255,255,.12);
color: var(--easyidp-white);
cursor: pointer;
transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}

.sel-btn:hover,
.sel-btn:focus{
transform: translateY(-2px);
background: rgba(97,199,211,.16);
border-color: rgba(154,245,87,.22);
color: var(--easyidp-white);
}

@media (max-width: 767px){
.login-container,
.signin-container{ padding: 18px; }

.auth-card,
.signin-card{ padding: 28px; }

.selection-grid{ grid-template-columns: 1fr; gap: 18px; }

.divider{ display:none; }
}

/* 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(--ink);
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) */
.progress-team-card,
.goal-card-panel,
.question-card-panel {
position: relative;
overflow: hidden;
border: 1px solid rgba(160, 190, 235, 0.14);
background:
radial-gradient(circle at top right, rgba(73, 134, 207, 0.16), transparent 36%),
linear-gradient(180deg, rgba(14, 28, 84, 0.98), rgba(9, 19, 58, 0.98));
border-radius: 28px;
box-shadow: 0 24px 60px rgba(4, 10, 31, 0.24);
color: var(--easyidp-white);
}

.progress-team-card::before,
.goal-card-panel::before,
.question-card-panel::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 22%);
}

.easy-card-header {
position: relative;
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 18px;
padding: 18px 22px 14px;
background: transparent;
color: var(--easyidp-white);
border: 0;
}

.easy-card-header-main {
min-width: 0;
display: grid;
gap: 6px;
}

.easy-card-header-title,
.easy-card-header .card-title,
.easy-card-header h5 {
margin: 0;
font-size: clamp(1.05rem, 2vw, 1.35rem);
line-height: 1.18;
font-weight: 700;
color: rgba(246, 251, 255, 0.98) !important;
letter-spacing: -0.01em;
}

.easy-card-header-subtitle {
margin: 0;
font-size: 0.76rem;
line-height: 1.2;
text-transform: uppercase;
letter-spacing: 0.18em;
color: rgba(97, 199, 211, 0.96);
}

.easy-card-header-meta,
.easy-card-header-meta-secondary {
flex-shrink: 0;
display: inline-flex;
align-items: center;
justify-content: center;
padding: 10px 16px;
border-radius: 18px;
background: rgba(127, 255, 65, 0.12);
border: 1px solid rgba(127, 255, 65, 0.18);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
color: #9aff57 !important;
font-size: 0.9rem;
font-weight: 700;
line-height: 1;
white-space: nowrap;
}

.easy-card-header-meta-secondary {
background: rgba(127, 255, 65, 0.12);
border-color: rgba(127, 255, 65, 0.18);
color: #9aff57 !important;
}

.progress-team-card-body,
.goal-card-body,
.question-card-body {
position: relative;
padding: 0 22px 20px;
}

.goal-card-category-row,
.question-card-category-row {
margin: 0 0 16px;
padding: 16px 18px;
border-radius: 20px;
background: rgba(255, 255, 255, 0.05);
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.goal-card .card-body h4,
.question-card .card-body h5 {
color: rgba(246, 251, 255, 0.96);
font-weight: 700;
margin: 0;
}

.goal-card-description,
.question-card-description {
margin-bottom: 14px;
color: rgba(224, 234, 246, 0.84) !important;
line-height: 1.58;
}

.goal-card-date,
.question-card-date {
margin: 0;
}

.goal-card-date .text-muted,
.question-card-date .text-muted,
.progress-team-empty,
.progress-team-card .text-muted {
color: rgba(189, 205, 231, 0.74) !important;
}

.goal-card-footer,
.question-card-footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 10px;
padding: 22px 22px;
background: transparent;
border-top: 0;
}

.progress-team-list {
display: grid;
gap: 12px;
padding: 0 22px 22px;
background: transparent;
}

.progress-team-item,
.question-choice-item {
padding: 14px 16px;
border-radius: 18px !important;
background: rgba(255, 255, 255, 0.05);
border: 1px solid rgba(255, 255, 255, 0.08);
color: rgba(246, 251, 255, 0.94);
}

.progress-team-player-name {
font-weight: 600;
color: rgba(246, 251, 255, 0.96);
}

.question-choice-list {
display: grid;
gap: 10px;
margin: 0 0 18px;
padding: 0;
counter-reset: item;
}

.question-choice-list .question-choice-item {
list-style: none;
position: relative;
padding-left: 48px;
}

.question-choice-list .question-choice-item::before {
counter-increment: item;
content: counter(item);
position: absolute;
left: 14px;
top: 50%;
transform: translateY(-50%);
display: inline-flex;
align-items: center;
justify-content: center;
width: 24px;
height: 24px;
border-radius: 999px;
background: rgba(97, 199, 211, 0.14);
color: rgba(207, 237, 242, 0.96);
font-size: 0.78rem;
font-weight: 700;
}

.ctgrClr {
width: 18px;
height: 18px;
border-radius: 999px;
box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.05);
justify-self: end;
}

.team-overview-card,
.team-players-section,
.team-player-card {
position: relative;
overflow: hidden;
border: 1px solid rgba(160, 190, 235, 0.14);
background:
radial-gradient(circle at top right, rgba(73, 134, 207, 0.14), transparent 36%),
linear-gradient(180deg, rgba(14, 28, 84, 0.98), rgba(9, 19, 58, 0.98));
border-radius: 28px;
box-shadow: 0 24px 60px rgba(4, 10, 31, 0.22);
}

.team-overview-card::before,
.team-players-section::before,
.team-player-card::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 22%);
}

.team-players-section-header {
position: relative;
padding: 18px 22px 14px;
background: transparent;
border: 0;
}

.team-players-section-body {
padding: 0 22px 22px;
}

.team-players-section-heading {
display: grid;
gap: 6px;
}

.team-players-section-heading h4 {
margin: 0;
font-size: clamp(1.15rem, 2vw, 1.55rem);
font-weight: 700;
color: rgba(246, 251, 255, 0.98);
}

.team-section-eyebrow {
font-size: 0.76rem;
line-height: 1.2;
text-transform: uppercase;
letter-spacing: 0.18em;
color: rgba(97, 199, 211, 0.96);
}

.team-player-grid {
row-gap: 10px;
}

.team-player-col {
display: flex;
}

.team-player-col .team-player-card {
width: 100%;
}

.team-player-card {
cursor: pointer;
transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.team-player-card:hover,
.team-player-card:focus-within {
transform: translateY(-3px);
border-color: rgba(97, 199, 211, 0.22);
box-shadow: 0 28px 70px rgba(4, 10, 31, 0.28);
}

.team-player-media {
display: block;
width: 100%;
height: 224px;
object-fit: cover;
border-radius: 20px 20px 0 0;
}

.team-player-media-placeholder {
height: 224px;
background: rgba(8, 16, 46, 0.7);
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.team-player-card-body {
position: relative;
padding: 18px 18px 22px;
}

.team-player-card-title {
margin: 0 0 10px;
font-size: 1.05rem;
font-weight: 700;
line-height: 1.2;
color: rgba(246, 251, 255, 0.98);
}

.team-player-card-meta {
margin: 0;
color: rgba(224, 234, 246, 0.82);
line-height: 1.55;
}

.team-player-card-meta strong {
color: rgba(246, 251, 255, 0.92);
font-weight: 700;
}

.team-player-card-meta em {
font-style: normal;
color: rgba(207, 237, 242, 0.92);
}

.team-add-player-card .team-player-card-body {
display: grid;
align-content: center;
min-height: 156px;
}

.team-add-player-card .team-player-card-title {
font-size: 1.15rem;
}

.team-add-player-card .team-player-card-meta {
max-width: 18ch;
margin-left: auto;
margin-right: auto;
}

.player-shell-card,
.player-section-card,
.player-progress-hero-card,
.player-progress-chart-card,
.player-progress-list-card,
.player-progress-entry-card {
position: relative;
overflow: hidden;
border: 1px solid rgba(160, 190, 235, 0.14);
background:
radial-gradient(circle at top right, rgba(73, 134, 207, 0.14), transparent 36%),
linear-gradient(180deg, rgba(14, 28, 84, 0.98), rgba(9, 19, 58, 0.98));
border-radius: 28px;
box-shadow: 0 24px 60px rgba(4, 10, 31, 0.22);
}

.player-shell-card::before,
.player-section-card::before,
.player-progress-hero-card::before,
.player-progress-chart-card::before,
.player-progress-list-card::before,
.player-progress-entry-card::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 22%);
}

.player-shell .card-body,
.player-progress-shell .card-body {
position: relative;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header,
.player-section-header,
.player-progress-list-header {
padding: 0;
background: transparent !important;
border: 0 !important;
box-shadow: none !important;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle,
.player-section-toggle {
position: relative;
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
padding: 8px 0 10px;
border: 0;
font-weight: 700;
font-size: 1rem;
line-height: 1.2;
color: rgba(246, 251, 255, 0.98) !important;
text-decoration: none !important;
background: transparent;
border-radius: 0;
box-shadow: none;
transition: color .18s ease, transform .18s ease;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle:hover,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle:hover,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle:hover,
.player-section-toggle:hover {
color: rgba(246, 251, 255, 1) !important;
text-decoration: none !important;
background: transparent;
transform: translateY(-1px);
}

.player-section-title {
display: inline-flex;
align-items: center;
gap: 8px;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-title,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-title,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-title {
display: inline-flex;
align-items: center;
min-height: 38px;
padding: 0.45rem 0.95rem;
border-radius: 999px;
background: rgba(154, 245, 87, 0.12);
border: 1px solid rgba(154, 245, 87, 0.12);
font-size: 1rem;
font-weight: 700;
letter-spacing: 0;
color: #9af557;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle > .player-section-title,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle > .player-section-title,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle > .player-section-title,
.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle > .chev,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle > .chev,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle > .chev {
margin-top: 0;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-title i,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-title i,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-title i {
color: #9af557;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .chev,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .chev,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .chev {
display: inline-flex;
align-items: center;
justify-content: center;
width: 34px;
height: 34px;
border-radius: 999px;
background: rgba(255,255,255,.06);
border: 1px solid rgba(255,255,255,.1);
color: rgba(246, 251, 255, 0.9);
transition: transform .2s ease, background .18s ease, border-color .18s ease;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"],
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"],
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle[aria-expanded="true"] {
background: transparent;
box-shadow: none;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .chev,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .chev,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle[aria-expanded="true"] .chev {
background: rgba(255,255,255,.09);
border-color: rgba(255,255,255,.14);
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle:hover .player-section-title,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle:hover .player-section-title,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle:hover .player-section-title,
.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .player-section-title,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .player-section-title,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle[aria-expanded="true"] .player-section-title {
background: rgba(154, 245, 87, 0.16);
border-color: rgba(154, 245, 87, 0.18);
color: #b0fb72;
}

.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle:hover .player-section-title i,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle:hover .player-section-title i,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle:hover .player-section-title i,
.player-shell #playerAccordion > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .player-section-title i,
.edit-player-shell #accordionExample > .player-section-card > .player-section-header .player-section-toggle[aria-expanded="true"] .player-section-title i,
.player-progress-shell #playerAccordion > .player-progress-list-card > .player-progress-list-header .player-section-toggle[aria-expanded="true"] .player-section-title i {
color: #b0fb72;
}

.player-shell #playerAccordion,
.edit-player-shell #accordionExample,
.player-progress-shell #playerAccordion {
display: grid;
gap: 14px;
}

.player-shell #playerAccordion > .player-section-card,
.edit-player-shell #accordionExample > .player-section-card,
.player-progress-shell #playerAccordion > .player-progress-list-card {
padding: 12px;
border-radius: 24px;
}

.edit-player-shell #accordionExample .player-section-header {
padding: 0 !important;
background: transparent !important;
border: 0 !important;
box-shadow: none !important;
}

.edit-player-shell #accordionExample .player-section-toggle {
display: flex !important;
align-items: center !important;
justify-content: space-between !important;
width: 100% !important;
padding: 8px 0 10px !important;
background: transparent !important;
border: 0 !important;
box-shadow: none !important;
text-decoration: none !important;
}

.edit-player-shell #accordionExample .player-section-title {
display: inline-flex !important;
align-items: center !important;
gap: 8px !important;
min-height: 38px !important;
padding: 0.45rem 0.95rem !important;
border-radius: 999px !important;
background: rgba(154, 245, 87, 0.12) !important;
border: 1px solid rgba(154, 245, 87, 0.12) !important;
color: #9af557 !important;
font-weight: 700 !important;
}

.edit-player-shell #accordionExample .player-section-title i {
color: #9af557 !important;
}

.edit-player-shell #accordionExample .player-section-toggle .chev {
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
width: 34px !important;
height: 34px !important;
border-radius: 999px !important;
background: rgba(255,255,255,.06) !important;
border: 1px solid rgba(255,255,255,.1) !important;
color: rgba(246, 251, 255, 0.9) !important;
}

.edit-player-shell #accordionExample .player-section-toggle:hover .player-section-title,
.edit-player-shell #accordionExample .player-section-toggle[aria-expanded="true"] .player-section-title {
background: rgba(154, 245, 87, 0.16) !important;
border-color: rgba(154, 245, 87, 0.18) !important;
color: #b0fb72 !important;
}

.edit-player-shell #accordionExample .player-section-toggle:hover .player-section-title i,
.edit-player-shell #accordionExample .player-section-toggle[aria-expanded="true"] .player-section-title i {
color: #b0fb72 !important;
}

.edit-player-shell .edit-player-accordion-card {
padding: 12px;
border-radius: 24px;
}

.edit-player-shell .edit-player-accordion-header {
padding: 0 !important;
background: transparent !important;
border: 0 !important;
box-shadow: none !important;
}

.edit-player-shell .edit-player-accordion-toggle {
display: flex !important;
align-items: center !important;
justify-content: space-between !important;
width: 100% !important;
padding: 8px 0 10px !important;
background: transparent !important;
border: 0 !important;
box-shadow: none !important;
text-decoration: none !important;
}

.edit-player-shell .edit-player-accordion-title {
display: inline-flex !important;
align-items: center !important;
gap: 8px !important;
min-height: 38px !important;
padding: 0.45rem 0.95rem !important;
border-radius: 999px !important;
background: rgba(154, 245, 87, 0.12) !important;
border: 1px solid rgba(154, 245, 87, 0.12) !important;
color: #9af557 !important;
font-weight: 700 !important;
}

.edit-player-shell .edit-player-accordion-title i {
color: #9af557 !important;
}

.edit-player-shell .edit-player-accordion-toggle .chev {
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
width: 34px !important;
height: 34px !important;
border-radius: 999px !important;
background: rgba(255,255,255,.06) !important;
border: 1px solid rgba(255,255,255,.1) !important;
color: rgba(246, 251, 255, 0.9) !important;
}

.edit-player-shell .edit-player-accordion-toggle:hover .edit-player-accordion-title,
.edit-player-shell .edit-player-accordion-toggle[aria-expanded="true"] .edit-player-accordion-title {
background: rgba(154, 245, 87, 0.16) !important;
border-color: rgba(154, 245, 87, 0.18) !important;
color: #b0fb72 !important;
}

.edit-player-shell .edit-player-accordion-toggle:hover .edit-player-accordion-title i,
.edit-player-shell .edit-player-accordion-toggle[aria-expanded="true"] .edit-player-accordion-title i {
color: #b0fb72 !important;
}

.player-shell #playerAccordion > .player-section-card .collapse.show,
.edit-player-shell #accordionExample > .player-section-card .collapse.show,
.player-progress-shell #playerAccordion > .player-progress-list-card .collapse.show {
margin-top: 12px;
border-top: 1px solid rgba(255,255,255,.08);
padding-top: 6px;
}

.player-section-card .card-body {
padding: 0 22px 22px;
}

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

.player-detail-grid--team {
grid-template-columns: repeat(2, minmax(0, 1fr));
align-content: center;
}

.player-detail-card {
position: relative;
padding: 18px;
border-radius: 22px;
border: 1px solid rgba(255, 255, 255, 0.08);
background: linear-gradient(180deg, rgba(20, 38, 100, 0.18), rgba(9, 18, 54, 0.48));
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
overflow: hidden;
}

.player-detail-card::before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(135deg, rgba(255, 255, 255, 0.04), transparent 58%);
pointer-events: none;
}

.player-detail-card--wide {
grid-column: 1 / -1;
}

.player-detail-label {
display: inline-flex;
align-items: center;
min-height: 32px;
padding: 0.35rem 0.8rem;
border-radius: 999px;
background: rgba(154, 245, 87, 0.12);
border: 1px solid rgba(154, 245, 87, 0.12);
color: #9af557;
font-size: 0.88rem;
font-weight: 700;
margin-bottom: 14px;
}

.player-detail-value {
position: relative;
z-index: 1;
font-size: 1.15rem;
line-height: 1.45;
font-weight: 700;
color: rgba(246, 251, 255, 0.98);
word-break: break-word;
}

.player-media-card {
display: flex;
align-items: center;
justify-content: center;
min-height: 100%;
border-radius: 24px;
border: 1px solid rgba(255, 255, 255, 0.08);
background: linear-gradient(180deg, rgba(20, 38, 100, 0.18), rgba(9, 18, 54, 0.48));
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
overflow: hidden;
}

.player-media-placeholder {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
min-height: 220px;
border-radius: 20px;
background: rgba(255, 255, 255, 0.03);
}

.player-media-image {
display: block;
width: 100%;
border-radius: 18px;
}

.player-team-media-card {
min-height: 100%;
}

.player-team-media-image {
aspect-ratio: 1 / 1;
object-fit: cover;
}

.player-summary-layout {
row-gap: 18px;
}

.player-info-panel,
.player-tags-panel {
padding: 18px 20px;
border-radius: 22px;
background: rgba(255, 255, 255, 0.05);
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.player-info-panel p,
.player-tags-panel p {
color: rgba(224, 234, 246, 0.9);
}

.player-info-panel strong,
.player-tags-panel strong {
color: rgba(246, 251, 255, 0.96);
}

.player-tag-title {
font-size: 1rem;
line-height: 1.25;
}

.player-tag-help {
color: rgba(189, 205, 231, 0.74);
line-height: 1.45;
}

.player-tag-chip {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 6px 10px;
border-radius: 12px;
font-size: 0.82rem;
font-weight: 700;
line-height: 1;
}

.player-tag-chip-positive {
background: rgba(127, 255, 65, 0.12);
border: 1px solid rgba(127, 255, 65, 0.18);
color: #9aff57;
}

.player-tag-chip-warning {
background: rgba(255, 196, 0, 0.14);
border: 1px solid rgba(255, 196, 0, 0.18);
color: #ffc63d;
}

.player-tag-empty {
color: rgba(189, 205, 231, 0.74);
}

.player-radar-panel {
padding-top: 8px;
border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.player-radar-title {
color: rgba(246, 251, 255, 0.96);
font-weight: 700;
}

.player-radar-card {
background: rgba(8, 16, 46, 0.55);
border-radius: 22px;
box-shadow: none;
}

.player-progress-subsection-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
margin-bottom: 18px;
padding: 0 2px;
}

.player-progress-subsection-header--spaced {
margin-top: 26px;
}

.player-progress-subsection-copy {
display: flex;
flex-direction: column;
gap: 6px;
}

.player-progress-subsection-kicker {
font-size: 0.74rem;
line-height: 1;
letter-spacing: 0.2em;
text-transform: uppercase;
color: rgba(111, 210, 229, 0.9);
font-weight: 700;
}

.player-progress-subsection-title {
color: rgba(246, 251, 255, 0.98);
font-size: 1.9rem;
font-weight: 700;
line-height: 1.08;
}

.player-progress-card-grid {
row-gap: 14px;
margin-bottom: 8px;
}

.player-progress-subsection-actions {
margin-top: 10px;
}

.player-shell #collapseProgress .goal-card-panel,
.player-shell #collapseProgress .question-card-panel {
background:
radial-gradient(circle at top right, rgba(72, 131, 205, 0.12), transparent 34%),
linear-gradient(180deg, rgba(12, 24, 68, 0.96), rgba(8, 18, 54, 0.94));
border: 1px solid rgba(159, 187, 232, 0.14);
border-radius: 24px;
box-shadow: 0 22px 48px rgba(3, 10, 31, 0.16);
overflow: hidden;
}

.player-shell #collapseProgress .goal-card-panel .easy-card-header,
.player-shell #collapseProgress .question-card-panel .easy-card-header {
padding: 18px 20px 14px;
background: linear-gradient(180deg, rgba(20, 40, 108, 0.78), rgba(10, 21, 61, 0.08));
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.player-shell #collapseProgress .goal-card-panel .easy-card-header-subtitle,
.player-shell #collapseProgress .question-card-panel .easy-card-header-subtitle {
color: rgba(111, 210, 229, 0.82);
letter-spacing: 0.18em;
font-size: 0.72rem;
text-transform: uppercase;
}

.player-shell #collapseProgress .goal-card-panel .easy-card-header-title,
.player-shell #collapseProgress .question-card-panel .easy-card-header-title {
font-size: 1rem;
line-height: 1.28;
color: rgba(246, 251, 255, 0.98);
}

.player-shell #collapseProgress .question-card-panel .easy-card-header-meta-secondary {
background: rgba(255, 255, 255, 0.06);
border: 1px solid rgba(255, 255, 255, 0.08);
color: rgba(223, 234, 251, 0.9);
}

.player-shell #collapseProgress .goal-card-body,
.player-shell #collapseProgress .question-card-body {
padding: 18px 20px 20px;
}

.player-shell #collapseProgress .goal-card-description,
.player-shell #collapseProgress .question-card-description {
color: rgba(223, 234, 251, 0.9);
line-height: 1.5;
margin-bottom: 10px;
}

.player-shell #collapseProgress .goal-card-date,
.player-shell #collapseProgress .question-card-date {
margin-bottom: 0;
}

.player-shell #collapseProgress .goal-card-date .text-muted,
.player-shell #collapseProgress .question-card-date .text-muted {
color: rgba(189, 205, 231, 0.7) !important;
}

.player-shell #collapseProgress .question-choice-list {
margin-bottom: 12px !important;
}

.player-shell #collapseProgress .question-choice-item {
background: rgba(255, 255, 255, 0.04);
border-color: rgba(255, 255, 255, 0.06);
color: rgba(235, 242, 252, 0.92);
border-radius: 14px;
}

.player-progress-hero-body {
padding: 22px;
}

.player-progress-chart-card .card-header,
.player-progress-entry-card .card-header {
background: transparent !important;
border: 0;
padding: 18px 22px 14px;
}

.player-progress-chart-card .card-body {
padding: 0 22px 22px;
}

.player-progress-list-card > .card-body {
padding: 0 0 18px;
}

.player-progress-list-shell .mx-3 {
margin-left: 22px !important;
margin-right: 22px !important;
}

.player-progress-entry-card .list-group-item {
background: rgba(255, 255, 255, 0.05);
border-color: rgba(255, 255, 255, 0.08);
}

.player-progress-entry-card .text-muted,
.player-shell .text-muted,
.player-progress-shell .text-muted {
color: rgba(189, 205, 231, 0.74) !important;
}

.player-progress-entry-card h6,
.player-progress-chart-card h6,
.player-shell h5 {
color: rgba(246, 251, 255, 0.96);
}

@media (max-width: 767px) {
.easy-card-header {
flex-direction: column;
align-items: flex-start;
}

.player-detail-grid,
.player-detail-grid--team {
grid-template-columns: 1fr;
}

.easy-card-header-meta,
.easy-card-header-meta-secondary {
white-space: normal;
}

.progress-team-list,
.goal-card-body,
.question-card-body,
.goal-card-footer,
.question-card-footer {
padding-left: 18px;
padding-right: 18px;
}

.progress-team-item {
align-items: flex-start !important;
flex-direction: column;
gap: 12px;
}

.goal-card-footer,
.question-card-footer {
justify-content: stretch;
flex-direction: column;
}

.goal-card-footer .btn-sm,
.question-card-footer .btn-sm,
.progress-team-item .btn-sm {
width: 100%;
}

.team-players-section-body {
padding-left: 18px;
padding-right: 18px;
}

.team-player-media,
.team-player-media-placeholder {
height: 208px;
}

.player-section-card .card-body,
.player-progress-hero-body,
.player-progress-chart-card .card-body {
padding-left: 18px;
padding-right: 18px;
}

.player-progress-list-shell .mx-3 {
margin-left: 18px !important;
margin-right: 18px !important;
}
}

/* 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%); }

