/* Comgrap LearnWorlds — SSO frontend (standalone, no Bootstrap dependency) */
:root {
    --cglw-sso-primary: #009de0;
    --cglw-sso-primary-600: #0087c2;
    --cglw-sso-primary-50: #e6f6fd;
    --cglw-sso-primary-100: #cceefa;
    --cglw-sso-text: #1f2937;
    --cglw-sso-text-muted: #6b7280;
    --cglw-sso-border: #e5e7eb;
    --cglw-sso-border-strong: #d1d5db;
    --cglw-sso-bg: #ffffff;
    --cglw-sso-bg-soft: #f7f8fa;
    --cglw-sso-radius: 14px;
    --cglw-sso-radius-sm: 8px;
    --cglw-sso-shadow-sm: 0 1px 2px rgba(17,24,39,.04);
    --cglw-sso-shadow: 0 10px 30px rgba(17,24,39,.08);
}

.comgrap-lw-auth {
    max-width: 440px;
    margin: 2rem auto;
    padding: 2rem 1.75rem;
    border: 1px solid var(--cglw-sso-border);
    border-radius: var(--cglw-sso-radius);
    background: var(--cglw-sso-bg);
    box-shadow: var(--cglw-sso-shadow);
    font-family: inherit;
    color: var(--cglw-sso-text);
    box-sizing: border-box;
}
.comgrap-lw-auth--account { max-width: 720px; }

.comgrap-lw-auth__header { margin-bottom: 1.25rem; text-align: center; }
.comgrap-lw-title { font-size: 1.5rem; font-weight: 700; margin: 0 0 .35rem; line-height: 1.2; color: var(--cglw-sso-text); }
.comgrap-lw-subtitle { margin: 0; color: var(--cglw-sso-text-muted); font-size: .92rem; }

.comgrap-lw-meta { color: var(--cglw-sso-text-muted); font-size: .85rem; }
.comgrap-lw-form { display: flex; flex-direction: column; gap: 1rem; }

.comgrap-lw-field { display: flex; flex-direction: column; gap: .4rem; }
.comgrap-lw-field > span { font-size: .82rem; font-weight: 600; color: var(--cglw-sso-text); letter-spacing: .01em; }
.comgrap-lw-field input {
    height: 44px;
    padding: 0 .85rem;
    border: 1px solid var(--cglw-sso-border-strong);
    border-radius: var(--cglw-sso-radius-sm);
    font: inherit;
    font-size: .95rem;
    color: var(--cglw-sso-text);
    background: var(--cglw-sso-bg);
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box;
    width: 100%;
}
.comgrap-lw-field input::placeholder { color: #9ca3af; }
.comgrap-lw-field input:focus { outline: none; border-color: var(--cglw-sso-primary); box-shadow: 0 0 0 3px rgba(0,157,224,.15); }

/* Password con toggle ojo */
.comgrap-lw-password { position: relative; display: block; }
.comgrap-lw-password input { padding-right: 44px; }
.comgrap-lw-password__toggle {
    position: absolute;
    top: 50%;
    right: 6px;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 0;
    border-radius: 6px;
    cursor: pointer;
    color: var(--cglw-sso-text-muted);
    font-size: 1rem;
    line-height: 1;
    padding: 0;
    transition: background .15s, color .15s;
}
.comgrap-lw-password__toggle:hover { background: var(--cglw-sso-primary-50); color: var(--cglw-sso-primary); }
.comgrap-lw-password.is-revealed .comgrap-lw-password__toggle { color: var(--cglw-sso-primary); }

.comgrap-lw-hint { color: var(--cglw-sso-text-muted); font-size: .78rem; line-height: 1.4; }

.comgrap-lw-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: .55rem 1.2rem;
    border-radius: var(--cglw-sso-radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    font: inherit;
    font-weight: 600;
    font-size: .95rem;
    text-decoration: none;
    transition: background .15s, border-color .15s, color .15s, transform .1s, opacity .15s;
}
.comgrap-lw-btn[disabled] { opacity: .6; cursor: not-allowed; }
.comgrap-lw-btn:active:not([disabled]) { transform: translateY(1px); }
.comgrap-lw-btn-block { width: 100%; margin-top: .35rem; }
.comgrap-lw-btn-primary { background: var(--cglw-sso-primary); color: #fff; border-color: var(--cglw-sso-primary); }
.comgrap-lw-btn-primary:hover { background: var(--cglw-sso-primary-600); border-color: var(--cglw-sso-primary-600); }
.comgrap-lw-btn-secondary { background: #fff; color: var(--cglw-sso-primary); border-color: var(--cglw-sso-primary); }
.comgrap-lw-btn-secondary:hover { background: var(--cglw-sso-primary-50); }
.comgrap-lw-btn-link { background: transparent; color: var(--cglw-sso-text-muted); }
.comgrap-lw-btn-link:hover { color: var(--cglw-sso-text); }

/* Enlace cruzado login ↔ registro */
.comgrap-lw-auth__alt {
    margin: 1.25rem 0 0;
    text-align: center;
    color: var(--cglw-sso-text-muted);
    font-size: .9rem;
}
.comgrap-lw-auth__alt-link {
    color: var(--cglw-sso-primary);
    font-weight: 600;
    text-decoration: none;
    margin-left: .25rem;
}
.comgrap-lw-auth__alt-link:hover { text-decoration: underline; }
.comgrap-lw-actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.comgrap-lw-feedback { padding: .65rem .8rem; border-radius: 8px; font-size: .9rem; }
.comgrap-lw-feedback.is-error   { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.comgrap-lw-feedback.is-success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.comgrap-lw-feedback.is-info    { background: var(--cglw-sso-primary-50, #e6f6fd); color: var(--cglw-sso-primary-600, #0087c2); border: 1px solid var(--cglw-sso-primary-100, #cceefa); }
.comgrap-lw-account-header { margin-bottom: 1.25rem; }
.comgrap-lw-account-section { padding: 1rem 0; border-top: 1px solid #e5e7eb; }
.comgrap-lw-account-section h3 { margin: 0 0 .75rem; font-size: 1rem; }
.comgrap-lw-dl { display: grid; grid-template-columns: 160px 1fr; gap: .35rem .75rem; margin: 0; }
.comgrap-lw-dl dt { color: #6b7280; font-size: .85rem; }
.comgrap-lw-dl dd { margin: 0; font-size: .9rem; }
.comgrap-lw-sessions { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.comgrap-lw-sessions li { padding: .65rem .8rem; border: 1px solid #e5e7eb; border-radius: 8px; display: flex; flex-direction: column; gap: .2rem; }
.comgrap-lw-badge { display: inline-block; align-self: flex-start; padding: .15rem .5rem; border-radius: 999px; background: #2271b1; color: #fff; font-size: .7rem; font-weight: 600; }
.comgrap-lw-greet { margin: 0 0 .5rem; }

/* Dashboard "Mi cuenta" — paleta corporativa cyan (#009de0) */
.comgrap-lw-account-dashboard {
    width: min(1120px, 100%);
    margin: 1.5rem auto;
    padding: 1.25rem;
    color: var(--cglw-sso-text);
    font-family: inherit;
    background:
        radial-gradient(1200px 320px at -10% -20%, rgba(0,157,224,.10), transparent 60%),
        radial-gradient(900px 280px at 110% 110%, rgba(0,157,224,.07), transparent 60%),
        var(--cglw-sso-bg-soft);
    border-radius: 18px;
}

/* Hero */
.comgrap-lw-account-hero {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 1rem; padding: 1.4rem 1.5rem;
    border: 1px solid var(--cglw-sso-primary-100);
    border-radius: 16px;
    background:
        linear-gradient(135deg, var(--cglw-sso-primary-50) 0%, #ffffff 60%);
    box-shadow: 0 6px 20px rgba(0,135,194,.08);
    position: relative; overflow: hidden;
}
.comgrap-lw-account-hero::before {
    content: ""; position: absolute; inset: 0 auto 0 0; width: 6px;
    background: linear-gradient(180deg, var(--cglw-sso-primary), var(--cglw-sso-primary-600));
}
.comgrap-lw-eyebrow {
    margin: 0 0 .35rem; color: var(--cglw-sso-primary-600);
    font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
}
.comgrap-lw-account-title { margin: 0; font-size: clamp(1.4rem, 2vw, 2rem); line-height: 1.15; color: #0b2a3b; }
.comgrap-lw-account-meta { margin: .35rem 0 0; color: var(--cglw-sso-text-muted); font-size: .95rem; word-break: break-word; }
.comgrap-lw-account-hero__actions { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: .6rem; }

/* Pills */
.comgrap-lw-pill {
    display: inline-flex; align-items: center; min-height: 28px;
    padding: .25rem .7rem;
    border: 1px solid var(--cglw-sso-primary-100);
    border-radius: 999px;
    background: var(--cglw-sso-primary-50);
    color: var(--cglw-sso-primary-600);
    font-size: .78rem; font-weight: 700; white-space: nowrap;
}
.comgrap-lw-pill.is-success { border-color: #bbf7d0; background: #ecfdf5; color: #166534; }

/* Stats */
.comgrap-lw-account-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .9rem; margin: 1rem 0; }
.comgrap-lw-account-stat {
    position: relative; min-height: 96px; padding: 1rem 1.1rem;
    border: 1px solid var(--cglw-sso-border);
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, var(--cglw-sso-primary-50) 220%);
    box-shadow: 0 1px 3px rgba(17,24,39,.04);
    overflow: hidden;
}
.comgrap-lw-account-stat::after {
    content: ""; position: absolute; right: -28px; top: -28px; width: 80px; height: 80px;
    border-radius: 50%; background: var(--cglw-sso-primary-50); opacity: .8;
}
.comgrap-lw-account-stat span { position: relative; z-index: 1; display: block; color: var(--cglw-sso-text-muted); font-size: .82rem; font-weight: 600; }
.comgrap-lw-account-stat strong { position: relative; z-index: 1; display: block; margin-top: .4rem; font-size: 1.65rem; line-height: 1.1; color: var(--cglw-sso-primary-600); }

/* Grid de paneles */
.comgrap-lw-account-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr); gap: 1rem; margin-bottom: 1rem; }
.comgrap-lw-account-panel {
    padding: 1.25rem;
    border: 1px solid var(--cglw-sso-border);
    border-top: 3px solid var(--cglw-sso-primary);
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 4px 16px rgba(17,24,39,.05);
}
.comgrap-lw-account-panel__head { display: flex; align-items: center; justify-content: space-between; gap: .75rem; margin-bottom: 1rem; padding-bottom: .65rem; border-bottom: 1px dashed var(--cglw-sso-primary-100); }
.comgrap-lw-account-panel__head h3 { margin: 0; font-size: 1.05rem; line-height: 1.2; color: var(--cglw-sso-primary-600); font-weight: 700; }

/* Definition lists */
.comgrap-lw-account-dl { display: grid; grid-template-columns: 150px 1fr; gap: .55rem .9rem; margin: 0; }
.comgrap-lw-account-dl dt { color: var(--cglw-sso-text-muted); font-size: .84rem; font-weight: 600; }
.comgrap-lw-account-dl dd { margin: 0; font-size: .92rem; color: var(--cglw-sso-text); word-break: break-word; }
.comgrap-lw-account-dl code { white-space: pre-wrap; word-break: break-word; }
.comgrap-lw-account-empty { margin: 0; color: var(--cglw-sso-text-muted); font-style: italic; }

/* Empty-state con CTA (cuando "Mis cursos" está vacío). */
.comgrap-lw-account-empty--cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: .5rem;
    padding: 2rem 1.25rem;
    background: linear-gradient(135deg, rgba(0, 157, 224, .06) 0%, rgba(255, 255, 255, 1) 100%);
    border: 1px dashed var(--cglw-sso-border);
    border-radius: 12px;
    color: var(--cglw-sso-text);
    font-style: normal;
}
.comgrap-lw-account-empty__icon { font-size: 2.25rem; line-height: 1; margin-bottom: .25rem; }
.comgrap-lw-account-empty__title { margin: 0; font-size: 1.05rem; font-weight: 600; color: var(--cglw-sso-text); }
.comgrap-lw-account-empty__subtitle { margin: 0 0 .75rem; font-size: .9rem; color: var(--cglw-sso-text-muted); max-width: 480px; }

/* Historial */
.comgrap-lw-account-history { margin-top: 1.1rem; padding-top: 1rem; border-top: 1px solid var(--cglw-sso-border); }
.comgrap-lw-account-history h4 { margin: 0 0 .65rem; font-size: .92rem; color: var(--cglw-sso-text); }
.comgrap-lw-account-history ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .5rem; }
.comgrap-lw-account-history li {
    display: grid; grid-template-columns: 1fr auto; gap: .15rem .7rem;
    padding: .7rem .85rem;
    border: 1px solid var(--cglw-sso-primary-100);
    border-left: 3px solid var(--cglw-sso-primary);
    border-radius: 10px;
    background: var(--cglw-sso-primary-50);
}
.comgrap-lw-account-history li span { font-weight: 700; color: #0b2a3b; }
.comgrap-lw-account-history li strong { color: var(--cglw-sso-primary-600); font-size: .82rem; }
.comgrap-lw-account-history li small { grid-column: 1 / -1; color: var(--cglw-sso-text-muted); }

/* Cursos */
.comgrap-lw-course-list { display: grid; gap: .9rem; }
.comgrap-lw-course-row {
    display: grid; grid-template-columns: 120px minmax(0, 1fr); gap: 1rem;
    padding: .9rem;
    border: 1px solid var(--cglw-sso-border);
    border-radius: 14px;
    background: #fff;
    transition: border-color .15s, box-shadow .15s, transform .12s;
}
.comgrap-lw-course-row:hover { border-color: var(--cglw-sso-primary); box-shadow: 0 8px 24px rgba(0,135,194,.10); transform: translateY(-1px); }
.comgrap-lw-course-row__image-link { display: block; width: 120px; height: 100%; }
.comgrap-lw-course-row__image,
.comgrap-lw-course-row__placeholder {
    width: 120px; aspect-ratio: 4 / 3;
    border-radius: 10px; object-fit: cover;
    background: var(--cglw-sso-primary-50);
}
.comgrap-lw-course-row__placeholder { background: linear-gradient(135deg, var(--cglw-sso-primary-100) 0%, #ffffff 100%); }
.comgrap-lw-course-row__body { min-width: 0; display: flex; flex-direction: column; gap: .55rem; }
.comgrap-lw-course-row__top { display: flex; align-items: flex-start; justify-content: space-between; gap: .7rem; }
.comgrap-lw-course-row__top h4 { margin: .1rem 0 0; font-size: 1.02rem; line-height: 1.25; color: #0b2a3b; overflow-wrap: anywhere; }
.comgrap-lw-course-row__top h4 a { color: inherit; text-decoration: none; transition: color .15s; }
.comgrap-lw-course-row__top h4 a:hover { color: var(--cglw-sso-primary-600); text-decoration: underline; }

.comgrap-lw-progress { width: 100%; height: 10px; overflow: hidden; border-radius: 999px; background: var(--cglw-sso-primary-50); border: 1px solid var(--cglw-sso-primary-100); }
.comgrap-lw-progress span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--cglw-sso-primary) 0%, var(--cglw-sso-primary-600) 100%); transition: width .25s ease; }
.comgrap-lw-course-row__meta { display: flex; flex-wrap: wrap; gap: .35rem .9rem; color: var(--cglw-sso-text-muted); font-size: .82rem; }

.comgrap-lw-course-row__actions { margin-top: .25rem; }
.comgrap-lw-course-row__actions .comgrap-lw-btn:hover { color: white;}
.comgrap-lw-btn-sm { min-height: 36px; padding: .35rem .9rem; font-size: .85rem; gap: .35rem; }

@media (max-width: 760px) {
    .comgrap-lw-account-dashboard { padding: .75rem; }
    .comgrap-lw-account-hero,
    .comgrap-lw-account-panel__head,
    .comgrap-lw-course-row__top { flex-direction: column; align-items: stretch; }
    .comgrap-lw-account-hero__actions { justify-content: flex-start; }
    .comgrap-lw-account-stats,
    .comgrap-lw-account-grid { grid-template-columns: 1fr; }
    .comgrap-lw-course-row { grid-template-columns: 1fr; }
    .comgrap-lw-course-row__image-link,
    .comgrap-lw-course-row__image,
    .comgrap-lw-course-row__placeholder { width: 100%; max-height: 200px; }
    .comgrap-lw-account-dl { grid-template-columns: 1fr; }
}
