:root {
    --bg: #06111f;
    --bg-2: #0a1728;
    --bg-3: #111f35;
    --surface: rgba(255, 255, 255, .88);
    --surface-2: rgba(255, 255, 255, .96);
    --ink: #142033;
    --muted: #667085;
    --line: rgba(20, 32, 51, .11);
    --cyan: #00fbff;
    --pink: #ff0055;
    --green: #77ff00;
    --gold: #ffcc47;
    --gold-2: #d59b22;
    --danger: #ff3b5c;
    --primary: #5b5df5;
    --radius-xl: 28px;
    --radius-lg: 22px;
    --radius-md: 16px;
    --shadow-soft: 0 22px 70px rgba(3, 10, 21, .16);
    --shadow-neon: 0 0 0 1px rgba(0, 251, 255, .22), 0 24px 80px rgba(0, 251, 255, .12);
    --font-main: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Roboto", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    min-height: 100vh;
    margin: 0;
    color: var(--ink);
    font-family: var(--font-main);
    background:
        radial-gradient(circle at top left, rgba(0, 251, 255, .16), transparent 32rem),
        radial-gradient(circle at top right, rgba(255, 0, 85, .13), transparent 30rem),
        linear-gradient(180deg, #f7fbff 0%, #edf3f8 48%, #f8fafc 100%);
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(6, 17, 31, .04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(6, 17, 31, .04) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 70%);
    z-index: -1;
}

img { max-width: 100%; display: block; }
a { color: inherit; }

.app-navbar {
    min-height: 74px;
    background: rgba(6, 17, 31, .91);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 16px 42px rgba(0, 0, 0, .22);
}

.nav-inner { min-height: 74px; }
.brand-shell {
    display: inline-flex;
    align-items: center;
    gap: .72rem;
    color: #fff;
    min-width: 0;
}
.brand-shell:hover { color: #fff; }
.brand-text { display: grid; line-height: 1.05; min-width: 0; }
.brand-text strong { font-size: .98rem; letter-spacing: .01em; white-space: nowrap; }
.brand-text small { color: rgba(255, 255, 255, .64); font-size: .72rem; margin-top: .22rem; }

.brand-logo-orbit {
    --logo-size: 64px;
    position: relative;
    flex: 0 0 var(--logo-size);
    width: var(--logo-size);
    height: var(--logo-size);
    display: grid;
    place-items: center;
    border-radius: 50%;
    padding: 5px;
    background:
        radial-gradient(circle at 30% 20%, #fff8cf 0 10%, transparent 22%),
        conic-gradient(from 225deg, #8a5b05, #ffd86c, #fff1a8, #d59b22, #8a5b05, #ffd86c, #8a5b05);
    box-shadow:
        0 0 0 1px rgba(255, 216, 108, .46),
        0 0 28px rgba(255, 204, 71, .30),
        0 8px 22px rgba(0, 0, 0, .28);
    overflow: hidden;
    animation: goldPulse 3.8s ease-in-out infinite;
}
.brand-logo-orbit::after {
    content: "";
    position: absolute;
    inset: -38% 28% 50% -30%;
    background: linear-gradient(115deg, transparent, rgba(255,255,255,.75), transparent);
    transform: rotate(18deg);
    animation: goldSweep 4.8s ease-in-out infinite;
}
.brand-logo {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    background: #fff;
    border: 2px solid rgba(6,17,31,.72);
}

@keyframes goldPulse {
    0%, 100% { box-shadow: 0 0 0 1px rgba(255,216,108,.42), 0 0 22px rgba(255,204,71,.24), 0 8px 22px rgba(0,0,0,.28); }
    50% { box-shadow: 0 0 0 1px rgba(255,239,166,.82), 0 0 38px rgba(255,204,71,.42), 0 8px 24px rgba(0,0,0,.30); }
}
@keyframes goldSweep {
    0%, 42% { transform: translateX(-160%) rotate(18deg); opacity: 0; }
    50% { opacity: 1; }
    68%, 100% { transform: translateX(260%) rotate(18deg); opacity: 0; }
}

.auth-zone { display: flex; align-items: center; gap: .8rem; color: #fff; }
.auth-label { font-size: .9rem; color: rgba(255,255,255,.75); text-align: right; line-height: 1.15; }
.auth-label strong { color: #fff; display: block; }
.auth-label small { color: rgba(255,255,255,.58); }

.icon-btn {
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 16px;
    color: #fff;
    background: rgba(255,255,255,.07);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}
.icon-btn:hover { transform: translateY(-2px); border-color: rgba(0,251,255,.65); color: var(--cyan); box-shadow: 0 0 24px rgba(0,251,255,.18); }
.icon-btn.danger:hover { border-color: rgba(255,59,92,.7); color: var(--danger); box-shadow: 0 0 24px rgba(255,59,92,.18); }
.icon-btn.skeleton { animation: pulse 1s infinite alternate; }
@keyframes pulse { from { opacity: .35; } to { opacity: .8; } }

.hero-shell { margin-top: 1.25rem; }
.hero-carousel-shell {
    width: min(100%, 883px);
    min-height: 218px;
    margin-inline: auto;
}
.hero-carousel {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-xl);
    background: #020814;
    box-shadow: var(--shadow-neon);
}
.hero-carousel .carousel-inner,
.hero-carousel .carousel-item { height: 218px; }
.hero-carousel .carousel-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(1.18) contrast(1.03);
}
.hero-caption {
    position: absolute;
    left: 18px;
    bottom: 16px;
    z-index: 3;
    max-width: min(76%, 390px);
    padding: .52rem .78rem;
    color: white;
    border: 1px solid rgba(255,255,255,.20);
    border-radius: 14px;
    background: rgba(3, 10, 21, .36);
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 34px rgba(0,0,0,.20);
}
.hero-caption h5 { margin: 0; font-size: .88rem; font-weight: 900; letter-spacing: .02em; }
.hero-caption p { margin: .1rem 0 0; color: var(--gold); font-size: .72rem; font-weight: 800; }
.hero-carousel .carousel-indicators { margin-bottom: .55rem; }
.hero-carousel .carousel-indicators [data-bs-target] {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    border: 0;
    background-color: rgba(255,255,255,.65);
    opacity: .8;
}
.hero-carousel .carousel-indicators .active { background-color: var(--gold); opacity: 1; box-shadow: 0 0 12px rgba(255,204,71,.7); }
.hero-carousel .carousel-control-prev,
.hero-carousel .carousel-control-next { width: 10%; opacity: .3; transition: opacity .25s ease; }
.hero-carousel:hover .carousel-control-prev,
.hero-carousel:hover .carousel-control-next { opacity: .85; }

.ticker-holder { min-height: 0; }
.news-ticker {
    position: relative;
    overflow: hidden;
    margin: 1rem auto 0;
    border-radius: 18px;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(6,17,31,.96), rgba(27,59,178,.94), rgba(6,17,31,.96));
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 18px 44px rgba(6,17,31,.18), inset 0 0 0 1px rgba(0,251,255,.08);
}
.news-ticker::before,
.news-ticker::after {
    content: "";
    position: absolute;
    top: 0;
    width: 76px;
    height: 100%;
    z-index: 2;
    pointer-events: none;
}
.news-ticker::before { left: 0; background: linear-gradient(90deg, rgba(6,17,31,1), transparent); }
.news-ticker::after { right: 0; background: linear-gradient(270deg, rgba(6,17,31,1), transparent); }
.ticker-content {
    display: flex;
    align-items: center;
    width: max-content;
    white-space: nowrap;
    animation: tickerMove 34s linear infinite;
    padding: .72rem 0;
}
.ticker-item {
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    margin-right: 2.6rem;
    font-size: .92rem;
    font-weight: 800;
}
.ticker-live {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .25rem .55rem;
    border-radius: 999px;
    background: rgba(255, 0, 85, .92);
    box-shadow: 0 0 18px rgba(255,0,85,.38);
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.ticker-live i { animation: blinkDot 1s ease-in-out infinite; }
.ticker-date {
    display: inline-flex;
    align-items: center;
    padding: .25rem .55rem;
    border-radius: 8px;
    color: #06111f;
    background: var(--gold);
    font-weight: 950;
}
@keyframes tickerMove { from { transform: translateX(100%); } to { transform: translateX(-100%); } }
@keyframes blinkDot { 0%, 100% { opacity: .25; transform: scale(.86); } 50% { opacity: 1; transform: scale(1.1); } }

.futuristic-nav { margin: 1.35rem 0 1.7rem; }
.nav-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(.65rem, 2vw, 1.5rem);
    list-style: none;
    margin: 0;
    padding: 0 1rem;
}
.nav-list a {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .78rem .95rem;
    color: #465469;
    text-decoration: none;
    font-weight: 900;
    border-radius: 999px;
    transition: color .25s ease, transform .25s ease, background .25s ease;
}
.nav-list a::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: .34rem;
    width: 0;
    height: 3px;
    border-radius: 999px;
    background: var(--clr);
    box-shadow: 0 0 16px var(--clr);
    transform: translateX(-50%);
    transition: width .25s ease;
}
.nav-list a:hover, .nav-list a:focus-visible {
    color: var(--clr);
    background: rgba(255,255,255,.72);
    transform: translateY(-2px);
}
.nav-list a:hover::after, .nav-list a:focus-visible::after { width: 62%; }

.app-main { min-height: 420px; }
.content-stage { animation: fadeUp .35s ease both; }
.section-heading { max-width: 780px; margin: 0 auto 1.6rem; }
.section-heading.compact { margin-bottom: 1rem; }
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: #007c89;
    font-weight: 950;
    letter-spacing: .16em;
    text-transform: uppercase;
    font-size: .72rem;
}
.section-heading h1, .section-heading h2 { margin: .35rem 0 .5rem; color: #0a1728; font-weight: 950; letter-spacing: -.04em; }
.section-heading p { margin: 0; color: var(--muted); }

.public-landing {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 1.25rem;
    align-items: stretch;
    margin-bottom: 2rem;
}
.landing-card, .profile-card, .form-shell, .admin-panel-card {
    border: 1px solid rgba(255,255,255,.70);
    border-radius: var(--radius-xl);
    background: rgba(255,255,255,.86);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(18px);
}
.landing-card { padding: clamp(1.25rem, 3vw, 2rem); overflow: hidden; position: relative; }
.landing-card::before {
    content: "";
    position: absolute;
    width: 220px;
    height: 220px;
    right: -60px;
    top: -80px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,251,255,.22), transparent 68%);
}
.landing-card h1 { font-weight: 950; letter-spacing: -.045em; margin: .3rem 0 .7rem; }
.landing-card p { color: var(--muted); margin-bottom: 1.1rem; }
.landing-actions { display: flex; flex-wrap: wrap; gap: .72rem; }
.privacy-list { display: grid; gap: .7rem; margin: 1.3rem 0 0; padding: 0; list-style: none; }
.privacy-list li { display: flex; gap: .6rem; align-items: flex-start; color: #344054; font-weight: 750; }
.privacy-list i { color: #008e9b; font-size: 1.05rem; margin-top: .1rem; }

.profile-shell { display: grid; gap: 1.2rem; margin-bottom: 2rem; }
.profile-grid { display: grid; grid-template-columns: minmax(260px, .85fr) minmax(0, 1.45fr); gap: 1rem; }
.profile-card { padding: 1.15rem; }
.profile-avatar {
    width: 72px;
    height: 72px;
    display: grid;
    place-items: center;
    border-radius: 22px;
    color: #06111f;
    background: linear-gradient(135deg, var(--cyan), #e4fffb);
    box-shadow: 0 14px 34px rgba(0,251,255,.16);
    font-size: 1.8rem;
    margin-bottom: .9rem;
}
.profile-card h2 { margin: 0; font-size: 1.25rem; font-weight: 950; }
.profile-meta { color: var(--muted); margin: .2rem 0 .9rem; font-size: .9rem; }
.profile-actions { display: grid; gap: .55rem; }
.admin-tools { display: grid; gap: .55rem; margin-top: .9rem; padding-top: .9rem; border-top: 1px solid rgba(20,32,51,.1); }
.stat-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .75rem; }
.stat-card { padding: 1rem; border-radius: 20px; background: rgba(6,17,31,.94); color: #fff; overflow: hidden; position: relative; }
.stat-card::after { content: ""; position: absolute; inset: auto -30px -48px auto; width: 120px; height: 120px; border-radius: 50%; background: rgba(0,251,255,.13); }
.stat-card span { display: block; font-size: .74rem; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .1em; font-weight: 900; }
.stat-card strong { display: block; font-size: 1.8rem; line-height: 1; margin-top: .35rem; }

.dashboard-toolbar { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin: .7rem 0 1rem; }
.dashboard-toolbar h2 { margin: 0; font-weight: 950; letter-spacing: -.035em; }
.dashboard-toolbar p { margin: .2rem 0 0; color: var(--muted); }
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 2.5rem;
}
.record-card {
    position: relative;
    overflow: hidden;
    min-height: 255px;
    padding: 1.05rem;
    border: 1px solid rgba(255,255,255,.66);
    border-radius: var(--radius-lg);
    background: var(--surface);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(18px);
}
.record-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 5px;
    background: linear-gradient(90deg, var(--cyan), var(--pink), var(--green));
}
.record-head { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; margin-bottom: .9rem; }
.type-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem .65rem;
    border-radius: 999px;
    color: #05233a;
    background: rgba(0,251,255,.14);
    border: 1px solid rgba(0,251,255,.25);
    font-size: .78rem;
    font-weight: 950;
}
.record-date { color: var(--muted); font-size: .78rem; font-weight: 800; text-align: right; }
.record-card h3 { margin: 0 0 .7rem; font-size: 1.05rem; font-weight: 950; }
.member-list { display: grid; gap: .45rem; margin: .7rem 0 1rem; }
.member-line { display: flex; align-items: center; gap: .45rem; color: #334155; font-size: .92rem; }
.member-line i { color: #008e9b; }
.record-summary { display: flex; gap: .45rem; flex-wrap: wrap; margin-top: auto; }
.pill { display: inline-flex; align-items: center; gap: .35rem; padding: .38rem .56rem; border-radius: 999px; background: rgba(20,32,51,.06); color: #344054; font-size: .78rem; font-weight: 850; }
.items-box { margin-top: .85rem; display: flex; flex-wrap: wrap; gap: .38rem; padding-bottom: 2.2rem; }
.item-tag { padding: .3rem .5rem; border-radius: 999px; background: #eef2f7; color: #475467; font-size: .76rem; font-weight: 750; }
.record-actions { position: absolute; right: .85rem; bottom: .85rem; display: flex; gap: .4rem; }
.empty-state {
    grid-column: 1 / -1;
    padding: 2rem;
    text-align: center;
    border: 1px dashed rgba(20,32,51,.18);
    border-radius: var(--radius-xl);
    background: rgba(255,255,255,.64);
}
.empty-state i { font-size: 2.4rem; color: #008e9b; }
.empty-state h3 { margin: .75rem 0 .25rem; font-weight: 950; }
.empty-state p { color: var(--muted); margin: 0; }

.mini-showcase {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin: 1rem 0 2.6rem;
}
.mini-slider-card {
    padding: .75rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,.7);
    background: rgba(255,255,255,.82);
    box-shadow: var(--shadow-soft);
}
.mini-title { display: flex; align-items: center; gap: .5rem; padding: .3rem .25rem .7rem; font-weight: 950; color: #0a1728; }
.mini-title i { color: #008e9b; }
.gallery-carousel { position: relative; height: 188px; overflow: hidden; border-radius: 18px; background: #020814; }
.gallery-carousel .carousel-inner,
.gallery-carousel .carousel-item { height: 188px; }
.gallery-carousel img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease, filter .55s ease; }
.mini-slider-card:hover img { transform: scale(1.08); filter: saturate(1.14); }
.mini-caption {
    position: absolute;
    inset: auto 0 0;
    padding: 2.2rem .85rem .85rem;
    color: white;
    font-size: .86rem;
    font-weight: 950;
    text-align: center;
    background: linear-gradient(transparent, rgba(0,0,0,.72));
}
.gallery-carousel .carousel-indicators { margin-bottom: .35rem; }
.gallery-carousel .carousel-indicators [data-bs-target] { width: 7px; height: 7px; border-radius: 50%; border: 0; }

.form-shell {
    max-width: 980px;
    margin: 0 auto 2.5rem;
    padding: clamp(1rem, 3vw, 1.5rem);
}
.form-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.1rem; }
.form-top h2 { margin: 0; font-weight: 950; letter-spacing: -.03em; }
.form-top p { margin: .25rem 0 0; color: var(--muted); }
.form-section-title { margin: 1.1rem 0 .65rem; font-size: .84rem; font-weight: 950; color: #006d78; text-transform: uppercase; letter-spacing: .12em; }
.family-list { display: grid; gap: .7rem; }
.family-member-row {
    display: grid;
    grid-template-columns: 170px 1fr 1fr 110px 44px;
    gap: .55rem;
    align-items: center;
    padding: .7rem;
    border: 1px solid rgba(20,32,51,.08);
    border-radius: 18px;
    background: #fff;
}
.form-control, .form-select { border-radius: 14px; border-color: rgba(20,32,51,.16); min-height: 44px; }
.form-control:focus, .form-select:focus { border-color: rgba(0,251,255,.95); box-shadow: 0 0 0 .2rem rgba(0,251,255,.14); }
.remove-member { width: 44px; height: 44px; border-radius: 14px; }
.counter-strip {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    margin: 1rem 0;
    padding: .85rem;
    border-radius: 18px;
    color: #053142;
    background: linear-gradient(135deg, rgba(0,251,255,.18), rgba(119,255,0,.12));
    border: 1px solid rgba(0,251,255,.24);
}
.counter-strip span { display: inline-flex; align-items: center; gap: .38rem; font-weight: 900; }
.tag-input-wrap { display: grid; gap: .65rem; }
.tags { display: flex; flex-wrap: wrap; gap: .45rem; min-height: 38px; }
.tag-badge {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .46rem .65rem;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(135deg, #4b5563, #111827);
    font-size: .86rem;
    font-weight: 800;
}
.tag-badge button { all: unset; cursor: pointer; display: inline-grid; place-items: center; width: 18px; height: 18px; border-radius: 999px; background: rgba(255,255,255,.16); }
.form-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: 1.25rem; }
.btn-nexus {
    border: 0;
    border-radius: 16px;
    min-height: 48px;
    color: #03101c;
    font-weight: 950;
    background: linear-gradient(135deg, var(--cyan), #d7fff9);
    box-shadow: 0 16px 36px rgba(0,251,255,.18);
}
.btn-nexus:hover { transform: translateY(-1px); color: #03101c; }
.btn-dark-soft { border-radius: 16px; background: #0a1728; color: #fff; min-height: 48px; }
.btn-gold { border: 0; border-radius: 16px; color: #06111f; font-weight: 950; background: linear-gradient(135deg, #ffcc47, #fff0a6, #d59b22); box-shadow: 0 16px 34px rgba(213,155,34,.18); }
.btn-gold:hover { color: #06111f; transform: translateY(-1px); }

.anime-section { margin-bottom: 2.6rem; }
.layout-container {
    position: relative;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    min-height: 190px;
}
.anime-card {
    display: grid;
    place-items: center;
    align-content: center;
    gap: .5rem;
    min-height: 160px;
    border-radius: var(--radius-xl);
    color: #fff;
    font-size: 1.05rem;
    font-weight: 950;
    box-shadow: var(--shadow-soft);
    transform-origin: center;
}
.anime-card i { font-size: 2rem; }
.item-a { background: linear-gradient(135deg, #00a5ff, #00fbff); }
.item-b { background: linear-gradient(135deg, #ff0055, #ff7aa8); }
.item-c { background: linear-gradient(135deg, #00b36b, #77ff00); color: #062019; }
.item-d { background: linear-gradient(135deg, #06111f, #22314a); }

.app-footer {
    margin-top: auto;
    color: rgba(255,255,255,.78);
    background: #06111f;
    border-top: 1px solid rgba(255,255,255,.08);
}
.footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.15rem 0;
}
.footer-links { display: flex; flex-wrap: wrap; gap: .9rem; }
.footer-links a { color: rgba(255,255,255,.78); font-size: .86rem; text-decoration: none; }
.footer-links a:hover { color: var(--cyan); }
.app-footer p { margin: 0; font-size: .86rem; }

/* SweetAlert Login estilo premium oscuro */
.swal2-popup.association-login {
    width: min(92vw, 450px) !important;
    padding: 0 !important;
    border-radius: 20px !important;
    color: #dfe7f4 !important;
    background: linear-gradient(180deg, rgba(17,29,51,.98), rgba(8,16,31,.98)) !important;
    border: 1px solid rgba(148,163,184,.22) !important;
    box-shadow: 0 26px 90px rgba(0,0,0,.5), 0 0 0 1px rgba(0,251,255,.08) !important;
    overflow: hidden !important;
}
.association-login .swal2-html-container { margin: 0 !important; color: inherit !important; }
.login-box { padding: 2.05rem 2.1rem 1.65rem; }
.login-logo {
    width: 92px;
    height: 92px;
    display: grid;
    place-items: center;
    margin: 0 auto 1.05rem;
    border-radius: 50%;
    background: conic-gradient(from 210deg, var(--gold-2), var(--gold), #fff3b8, var(--gold-2));
    box-shadow: 0 0 0 4px rgba(0,251,255,.09), 0 0 34px rgba(255,204,71,.24);
    padding: 5px;
}
.login-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; background: #fff; }
.login-box h2 { margin: .15rem 0 .4rem; color: #f8fafc; font-size: 1.55rem; font-weight: 950; text-align: center; }
.login-box .login-subtitle { color: #98a6bd; text-align: center; margin: 0 0 1.45rem; font-weight: 600; }
.login-field { margin-bottom: 1rem; text-align: left; }
.login-field label { display: block; color: #aab7ca; font-weight: 850; font-size: .88rem; margin-bottom: .42rem; }
.login-input-wrap { position: relative; }
.login-input-wrap i { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: #95a3b7; }
.login-input-wrap input {
    width: 100%;
    min-height: 48px;
    border-radius: 12px;
    border: 1px solid rgba(148,163,184,.42);
    background: rgba(3,10,21,.72);
    color: #f8fafc;
    padding: .75rem 2.8rem .75rem 2.6rem;
    outline: 0;
    transition: border-color .25s ease, box-shadow .25s ease;
}
.login-input-wrap input:focus { border-color: rgba(0,251,255,.72); box-shadow: 0 0 0 .18rem rgba(0,251,255,.13); }
.login-input-wrap .pass-toggle { all: unset; position: absolute; right: .95rem; top: 50%; transform: translateY(-50%); color: #95a3b7; cursor: pointer; }
.login-help { display: flex; justify-content: flex-end; margin: .2rem 0 1.25rem; }
.login-help a, .login-register a { color: #7c83ff; text-decoration: none; font-weight: 800; }
.login-help a:hover, .login-register a:hover { color: var(--cyan); }
.login-register { text-align: center; color: #98a6bd; margin-top: 1.05rem; }
.association-login-confirm {
    width: calc(100% - 4.2rem) !important;
    min-height: 50px !important;
    margin: 0 2.1rem 0 !important;
    border-radius: 12px !important;
    font-weight: 950 !important;
    color: #fff !important;
    background: linear-gradient(135deg, #6567f5, #5145ef) !important;
    box-shadow: 0 14px 34px rgba(81,69,239,.28) !important;
}
.association-login-cancel { color: #aab7ca !important; }

@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 991.98px) {
    .public-landing, .profile-grid { grid-template-columns: 1fr; }
    .dashboard-grid, .mini-showcase { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .family-member-row { grid-template-columns: 1fr 1fr; }
    .remove-member { width: 100%; }
    .layout-container { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 575.98px) {
    .app-navbar { min-height: 66px; }
    .nav-inner { min-height: 66px; }
    .brand-logo-orbit { --logo-size: 54px; padding: 4px; }
    .brand-text strong { font-size: .78rem; max-width: 168px; overflow: hidden; text-overflow: ellipsis; }
    .brand-text small { display: none; }
    .auth-label { display: none; }
    .hero-carousel-shell { min-height: 174px; }
    .hero-carousel .carousel-inner,
    .hero-carousel .carousel-item { height: 174px; }
    .hero-carousel { border-radius: 22px; }
    .hero-caption { left: 12px; bottom: 12px; padding: .45rem .58rem; }
    .hero-caption h5 { font-size: .78rem; }
    .hero-caption p { font-size: .66rem; }
    .ticker-item { font-size: .82rem; margin-right: 2rem; }
    .nav-list { gap: .25rem; }
    .nav-list a { font-size: .86rem; padding: .65rem .58rem; }
    .dashboard-grid, .mini-showcase, .layout-container, .stat-grid { grid-template-columns: 1fr; }
    .family-member-row { grid-template-columns: 1fr; }
    .form-actions { grid-template-columns: 1fr; }
    .dashboard-toolbar, .form-top { flex-direction: column; align-items: stretch; }
    .footer-inner { flex-direction: column; text-align: center; }
    .footer-links { justify-content: center; }
    .login-box { padding: 1.65rem 1.35rem 1.35rem; }
    .association-login-confirm { width: calc(100% - 2.7rem) !important; margin: 0 1.35rem !important; }
}
