@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;700;800;900&display=swap');

:root {
    --bg: #050816;
    --surface: rgba(17, 21, 43, 0.86);
    --surface-2: rgba(26, 30, 54, 0.78);
    --line: rgba(255, 255, 255, 0.08);
    --text: #f8fafc;
    --muted: #b6bfd9;
    --accent: #7c3aed;
    --accent-2: #a855f7;
    --accent-3: #c084fc;
    --shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
    --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: 'Cairo', sans-serif;
    background:
        radial-gradient(circle at 80% 18%, rgba(168, 85, 247, 0.18), transparent 22%),
        radial-gradient(circle at 18% 8%, rgba(124, 58, 237, 0.17), transparent 24%),
        linear-gradient(180deg, #040611 0%, #050816 26%, #070b18 100%);
    color: var(--text);
    direction: rtl;
    overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { width: min(1240px, calc(100% - 32px)); margin: 0 auto; }
.center { text-align: center; }
.mt24 { margin-top: 24px; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    backdrop-filter: blur(14px);
    background: rgba(5, 8, 22, 0.55);
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

.nav {
    height: 92px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 18px;
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-inline-start: auto;
    flex-shrink: 0;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.brand-mark {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: linear-gradient(145deg, #a855f7, #6d28d9);
    box-shadow: 0 14px 30px rgba(124, 58, 237, 0.35);
}
.brand-mark.sm { width: 38px; height: 38px; border-radius: 12px; }
.brand-mark svg { width: 28px; height: 28px; }
.brand-text { line-height: 1.05; text-align: right; }
.brand-text strong { display: block; font-size: 1.1rem; }
.brand-text span { color: var(--muted); font-size: 0.82rem; }

.nav-links {
    display: flex;
    align-items: center;
    gap: 30px;
    color: #dfe4f4;
    font-weight: 700;
    flex: 1 1 auto;
    justify-content: center;
    min-width: 0;
}

.nav-links a { position: relative; padding: 8px 0; opacity: 0.92; }
.nav-links a.active::after {
    content: '';
    position: absolute;
    inset-inline: 0;
    bottom: -11px;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, var(--accent-3), transparent);
    box-shadow: 0 0 16px rgba(168, 85, 247, 0.8);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 12px;
    border: 1px solid transparent;
    font-weight: 800;
    font-size: .86rem;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
    white-space: nowrap;
    cursor: pointer;
}
.btn:hover { transform: translateY(-1px); }
.btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.btn-sm { padding: 8px 12px; font-size: .8rem; }
.btn-primary {
    background: linear-gradient(135deg, #22c55e, #16a34a 55%, #15803d);
    box-shadow: 0 14px 30px rgba(34, 197, 94, 0.28);
}
.btn-outline {
    background: rgba(59, 130, 246, 0.12);
    border-color: rgba(59,130,246,0.3);
    color: #dbeafe;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.btn-cyan {
    background: rgba(6, 182, 212, 0.16);
    border-color: rgba(6, 182, 212, 0.34);
    color: #cffafe;
    box-shadow: 0 10px 22px rgba(6, 182, 212, 0.12);
}
.btn-violet {
    background: rgba(139, 92, 246, 0.16);
    border-color: rgba(139, 92, 246, 0.34);
    color: #ede9fe;
    box-shadow: 0 10px 22px rgba(139, 92, 246, 0.12);
}
.btn-amber {
    background: rgba(245, 158, 11, 0.16);
    border-color: rgba(245, 158, 11, 0.34);
    color: #fef3c7;
    box-shadow: 0 10px 22px rgba(245, 158, 11, 0.12);
}
.btn-sky {
    background: rgba(59, 130, 246, 0.16);
    border-color: rgba(59, 130, 246, 0.34);
    color: #dbeafe;
    box-shadow: 0 10px 22px rgba(59, 130, 246, 0.12);
}
.btn-rose {
    background: rgba(244, 63, 94, 0.16);
    border-color: rgba(244, 63, 94, 0.34);
    color: #ffe4e6;
    box-shadow: 0 10px 22px rgba(244, 63, 94, 0.12);
}
.btn-teal {
    background: rgba(20, 184, 166, 0.16);
    border-color: rgba(20, 184, 166, 0.34);
    color: #ccfbf1;
    box-shadow: 0 10px 22px rgba(20, 184, 166, 0.12);
}
.btn-purple {
    background: rgba(168, 85, 247, 0.16);
    border-color: rgba(168, 85, 247, 0.34);
    color: #f3e8ff;
    box-shadow: 0 10px 22px rgba(168, 85, 247, 0.12);
}
.btn-orange {
    background: rgba(249, 115, 22, 0.16);
    border-color: rgba(249, 115, 22, 0.34);
    color: #ffedd5;
    box-shadow: 0 10px 22px rgba(249, 115, 22, 0.12);
}
.btn-slate {
    background: rgba(100, 116, 139, 0.16);
    border-color: rgba(100, 116, 139, 0.34);
    color: #e2e8f0;
    box-shadow: 0 10px 22px rgba(100, 116, 139, 0.12);
}
.btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626 55%, #b91c1c);
    box-shadow: 0 14px 30px rgba(239, 68, 68, 0.25);
    color: #fff;
}

.hero {
    position: relative;
    padding: 34px 0 28px;
    overflow: hidden;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 20px;
    align-items: center;
    min-height: 560px;
}

.hero-copy { position: relative; z-index: 2; }
.pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(124, 58, 237, 0.18);
    border: 1px solid rgba(168, 85, 247, 0.26);
    color: #efe5ff;
    font-weight: 800;
    margin-bottom: 18px;
}

h1 {
    margin: 0;
    font-size: clamp(2.2rem, 4vw, 3.8rem);
    line-height: 1.12;
    letter-spacing: -0.02em;
}

.accent { color: #b56cff; text-shadow: 0 0 20px rgba(168, 85, 247, 0.28); }
.lead {
    max-width: 680px;
    margin: 18px 0 0;
    color: var(--muted);
    font-size: 1rem;
    line-height: 1.7;
}

.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 24px; }

.benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-top: 24px;
    max-width: 100%;
}

.benefit {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(12, 15, 31, 0.35);
    min-height: 82px;
}
.iconbox,
.service .iconbox,
.stat .iconbox,
.contact-item .iconbox {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(124, 58, 237, 0.16);
    color: #d8b4fe;
    border: 1px solid rgba(168, 85, 247, 0.18);
    flex-shrink: 0;
}
.benefit strong { display: block; font-size: 0.88rem; }
.benefit span { color: var(--muted); font-size: 0.76rem; }

.hero-visual {
    position: relative;
    min-height: 560px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glow {
    position: absolute;
    inset: auto 0 0 auto;
    width: 92%;
    height: 92%;
    filter: blur(20px);
    background: radial-gradient(circle at 58% 42%, rgba(168, 85, 247, 0.18), transparent 35%),
                radial-gradient(circle at 70% 30%, rgba(124, 58, 237, 0.22), transparent 20%);
    pointer-events: none;
}

.screen {
    position: absolute;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(13, 18, 39, 0.96), rgba(8, 12, 28, 0.96));
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: var(--shadow);
}
.screen.one { width: 220px; height: 150px; left: 10%; top: 28%; opacity: 0.72; }
.screen.two { width: 260px; height: 170px; right: 8%; top: 35%; opacity: 0.78; }
.code-lines {
    position: absolute; inset: 16px;
    background: linear-gradient(90deg, transparent 0 8%, rgba(168,85,247,0.9) 8% 10%, transparent 10% 22%, rgba(255,255,255,0.15) 22% 24%, transparent 24%),
                linear-gradient(#1b2144 0 0) 0 18px / 100% 1px,
                linear-gradient(#1b2144 0 0) 0 46px / 100% 1px,
                linear-gradient(#1b2144 0 0) 0 74px / 100% 1px,
                linear-gradient(#1b2144 0 0) 0 102px / 100% 1px;
    background-repeat: no-repeat;
    border-radius: 14px;
}

.code-symbol {
    position: absolute;
    right: 6%;
    top: 19%;
    font-size: clamp(4rem, 8vw, 7rem);
    color: rgba(186, 104, 255, 0.95);
    text-shadow: 0 0 22px rgba(168, 85, 247, 0.5);
    font-weight: 900;
}

.photo-card {
    position: relative;
    width: min(360px, 92%);
    aspect-ratio: 0.8;
    margin-top: 40px;
    z-index: 2;
}

.photo-frame {
    position: absolute;
    inset: 0;
    border-radius: 34% 34% 20% 20% / 28% 28% 16% 16%;
    overflow: hidden;
    box-shadow: 0 22px 50px rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(255,255,255,0.08);
}
.photo-frame::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 44%, rgba(8, 10, 16, 0.42) 100%);
    z-index: 1;
}
.photo-frame img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    filter: saturate(0.92) contrast(1.02);
}

.laptop-overlay {
    position: absolute;
    left: 6%;
    right: 6%;
    bottom: -3%;
    height: 30%;
    display: grid;
    place-items: center;
}

.laptop-screen {
    width: 82%;
    height: 100%;
    border-radius: 16px;
    transform: perspective(900px) rotateX(18deg);
    background: linear-gradient(180deg, #40445a, #171a29 80%);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 20px 40px rgba(0,0,0,0.48);
    display: grid;
    place-items: center;
    gap: 4px;
}
.laptop-screen span { color: rgba(255,255,255,0.72); font-weight: 900; font-size: 1.15rem; }
.laptop-screen strong { color: rgba(192, 132, 252, 0.95); font-size: 1.8rem; text-shadow: 0 0 14px rgba(168, 85, 247, 0.6); }

.floating-card {
    position: absolute;
    right: -2%;
    bottom: 11%;
    width: 270px;
    padding: 18px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(22, 24, 49, 0.92), rgba(16, 19, 38, 0.88));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow);
    z-index: 3;
}
.floating-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.floating-card h3 { margin: 0; font-size: 0.95rem; }
.floating-card-link {
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(124,58,237,0.16);
    border: 1px solid rgba(168,85,247,0.18);
    color: #efe5ff;
    font-size: .75rem;
    font-weight: 800;
    white-space: nowrap;
}
.floating-card strong {
    display: block;
    margin-bottom: 8px;
    color: #f7f3ff;
    font-size: 1.02rem;
}
.floating-card p { margin: 0; color: #d8dcf0; line-height: 1.7; font-size: 0.86rem; }
.hero-project-note {
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #eae7ff;
    font-size: .9rem;
    line-height: 1.6;
}
.hero-project-note strong { color: #c084fc; }

.plant {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 92px;
    height: 120px;
    z-index: 2;
}
.plant::before {
    content: '';
    position: absolute;
    inset: auto 16px 0;
    height: 34px;
    border-radius: 0 0 16px 16px;
    background: linear-gradient(180deg, #d8d9df, #b7bac5);
}
.plant::after {
    content: '';
    position: absolute;
    inset: 14px 14px 28px;
    background:
        radial-gradient(circle at 30% 100%, #43a047 0 14%, transparent 15%),
        radial-gradient(circle at 50% 100%, #66bb6a 0 14%, transparent 15%),
        radial-gradient(circle at 70% 100%, #2e7d32 0 14%, transparent 15%);
    transform: rotate(-7deg);
}

.section { padding: 26px 0 10px; }
.section-head { text-align: center; margin-bottom: 24px; }
.section-head.left { text-align: right; }
.section-head h2 {
    margin: 0;
    font-size: clamp(1.7rem, 2.7vw, 2.4rem);
    line-height: 1.2;
}
.section-head p { margin: 8px 0 0; color: var(--muted); font-size: 0.92rem; }

.grid-3, .grid-4 { display: grid; gap: 14px; }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

.service, .project, .stat, .footer-panel, .about-card, .contact-card {
    background: linear-gradient(180deg, var(--surface-2), rgba(12, 16, 33, 0.78));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.service {
    padding: 18px 18px 16px;
    min-height: 230px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.service h3, .project h3 { margin: 14px 0 8px; font-size: 1.18rem; }
.service p, .project p, .about-card p { margin: 0; color: var(--muted); line-height: 1.7; }
.link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 18px;
    color: #d8b4fe;
    font-weight: 800;
}

.project { overflow: hidden; }
.project .thumb {
    height: 146px;
    background: linear-gradient(180deg, #f6f7fb, #e9eefb);
    position: relative;
}
.thumb::before,
.thumb::after {
    content: '';
    position: absolute;
    inset: 14px;
    border-radius: 12px;
    background:
        linear-gradient(90deg, rgba(34, 38, 66, 0.12) 0 13%, transparent 13%),
        linear-gradient(#bdc7df 0 0) 0 28px / 100% 1px,
        linear-gradient(#bdc7df 0 0) 0 62px / 100% 1px,
        linear-gradient(#bdc7df 0 0) 0 96px / 100% 1px,
        linear-gradient(#cfd8ea 0 0) 18px 18px / 58px 58px,
        linear-gradient(#cfd8ea 0 0) 92px 18px / 58px 58px,
        linear-gradient(#cfd8ea 0 0) 166px 18px / 58px 58px;
    background-repeat: no-repeat;
}
.thumb::after {
    inset: auto 0 0;
    height: 56px;
    background:
        linear-gradient(90deg, rgba(124,58,237,0.88), rgba(168,85,247,0.88)) 14px 14px / 110px 28px,
        linear-gradient(90deg, rgba(37,99,235,0.8), rgba(56,189,248,0.8)) 138px 14px / 74px 28px,
        linear-gradient(90deg, rgba(251,146,60,0.8), rgba(249,115,22,0.8)) 226px 14px / 64px 28px;
    background-repeat: no-repeat;
}
.project .body { padding: 18px 20px 20px; }
.tag {
    display: inline-flex;
    margin-top: -24px;
    position: relative;
    padding: 7px 12px;
    border-radius: 999px;
    background: linear-gradient(135deg, #a855f7, #7c3aed);
    font-size: 0.82rem;
    font-weight: 800;
    box-shadow: 0 10px 20px rgba(124, 58, 237, 0.25);
}

.stats { margin-top: 26px; }
.stat {
    padding: 22px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    min-height: 110px;
}
.stat strong { display: block; font-size: 1.9rem; color: #c084fc; }
.stat span { color: var(--muted); font-weight: 700; }

.about-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 18px; }
.about-card { padding: 28px; }
.eyebrow { color: #d8b4fe; font-weight: 800; margin-bottom: 12px; }
.about-card h2 { margin: 0 0 12px; font-size: clamp(1.8rem, 3vw, 2.6rem); line-height: 1.3; }
.about-points { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.about-points span {
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(124, 58, 237, 0.12);
    border: 1px solid rgba(255,255,255,0.08);
}
.about-side { display: grid; gap: 12px; align-content: center; }
.mini-stat {
    padding: 18px 20px;
    border-radius: 18px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
}
.mini-stat strong { display: block; font-size: 1.7rem; color: #c084fc; }
.mini-stat span { color: var(--muted); }

.contact-card { padding: 28px; }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 18px; }
.contact-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    border-radius: 18px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    margin-bottom: 12px;
}
.contact-item strong { display: block; }
.contact-item span { color: var(--muted); }
.contact-form { display: grid; gap: 12px; }
.contact-form input, .contact-form textarea {
    width: 100%;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(7, 10, 22, 0.72);
    color: var(--text);
    border-radius: 16px;
    padding: 14px 16px;
    font: inherit;
    outline: none;
}
.contact-form textarea { resize: vertical; min-height: 150px; }

footer {
    margin-top: 36px;
    padding: 22px 0 34px;
}
.footer-panel { padding: 30px; }
.footer-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr 1fr;
    gap: 24px;
    align-items: start;
}
.footer-col h4 { margin: 0 0 14px; font-size: 1.35rem; }
.footer-col p, .footer-col a { color: var(--muted); line-height: 2; }
.divider { height: 1px; background: rgba(255,255,255,0.08); margin: 30px 0; }
.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    color: var(--muted);
    flex-wrap: wrap;
}
.mini { display: inline-flex; align-items: center; gap: 8px; color: #ece7ff; font-weight: 800; }

/* Project detail page */
.project-detail.hero {
    padding: 30px 0 20px;
}

.project-breadcrumbs {
    display: flex;
    gap: 10px;
    align-items: center;
    color: var(--muted);
    font-size: 0.95rem;
    margin-bottom: 18px;
    justify-content: flex-start;
}
.project-breadcrumbs strong { color: #eeeaf8; font-weight: 600; }

.project-hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 30px;
    align-items: center;
    min-height: 640px;
    direction: ltr;
}
.project-hero-grid > * { direction: rtl; }

.project-visual-card {
    position: relative;
    min-height: 520px;
}

.project-device {
    position: absolute;
    background: linear-gradient(180deg, rgba(16, 20, 39, 0.97), rgba(10, 12, 25, 0.98));
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: var(--shadow);
}
.project-image-frame,
.project-phone-image {
    background-size: cover;
    background-position: center;
    overflow: hidden;
}
.project-image-labels {
    position: absolute;
    inset: auto 18px 18px 18px;
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(9, 12, 24, 0.48);
    border: 1px solid rgba(255,255,255,0.12);
    backdrop-filter: blur(16px);
}
.project-image-labels span {
    color: #d8b4fe;
    font-size: .8rem;
    font-weight: 800;
}
.project-image-labels strong {
    color: #fff;
    font-size: 1.05rem;
    line-height: 1.4;
}

.project-screen-lg {
    left: 8px;
    top: 24px;
    width: 100%;
    height: 356px;
    border-radius: 22px;
    padding: 18px;
}

.project-ui {
    display: grid;
    grid-template-columns: 74px 1fr;
    height: 100%;
    gap: 14px;
}

.project-sidebar {
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(124,58,237,0.9), rgba(124,58,237,0.12)) 18px 20px/36px 10px,
        linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
    background-repeat: no-repeat;
    opacity: .95;
}

.project-canvas {
    border-radius: 14px;
    background: linear-gradient(180deg, #f8f9fd, #eef2fb);
    padding: 18px;
    display: grid;
    grid-template-rows: 18px auto 1fr 72px;
    gap: 16px;
}
.project-topbar { border-radius: 999px; background: #dfe4f3; height: 18px; }
.project-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.project-metrics span { display: block; height: 64px; border-radius: 12px; background: linear-gradient(180deg, #fff, #e8edf8); }
.project-chart { border-radius: 12px; background: linear-gradient(180deg, #fff, #e7ebf8); position: relative; }
.project-chart::before {
    content: '';
    position: absolute;
    inset: 16px;
    border-radius: 10px;
    background:
        linear-gradient(#2f68ff 0 0) 14px 70px / 140px 4px,
        linear-gradient(#8b5cf6 0 0) 14px 54px / 170px 4px,
        linear-gradient(#22c55e 0 0) 14px 38px / 110px 4px,
        linear-gradient(#d1d5db 0 0) 14px 22px / 180px 1px,
        linear-gradient(#d1d5db 0 0) 14px 48px / 180px 1px,
        linear-gradient(#d1d5db 0 0) 14px 74px / 180px 1px;
    background-repeat: no-repeat;
    opacity: .9;
}
.project-table { border-radius: 12px; background: linear-gradient(180deg, #fff, #e7ebf8); }

.project-phone {
    right: 18px;
    bottom: 0;
    width: 156px;
    height: 286px;
    border-radius: 24px;
    padding: 11px;
}
.project-phone-image {
    background-size: cover;
    background-position: center;
}
.phone-ui { height: 100%; border-radius: 16px; background: linear-gradient(180deg, #111427, #0a0d19); padding: 12px; }
.phone-header { height: 56px; border-radius: 12px; background: linear-gradient(180deg, #7c3aed, #4f46e5); margin-bottom: 12px; }
.phone-list { display: grid; gap: 8px; }
.phone-list span { height: 18px; border-radius: 999px; background: rgba(255,255,255,0.12); }

.project-copy h1 { margin-top: 8px; font-size: clamp(2.6rem, 4.1vw, 4.4rem); line-height: 1.05; letter-spacing: -.02em; }
.project-copy { text-align: right; }
.project-copy .lead { max-width: 640px; font-size: 1.03rem; line-height: 1.95; color: #d8d6ea; }
.project-title-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
}
.project-title-row h1 { margin: 0; }
.project-icon-bubble {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(124,58,237,0.18);
    border: 1px solid rgba(168,85,247,0.18);
    box-shadow: 0 20px 50px rgba(91,33,182,0.18), 0 0 0 12px rgba(124,58,237,0.05);
    font-size: 1.25rem;
    flex-shrink: 0;
}
.project-icon-bubble svg,
.meta-card-icon svg,
.feature-card .iconbox svg,
.project-actions .icon-only svg {
    width: 22px;
    height: 22px;
    display: block;
}

.project-meta-grid {
    margin-top: 20px;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}
.meta-card {
    padding: 15px 16px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.09);
    display: grid;
    gap: 9px;
    min-height: 108px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.meta-card-icon {
    width: 32px;
    height: 32px;
    border-radius: 11px;
    display: grid;
    place-items: center;
    color: #d8b4fe;
    background: rgba(124,58,237,0.14);
    border: 1px solid rgba(168,85,247,0.16);
}
.meta-card strong { display: block; font-size: .8rem; color: #e6defb; margin-bottom: 2px; }
.meta-card span { color: var(--muted); }

.project-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 22px;
}
.project-actions .icon-only { width: 54px; padding-inline: 0; }

.project-tabs { border-top: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.tabs-row {
    display: flex;
    gap: 24px;
    overflow-x: auto;
    padding: 14px 0;
    white-space: nowrap;
}
.tabs-row a { padding: 10px 4px; color: var(--muted); position: relative; font-weight: 700; }
.tabs-row a.active { color: var(--text); }
.tabs-row a.active::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -12px;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, var(--accent-3), transparent);
}

.overview-grid, .tech-grid {
    display: grid;
    grid-template-columns: .95fr 1.05fr;
    gap: 18px;
    align-items: start;
    direction: ltr;
}
.overview-grid > *, .tech-grid > * { direction: rtl; }

.overview-card, .tech-card, .price-card, .cta-band, .feature-card, .gallery-shot {
    background: linear-gradient(180deg, var(--surface-2), rgba(12, 16, 33, 0.78));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.overview-card { padding: 26px; }
.overview-card h2, .tech-card h2, .price-card h2, .cta-band h2 { margin-top: 0; }
.overview-card h2, .tech-card h2, .price-card h2 { font-size: 1.8rem; }
.overview-highlight {
    margin-top: 10px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(124,58,237,0.14);
    background: linear-gradient(180deg, rgba(124,58,237,0.12), rgba(255,255,255,0.03));
    color: #ece7ff;
    line-height: 1.85;
    font-weight: 700;
}
.overview-card p { color: var(--muted); line-height: 2; }
.check-list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 10px; }
.check-list li { position: relative; padding-right: 26px; color: #e7eaf5; line-height: 1.8; }
.check-list li::before { content: '✓'; position: absolute; right: 0; top: 0; color: #c084fc; }
.check-list.compact li { color: var(--muted); }

.overview-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 18px; }
.overview-stats div { padding: 14px 16px; border-radius: 14px; background: rgba(255,255,255,0.04); }
.overview-stats strong { display: block; color: #c084fc; font-size: 1.7rem; }
.overview-stats span { color: var(--muted); }

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}
.feature-card { padding: 22px; min-height: 162px; align-content: start; }
.feature-card .iconbox { width: 50px; height: 50px; font-size: 1.2rem; margin-bottom: 14px; }
.feature-card h3 { margin: 0 0 10px; font-size: 1.05rem; }
.feature-card p { margin: 0; color: var(--muted); line-height: 1.8; }

.gallery-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.gallery-shot { padding: 18px; }
.shot-thumb {
    height: 200px;
    border-radius: 16px;
    background: linear-gradient(180deg, #fff, #eef2fb);
    position: relative;
    overflow: hidden;
}
.shot-thumb.is-image {
    background-size: cover;
    background-position: center;
}
.shot-thumb.is-image::before {
    display: none;
}
.thumb.is-image::before,
.thumb.is-image::after {
    display: none;
}
.shot-thumb::before { content: ''; position: absolute; inset: 16px; border-radius: 12px; background: linear-gradient(#dfe4f3 0 0) 0 0 / 100% 24px, linear-gradient(#cfd6ea 0 0) 0 34px / 100% 1px, linear-gradient(#cfd6ea 0 0) 0 58px / 100% 1px, linear-gradient(#cfd6ea 0 0) 0 82px / 100% 1px, linear-gradient(#7c3aed 0 0) 14px 106px / 82px 32px, linear-gradient(#2f68ff 0 0) 108px 106px / 74px 32px; background-repeat: no-repeat; }
.shot-thumb.alt::before { background: linear-gradient(#dfe4f3 0 0) 0 0 / 100% 24px, linear-gradient(#cfd6ea 0 0) 0 34px / 100% 1px, linear-gradient(#cfd6ea 0 0) 0 58px / 100% 1px, linear-gradient(#7c3aed 0 0) 16px 106px / 114px 32px, linear-gradient(#2f68ff 0 0) 142px 106px / 58px 32px; background-repeat: no-repeat; }
.shot-thumb.third::before { background: linear-gradient(#dfe4f3 0 0) 0 0 / 100% 24px, linear-gradient(#cfd6ea 0 0) 0 34px / 100% 1px, linear-gradient(#cfd6ea 0 0) 0 58px / 100% 1px, linear-gradient(#22c55e 0 0) 14px 106px / 82px 32px, linear-gradient(#f59e0b 0 0) 108px 106px / 74px 32px; background-repeat: no-repeat; }
.shot-thumb.fourth::before { background: linear-gradient(#dfe4f3 0 0) 0 0 / 100% 24px, linear-gradient(#cfd6ea 0 0) 0 34px / 100% 1px, linear-gradient(#cfd6ea 0 0) 0 58px / 100% 1px, linear-gradient(#f97316 0 0) 14px 106px / 82px 32px, linear-gradient(#7c3aed 0 0) 108px 106px / 74px 32px; background-repeat: no-repeat; }
.gallery-shot span { display: block; margin-top: 10px; color: var(--text); font-weight: 700; }

.gallery-controls {
    margin-top: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
}
.gallery-controls button {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 0;
    background: var(--accent);
    color: white;
    font-size: 1.2rem;
}
.projects-index-page { padding-top: 34px; }
.courses-index-page { padding-top: 34px; }
.courses-hero {
    display: grid;
    grid-template-columns: 1.3fr .9fr;
    gap: 18px;
    align-items: start;
    margin-bottom: 22px;
}
.courses-hero h1 { margin-top: 6px; }
.courses-hero-actions { margin-top: 18px; }
.courses-hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.courses-results-top {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 18px 0 14px;
}
.courses-grid { margin-top: 14px; }
.course-card { overflow: hidden; }
.course-thumb {
    min-height: 220px;
    background: linear-gradient(135deg, rgba(124,58,237,0.24), rgba(249,115,22,0.18));
}
.course-thumb::before {
    content: '';
    position: absolute;
    inset: 16px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.09);
    background:
        radial-gradient(circle at 24% 28%, rgba(255,255,255,0.18), transparent 18%),
        radial-gradient(circle at 78% 18%, rgba(255,255,255,0.18), transparent 16%),
        linear-gradient(135deg, rgba(17,24,39,0.16), rgba(17,24,39,0.42));
}
.course-card .body { padding: 18px 20px 20px; }
.course-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.tag-violet { background: rgba(168,85,247,0.18); color: #f3e8ff; }
.tag-orange { background: rgba(249,115,22,0.18); color: #ffedd5; }
.tag-teal { background: rgba(20,184,166,0.18); color: #ccfbf1; }
.course-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
    color: #d8def0;
    font-size: .82rem;
}
.course-meta span {
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
}
.course-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 18px;
}
.course-actions strong { color: #f5f3ff; font-size: 1rem; }
.courses-empty { padding: 32px; text-align: center; }
.course-card-link {
    display: block;
    color: inherit;
    text-decoration: none;
}
.course-show-page { padding-top: 34px; }
.course-hero {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 18px;
    margin-bottom: 22px;
    align-items: stretch;
}
.course-live-hero {
    display: grid;
    grid-template-columns: .94fr 1.06fr;
    gap: 18px;
    align-items: stretch;
    direction: ltr;
    margin-bottom: 18px;
}
.course-live-hero > * { direction: rtl; }
.course-hero-image {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    min-height: 550px;
    background: linear-gradient(135deg, rgba(124,58,237,0.12), rgba(17,24,39,0.04));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}
.course-live-badge {
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 2;
    padding: 8px 12px;
    border-radius: 10px;
    background: #ef4444;
    color: #fff;
    font-size: .84rem;
    font-weight: 900;
    letter-spacing: .04em;
}
.course-live-thumb { height: 100%; min-height: 550px; }
.course-image-footer {
    position: absolute;
    inset-inline: 14px;
    bottom: 14px;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.course-image-footer span {
    padding: 9px 11px;
    border-radius: 12px;
    background: rgba(8, 12, 26, 0.72);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.08);
    font-size: .82rem;
    font-weight: 700;
}
.course-live-copy {
    display: grid;
    gap: 14px;
    align-content: start;
    padding: 26px 4px 20px;
}
.course-live-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}
.course-live-inline-note {
    color: #8b5cf6;
    font-weight: 800;
    font-size: .9rem;
}
.course-live-copy h1 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.7rem);
    line-height: 1.08;
    letter-spacing: -.03em;
}
.course-live-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.course-live-metrics .meta-card { min-height: 96px; }
.course-live-price-row {
    display: flex;
    align-items: baseline;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 2px;
    justify-content: flex-start;
}
.course-live-price {
    font-size: 2.25rem;
    font-weight: 900;
    color: #6d28d9;
}
.course-live-price-caption { color: #5b6478; font-weight: 700; }
.course-live-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.course-live-pdf-row {
    display: flex;
    justify-content: flex-start;
    margin-top: 4px;
}
.course-live-actions {
    margin-top: 10px;
    justify-content: flex-start;
    align-self: start;
}
.course-live-actions .btn { width: auto; }
.course-info-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    padding: 16px;
    margin-bottom: 16px;
    direction: rtl;
}
.course-info-card {
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(124,58,237,0.04);
    border: 1px solid rgba(124,58,237,0.08);
    display: grid;
    gap: 6px;
    direction: rtl;
    text-align: right;
}
.course-info-label {
    color: #a78bfa;
    font-size: .82rem;
    font-weight: 800;
}
.course-info-card strong {
    font-size: 1.05rem;
    color: #f8fafc;
}
.course-info-card span {
    color: #d8def0;
}
.course-cards-grid {
    display: grid;
    grid-template-columns: .84fr 1.08fr 1.08fr;
    grid-template-areas: 'teacher learn outcomes';
    gap: 16px;
    margin-bottom: 16px;
    direction: ltr;
    align-items: start;
}
.course-cards-grid .course-teacher-card,
.course-cards-grid .course-panel-card {
    min-height: 100%;
}
.course-teacher-stack {
    display: grid;
    gap: 16px;
    align-self: start;
}
.course-teacher-stack,
.course-teacher-card,
.course-description-card,
.course-panel-card,
.course-outline-card,
.course-sessions-card {
    direction: rtl;
    text-align: right;
}
.course-area-teacher { grid-area: teacher; }
.course-area-learn { grid-area: learn; }
.course-area-outcomes { grid-area: outcomes; }
.course-area-requirements { grid-area: outline; }
.course-bottom-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: 'sessions outline';
    gap: 16px;
    direction: ltr;
    align-items: start;
}
.course-area-sessions { grid-area: sessions; }
.course-area-videos { grid-area: sessions; }
.course-area-sections { grid-area: outline; }
.course-outline-card {
    padding: 22px;
}
.course-description-card {
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(124,58,237,0.12);
    background: linear-gradient(180deg, rgba(13, 17, 41, 0.94), rgba(10, 13, 31, 0.94));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.course-description-panel {
    position: relative;
    min-height: 310px;
    padding: 26px 24px 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    text-align: center;
}
.course-description-kicker {
    align-self: flex-start;
    color: #c4b5fd;
    font-size: .86rem;
    font-weight: 800;
    margin-bottom: 6px;
}
.course-description-panel h2 {
    margin: 0 0 14px;
    font-size: clamp(2.35rem, 3.4vw, 3.35rem);
    line-height: 1.05;
    color: #f8fafc;
    font-weight: 900;
}
.course-teacher-detail-card {
    padding: 22px;
}
.course-teacher-detail-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.course-teacher-detail-grid div {
    padding: 14px;
    border-radius: 16px;
    background: rgba(124,58,237,0.04);
    border: 1px solid rgba(124,58,237,0.08);
    direction: rtl;
    text-align: right;
}
.course-teacher-detail-grid span {
    display: block;
    color: #a78bfa;
    font-size: .8rem;
    font-weight: 800;
    margin-bottom: 6px;
}
.course-teacher-detail-grid strong {
    color: #f8fafc;
    font-size: .96rem;
}
.course-recorded-accordion-wrap {
    margin-bottom: 16px;
}
.course-recorded-layout-grid {
    display: grid;
    grid-template-columns: .62fr 1.38fr;
    gap: 16px;
    align-items: start;
}
.course-recorded-accordion-card {
    padding: 22px;
}
.course-requirements-card {
    padding: 22px;
    align-self: start;
}
.course-accordion-list {
    display: grid;
    gap: 10px;
}
.course-accordion-item {
    overflow: hidden;
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(124,58,237,0.08);
}
.course-accordion-item[open] {
    background: rgba(124,58,237,0.05);
}
.course-accordion-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    color: #f5f3ff;
    font-weight: 800;
    user-select: none;
}
.course-accordion-summary::-webkit-details-marker { display: none; }
.course-accordion-summary::after {
    content: '⌃';
    color: #c084fc;
    font-size: 1.1rem;
    line-height: 1;
    transition: transform .18s ease;
}
.course-accordion-item:not([open]) .course-accordion-summary::after {
    transform: rotate(180deg);
}
.course-accordion-title {
    font-size: .98rem;
}
.course-accordion-meta {
    color: #c4b5fd;
    font-size: .82rem;
    font-weight: 800;
    white-space: nowrap;
}
.course-accordion-body {
    border-top: 1px solid rgba(255,255,255,0.06);
    padding: 8px 0 10px;
}
.course-requirements-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
}
.course-requirements-list li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 11px 16px;
    align-items: start;
}
.course-requirements-card .course-requirements-list li {
    padding-inline: 12px;
}
.course-lesson-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 11px 16px;
    align-items: start;
}
.course-lesson-row + .course-lesson-row {
    border-top: 1px solid rgba(255,255,255,0.04);
}
.course-lesson-index {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(168,85,247,0.16);
    border: 1px solid rgba(168,85,247,0.22);
    color: #f3e8ff;
    font-size: .82rem;
    font-weight: 900;
    flex-shrink: 0;
}
.course-lesson-copy {
    display: grid;
    gap: 4px;
    direction: rtl;
    text-align: right;
}
.course-lesson-copy strong {
    color: #f8fafc;
    font-size: .94rem;
    line-height: 1.55;
}
.course-lesson-copy span {
    color: #c7d2fe;
    font-size: .82rem;
    font-weight: 700;
}
.course-description-text {
    margin: 0;
    max-width: 480px;
    color: #d7def5;
    line-height: 1.95;
    font-size: .9rem;
    white-space: pre-line;
    direction: rtl;
    text-align: center;
    position: relative;
    z-index: 2;
}
.course-description-art {
    position: relative;
    width: 100%;
    min-height: 146px;
    margin-top: auto;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.course-description-glow {
    position: absolute;
    bottom: 10px;
    width: 260px;
    height: 110px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(168,85,247,0.42), transparent 70%);
    filter: blur(4px);
}
.course-description-ray {
    position: absolute;
    bottom: 34px;
    height: 4px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(168,85,247,0.35), rgba(124,58,237,0.9), rgba(168,85,247,0.35), transparent);
    filter: blur(.2px);
    opacity: .8;
}
.course-description-ray-left {
    left: 10px;
    width: 86px;
    transform: rotate(-20deg);
    transform-origin: left center;
}
.course-description-ray-right {
    right: 10px;
    width: 86px;
    transform: rotate(18deg);
    transform-origin: right center;
}
.course-description-orb {
    position: absolute;
    bottom: 28px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(168,85,247,0.26);
    box-shadow: 0 0 22px rgba(168,85,247,0.42);
}
.course-description-orb-left { left: 36%; }
.course-description-orb-right { right: 36%; }
.course-description-folder {
    position: relative;
    z-index: 2;
    width: 140px;
    height: 92px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(130,55,240,0.98), rgba(92,30,181,0.96));
    border: 1px solid rgba(196,132,255,0.26);
    display: grid;
    place-items: center;
    box-shadow: 0 18px 42px rgba(124,58,237,0.26), inset 0 1px 0 rgba(255,255,255,0.12);
}
.course-description-folder-back {
    position: absolute;
    bottom: 30px;
    width: 110px;
    height: 74px;
    left: calc(50% - 68px);
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(99,32,196,0.65), rgba(63,20,125,0.72));
    border-color: rgba(196,132,255,0.14);
    opacity: .9;
}
.course-description-folder-front span {
    font-size: 2.2rem;
    font-weight: 900;
    color: #f9f5ff;
    text-shadow: 0 0 18px rgba(255,255,255,0.2);
    letter-spacing: -0.02em;
}
.course-outline-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}
.course-outline-list li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    background: rgba(124,58,237,0.03);
    border: 1px solid rgba(124,58,237,0.08);
    direction: rtl;
    text-align: right;
}
.course-outline-index {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: rgba(124,58,237,0.12);
    color: #6d28d9;
    font-weight: 900;
    font-size: .85rem;
}
.course-outline-list strong { color: #111827; }
.course-outline-list p { margin: 4px 0 0; color: #5b6478; }
.course-outline-footer { margin-top: 18px; }
.course-recorded-layout {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 18px;
    align-items: stretch;
}
.course-recorded-main { padding: 8px 4px; }
.course-recorded-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }
.course-recorded-side .course-thumb { min-height: 360px; }
.course-hero-visual .course-thumb { min-height: 100%; height: 100%; }
.course-hero-copy { display: grid; gap: 14px; align-content: start; }
.course-hero-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.course-meta-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-top: 4px; }
.course-meta-grid .meta-card { min-height: 94px; }
.course-details-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.course-live-grid {
    display: grid;
    grid-template-columns: .98fr 1.02fr;
    gap: 16px;
    margin-bottom: 16px;
}
.course-live-grid .course-teacher-card { grid-row: span 1; }
.course-teacher-head {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 14px;
    direction: ltr;
}
.course-teacher-head > div:last-child {
    direction: rtl;
    text-align: right;
}
.course-teacher-avatar {
    width: 84px;
    height: 84px;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(124,58,237,0.26), rgba(249,115,22,0.18));
    display: grid;
    place-items: center;
    border: 1px solid rgba(255,255,255,0.08);
}
.course-teacher-avatar img { width: 100%; height: 100%; object-fit: cover; }
.course-teacher-avatar span { font-size: 2rem; font-weight: 900; color: #fff; }
.course-teacher-card-hero {
    padding: 24px 24px 22px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(13, 17, 41, 0.98), rgba(10, 13, 31, 0.96));
    border: 1px solid rgba(124,58,237,0.14);
}
.course-teacher-card-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 18% 18%, rgba(124,58,237,0.12), transparent 34%), radial-gradient(circle at 82% 26%, rgba(168,85,247,0.1), transparent 30%);
    pointer-events: none;
}
.course-teacher-card-top {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    direction: ltr;
}
.course-teacher-avatar-hero {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    position: relative;
    border: 2px solid rgba(196,132,255,0.65);
    box-shadow: 0 0 0 7px rgba(124,58,237,0.08), 0 20px 40px rgba(0,0,0,0.25);
    background: radial-gradient(circle at 50% 35%, rgba(124,58,237,0.22), rgba(12, 16, 36, 0.95) 70%);
}
.course-teacher-avatar-hero img { width: 100%; height: 100%; object-fit: cover; }
.course-teacher-avatar-badge {
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(34, 16, 68, 0.92);
    border: 1px solid rgba(196,132,255,0.22);
    color: #f5f3ff;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .02em;
}
.course-teacher-card-copy {
    position: relative;
    z-index: 1;
    direction: rtl;
    text-align: right;
    padding-top: 8px;
}
.course-teacher-card-copy .eyebrow {
    font-size: .86rem;
    margin-bottom: 8px;
}
.course-teacher-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
}
.course-teacher-chip {
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(124,58,237,0.10);
    border: 1px solid rgba(168,85,247,0.14);
    color: #e9d5ff;
    font-size: .8rem;
    font-weight: 800;
}
.course-panel-card { padding: 22px; }
.course-sessions-card { padding: 22px; }
.course-videos-card { padding: 22px; }
.course-panel-card .section-head,
.course-outline-card .section-head,
.course-sessions-card .section-head,
.course-videos-card .section-head {
    margin-bottom: 18px;
}
.course-panel-card .section-head h2,
.course-outline-card .section-head h2,
.course-sessions-card .section-head h2,
.course-videos-card .section-head h2 {
    font-size: 1.55rem;
}
.course-teacher-card h2 {
    margin: 0;
    font-size: 1.95rem;
    line-height: 1.08;
}
.course-teacher-card .admin-muted {
    font-size: .92rem;
    line-height: 1.7;
}
.course-teacher-role {
    margin: 0 0 6px;
    color: #d8b4fe;
    font-size: .98rem;
    font-weight: 800;
}
.course-teacher-summary {
    margin: 0;
    color: #c7d2fe;
    font-size: .9rem;
    line-height: 1.75;
}
.course-teacher-points {
    list-style: none;
    padding: 14px 0 0;
    margin: 14px 0 0;
    display: grid;
    gap: 12px;
    border-top: 1px solid rgba(255,255,255,0.06);
    position: relative;
    z-index: 1;
}
.course-teacher-points li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    color: #e5e7ff;
    font-size: .92rem;
    line-height: 1.6;
}
.course-teacher-point-icon {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #d8b4fe;
    font-weight: 900;
    flex-shrink: 0;
}
.course-sessions-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}
.course-session-count {
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(124,58,237,0.14);
    border: 1px solid rgba(168,85,247,0.16);
    color: #e9d5ff;
    font-weight: 800;
}
.course-sessions-table-wrap { overflow-x: auto; }
.course-sessions-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 640px;
}
.course-sessions-table th,
.course-sessions-table td {
    padding: 12px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    text-align: right;
    direction: rtl;
}
.course-sessions-table th { color: #e9d5ff; font-size: .85rem; }
.course-sessions-table td { color: #e8ecf7; }
.course-sessions-table tbody tr:hover { background: rgba(255,255,255,0.03); }
.course-videos-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
}
.course-videos-list li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    background: rgba(124,58,237,0.03);
    border: 1px solid rgba(124,58,237,0.08);
    direction: rtl;
    text-align: right;
}
.course-videos-list strong { color: #f5f3ff; }
.course-videos-list p { margin: 4px 0 0; color: var(--muted); }
.course-detail-panel { padding: 22px; }
.course-sections-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
}
.course-sections-list li {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    display: grid;
    gap: 4px;
}
.course-sections-list strong { color: #f5f3ff; }
.course-sections-list span { color: var(--muted); }
.projects-filters {
    display: grid;
    grid-template-columns: 1.2fr .7fr auto auto;
    gap: 14px;
    align-items: end;
    margin-bottom: 22px;
}
.projects-filters label span {
    display: block;
    margin-bottom: 6px;
    color: #eae7f9;
    font-weight: 700;
    font-size: .85rem;
}
.projects-filter-check {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 0 12px;
}
.projects-filter-check input { width: 18px; height: 18px; accent-color: var(--accent-2); }
.projects-filter-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.projects-results-top {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 18px 0 14px;
}
.projects-results-top strong { font-size: 1.05rem; }
.projects-empty { padding: 32px; text-align: center; }
.projects-home-grid { margin-top: 8px; }
.projects-index-grid { margin-top: 14px; }
.gallery-dots { display: flex; gap: 8px; }
.gallery-dots span {
    width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.18);
}
.gallery-dots span.active { background: var(--accent-3); width: 24px; border-radius: 999px; }

.tech-card { padding: 28px; }
.tech-logos, .tech-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
}
.tech-logos span, .tech-tags span, .price-card .btn {
    padding: 12px 15px;
    border-radius: 14px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
}
.tech-logos span { min-width: 92px; text-align: center; font-weight: 700; color: #e8eaf7; }
.tech-tags span { color: #e9defe; }

.tech-card {
    position: relative;
    overflow: hidden;
}
.tech-card::before {
    content: '';
    position: absolute;
    inset: auto -12% -24% auto;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(124,58,237,0.18), transparent 60%);
    pointer-events: none;
}

.price-card { padding: 28px; display: grid; gap: 16px; align-content: start; }
.price { font-size: 3.1rem; font-weight: 900; color: #f5f3ff; }
.price-card .btn { width: 100%; }
.tech-grid { align-items: stretch; }
.price-card { min-height: 100%; }

.tech-logos { margin-bottom: 8px; }
.tech-note {
    margin: 16px 0 0;
    color: var(--muted);
    line-height: 1.9;
}

.price-label {
    display: inline-flex;
    align-self: start;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(124,58,237,0.12);
    border: 1px solid rgba(168,85,247,0.16);
    color: #e9defe;
    font-size: .8rem;
    font-weight: 800;
}
.price-card .price { margin-top: -2px; }
.price-card .check-list { margin-top: 4px; }
.price-card .btn:first-of-type { margin-top: 4px; }

.price-card {
    position: relative;
    overflow: hidden;
}
.price-card::before {
    content: '';
    position: absolute;
    inset: -20% auto auto -18%;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(168,85,247,0.15), transparent 64%);
    pointer-events: none;
}

.cta-band {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 28px 30px;
}
.cta-band h2 { margin: 0 0 8px; }
.cta-band p { margin: 0; color: var(--muted); }

.access-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.access-card {
    padding: 22px;
    border-radius: var(--radius);
    background: linear-gradient(180deg, var(--surface-2), rgba(12, 16, 33, 0.78));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow);
    display: grid;
    gap: 18px;
}
.access-card-wide { grid-column: span 2; }
.access-top {
    display: flex;
    align-items: center;
    gap: 16px;
}
.access-icon {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    background: rgba(124,58,237,0.16);
    border: 1px solid rgba(168,85,247,0.18);
    color: #d8b4fe;
    flex-shrink: 0;
}
.access-icon svg { width: 22px; height: 22px; display: block; }
.access-top h3 { margin: 0; font-size: 1.08rem; }
.access-top p { margin: 4px 0 0; color: var(--muted); line-height: 1.65; }
.access-link {
    display: inline-flex;
    width: fit-content;
    padding: 13px 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #ece7ff;
    font-weight: 800;
    word-break: break-all;
}
.credential-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.credential-row {
    padding: 16px;
    border-radius: 18px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
}
.credential-row span {
    display: block;
    color: var(--muted);
    font-size: .86rem;
    margin-bottom: 8px;
}
.credential-row strong {
    color: #f7f2ff;
    font-size: 1.02rem;
}
.access-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.access-tags span {
    padding: 10px 13px;
    border-radius: 999px;
    background: rgba(124,58,237,0.12);
    border: 1px solid rgba(168,85,247,0.16);
    color: #efe5ff;
    font-weight: 700;
}
.access-note {
    margin: 14px 4px 0;
    color: var(--muted);
    text-align: center;
}

.login-grid {
    grid-template-columns: 1fr;
}
.login-hero-card {
    padding: 24px;
}
.login-hero-card .access-top {
    margin-bottom: 14px;
}
.login-hero-card .access-top h3 {
    font-size: 1.15rem;
}
.login-hero-card .access-top p {
    margin-top: 4px;
}
.login-hero-card .credential-grid {
    margin-top: 0;
}

.faq-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.faq-card {
    padding: 20px 22px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(17, 20, 39, 0.92), rgba(12, 16, 33, 0.86));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow);
}
.faq-question {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}
.faq-index {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: rgba(124,58,237,0.16);
    border: 1px solid rgba(168,85,247,0.18);
    color: #eadcff;
    font-size: .75rem;
    font-weight: 900;
    flex-shrink: 0;
}
.faq-question strong {
    color: #f4f0ff;
    font-size: 1rem;
    line-height: 1.5;
}
.faq-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.9;
}
.faq-cta {
    margin-top: 16px;
}

/* Admin */
.admin-shell {
    min-height: 100vh;
    padding: 24px 0;
}
.admin-layout {
    min-height: 100vh;
    display: grid;
    grid-template-columns: clamp(224px, 18vw, 268px) minmax(0, 1fr);
    background: radial-gradient(circle at 80% 0%, rgba(168,85,247,0.14), transparent 22%), radial-gradient(circle at 15% 0%, rgba(59,130,246,0.08), transparent 18%), linear-gradient(180deg, #040611 0%, #050816 100%);
    transition: grid-template-columns .22s ease;
}
.admin-sidebar {
    position: sticky;
    top: 24px;
    height: calc(100vh - 48px);
    overflow: hidden;
    padding: 12px 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    background:
        radial-gradient(circle at 20% 0%, rgba(56,189,248,0.10), transparent 24%),
        radial-gradient(circle at 72% 0%, rgba(168,85,247,0.16), transparent 28%),
        linear-gradient(180deg, rgba(9, 12, 27, 0.96), rgba(6, 8, 18, 0.99));
    border-left: 1px solid rgba(168,85,247,0.10);
    box-shadow: inset -1px 0 0 rgba(255,255,255,0.03), -16px 0 48px rgba(0,0,0,0.20);
    backdrop-filter: blur(18px);
    transition: width .22s ease, padding .22s ease, box-shadow .22s ease;
}
.admin-sidebar::before,
.admin-sidebar::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 24px;
    pointer-events: none;
    z-index: 3;
}
.admin-sidebar::before {
    top: 0;
    background: linear-gradient(180deg, rgba(4,6,17,0.94), rgba(4,6,17,0));
}
.admin-sidebar::after {
    bottom: 0;
    background: linear-gradient(0deg, rgba(4,6,17,0.94), rgba(4,6,17,0));
}
.admin-sidebar-collapsed .admin-layout {
    grid-template-columns: 52px minmax(0, 1fr);
}
.admin-sidebar-collapsed .admin-sidebar {
    width: 52px;
}
.admin-sidebar-collapsed .admin-sidebar::before,
.admin-sidebar-collapsed .admin-sidebar::after {
    height: 14px;
}
.admin-sidebar-collapsed .admin-sidebar-head-row {
    justify-content: center;
}
.admin-sidebar-collapsed .admin-sidebar {
    overflow: visible;
}
.admin-sidebar-collapsed .admin-brand .brand-text,
.admin-sidebar-collapsed .admin-sidebar-note,
.admin-sidebar-collapsed .admin-sidebar-panel .admin-sidebar-label,
.admin-sidebar-collapsed .admin-nav-title,
.admin-sidebar-collapsed .admin-sidebar-footer p,
.admin-sidebar-collapsed .admin-nav-main span:last-child {
    display: none;
}
.admin-sidebar-collapsed .admin-sidebar-brand {
    grid-template-columns: 34px;
    justify-content: center;
    justify-items: center;
    padding: 8px 6px;
}
.admin-sidebar-collapsed .admin-sidebar-brand-copy,
.admin-sidebar-collapsed .admin-sidebar-brand-badge {
    display: none;
}
.admin-sidebar-collapsed .admin-sidebar-brand-mark {
    width: 34px;
    height: 34px;
    border-radius: 12px;
}
.admin-sidebar-collapsed .admin-sidebar-cta,
.admin-sidebar-collapsed .admin-sidebar-footer .btn {
    justify-content: center;
    padding-inline: 0;
    font-size: 0;
    position: relative;
    overflow: visible;
}
.admin-sidebar-collapsed .admin-sidebar-cta {
    min-height: 34px;
    width: 100%;
    border-radius: 12px;
}
.admin-sidebar-collapsed .admin-sidebar-cta svg,
.admin-sidebar-collapsed .admin-sidebar-footer .btn svg {
    margin: 0;
}
.admin-sidebar-collapsed .admin-sidebar-footer .btn {
    width: 34px;
    min-width: 34px;
    height: 34px;
    border-radius: 12px;
}
.admin-sidebar-collapsed .admin-sidebar,
.admin-sidebar-collapsed .admin-sidebar .admin-sidebar-panel,
.admin-sidebar-collapsed .admin-sidebar .admin-nav-group,
.admin-sidebar-collapsed .admin-sidebar .admin-sidebar-footer {
    padding-left: 4px;
    padding-right: 4px;
}
.admin-sidebar-collapsed .admin-sidebar-panel,
.admin-sidebar-collapsed .admin-nav-group,
.admin-sidebar-collapsed .admin-sidebar-footer,
.admin-sidebar-collapsed .admin-sidebar .admin-brand {
    border-radius: 14px;
}
.admin-sidebar-collapsed .admin-sidebar .admin-brand {
    justify-content: center;
    padding: 6px 4px;
}
.admin-sidebar-collapsed .admin-sidebar .brand-mark {
    width: 32px;
    height: 32px;
    margin-inline: auto;
}
.admin-sidebar-collapsed .admin-sidebar-actions {
    gap: 4px;
    margin-top: 4px;
}
.admin-sidebar-collapsed .admin-sidebar-scroll {
    gap: 4px;
    padding-block: 2px 6px;
}
.admin-sidebar-collapsed .admin-sidebar-panel,
.admin-sidebar-collapsed .admin-nav-group {
    padding: 6px 4px;
}
.admin-sidebar-collapsed .admin-sidebar-footer {
    padding: 6px 4px;
}
.admin-sidebar-collapsed .admin-sidebar-head {
    gap: 4px;
}
.admin-sidebar-collapsed .admin-sidebar-head-row {
    align-items: center;
}
.admin-sidebar-collapsed .admin-sidebar-toggle {
    width: 30px;
    height: 30px;
    border-radius: 10px;
}
.admin-sidebar-collapsed .admin-sidebar-cta::after,
.admin-sidebar-collapsed .admin-sidebar-footer .btn::after {
    content: attr(data-tooltip);
    position: absolute;
    top: 50%;
    inset-inline-end: calc(100% + 12px);
    transform: translateY(-50%) translateX(8px);
    opacity: 0;
    pointer-events: none;
    white-space: nowrap;
    z-index: 999;
    padding: 7px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(8, 11, 24, 0.98);
    color: #fff;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .01em;
    box-shadow: 0 18px 40px rgba(0,0,0,0.36), 0 0 0 1px rgba(168,85,247,0.10) inset;
    transition: opacity .16s ease, transform .16s ease;
}
.admin-sidebar-collapsed .admin-sidebar-cta::before,
.admin-sidebar-collapsed .admin-sidebar-footer .btn::before {
    content: '';
    position: absolute;
    top: 50%;
    inset-inline-end: calc(100% + 6px);
    transform: translateY(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: transparent rgba(8, 11, 24, 0.98) transparent transparent;
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
    z-index: 998;
}
.admin-sidebar-collapsed .admin-sidebar-cta:hover::after,
.admin-sidebar-collapsed .admin-sidebar-cta:focus-visible::after,
.admin-sidebar-collapsed .admin-sidebar-footer .btn:hover::after,
.admin-sidebar-collapsed .admin-sidebar-footer .btn:focus-visible::after,
.admin-sidebar-collapsed .admin-sidebar-cta:hover::before,
.admin-sidebar-collapsed .admin-sidebar-cta:focus-visible::before,
.admin-sidebar-collapsed .admin-sidebar-footer .btn:hover::before,
.admin-sidebar-collapsed .admin-sidebar-footer .btn:focus-visible::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}
.admin-sidebar-collapsed .admin-sidebar-footer {
    gap: 6px;
}
.admin-sidebar-collapsed .admin-sidebar-footer strong {
    font-size: .9rem;
}
.admin-sidebar-collapsed .admin-sidebar-footer .btn {
    padding-inline: 0;
}
.admin-sidebar-scroll {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    display: grid;
    gap: 8px;
    padding-left: 0;
    padding-block: 6px 10px;
    scrollbar-width: thin;
    scrollbar-color: rgba(168,85,247,0.45) transparent;
}
.admin-sidebar-scroll::-webkit-scrollbar {
    width: 8px;
}
.admin-sidebar-scroll::-webkit-scrollbar-track {
    background: transparent;
}
.admin-sidebar-scroll::-webkit-scrollbar-thumb {
    background: rgba(168,85,247,0.35);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}
.admin-sidebar-actions {
    display: grid;
    gap: 7px;
    margin-top: 8px;
}
.admin-content {
    min-width: 0;
    padding: 16px;
}
.admin-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 14px;
    margin-bottom: 12px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(8, 11, 24, 0.82);
    backdrop-filter: blur(18px);
    box-shadow: var(--shadow);
}
.admin-header-copy strong { display: block; font-size: 1rem; }
.admin-header-copy span { color: var(--muted); font-size: .84rem; }
.admin-header-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-sidebar-toggle {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    cursor: pointer;
    flex: 0 0 auto;
}
.admin-sidebar-toggle:hover {
    background: rgba(168,85,247,0.16);
    border-color: rgba(168,85,247,0.28);
    box-shadow: 0 12px 24px rgba(124,58,237,0.12);
}
.admin-sidebar-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    background: #fff;
    border-radius: 999px;
    margin: 2px 0;
}
.admin-sidebar-head {
    display: grid;
    gap: 8px;
    margin-bottom: 0;
}
.admin-sidebar-brand {
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 20px;
    border: 1px solid rgba(168,85,247,0.16);
    background:
        radial-gradient(circle at 0% 0%, rgba(168,85,247,0.18), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.07), 0 18px 34px rgba(0,0,0,0.20);
    position: relative;
    overflow: hidden;
}
.admin-sidebar-brand::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.06) 42%, transparent 58%);
    pointer-events: none;
}
.admin-sidebar-brand-mark {
    width: 50px;
    height: 50px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #8b5cf6, #6d28d9);
    color: #fff;
    font-weight: 900;
    letter-spacing: .04em;
    box-shadow: 0 14px 30px rgba(124,58,237,0.30), inset 0 0 0 1px rgba(255,255,255,0.12);
}
.admin-sidebar-brand-copy {
    min-width: 0;
    display: grid;
    gap: 2px;
}
.admin-sidebar-brand-copy strong {
    color: #fff;
    font-size: 1rem;
    line-height: 1.1;
}
.admin-sidebar-brand-copy span {
    color: var(--muted);
    font-size: .72rem;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.admin-sidebar-brand-badge {
    align-self: start;
    padding: 7px 10px;
    border-radius: 999px;
    border: 1px solid rgba(168,85,247,0.16);
    background: rgba(124,58,237,0.16);
    color: #efe5ff;
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.admin-sidebar-head-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.admin-sidebar .admin-brand {
    width: 100%;
    padding: 10px 12px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 14px 28px rgba(0,0,0,0.16);
}
.admin-sidebar .admin-brand .brand-mark {
    box-shadow: 0 14px 30px rgba(124, 58, 237, 0.32), inset 0 0 0 1px rgba(255,255,255,0.08);
}
.admin-sidebar .admin-brand .brand-text strong {
    font-size: 1.02rem;
}
.admin-sidebar .admin-brand .brand-text span {
    font-size: .78rem;
}
.admin-sidebar-note {
    color: var(--muted);
    line-height: 1.55;
    font-size: .74rem;
    padding-inline-start: 2px;
}
.admin-sidebar-panel,
.admin-nav-group {
    padding: 10px;
    border-radius: 18px;
    background:
        radial-gradient(circle at 0% 0%, rgba(168,85,247,0.10), transparent 30%),
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.02));
    border: 1px solid rgba(168,85,247,0.10);
    margin-top: 0;
    position: relative;
    overflow: hidden;
}
.admin-sidebar-panel::before,
.admin-nav-group::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), transparent 42%);
    pointer-events: none;
}
.admin-sidebar-panel:hover,
.admin-nav-group:hover {
    border-color: rgba(168,85,247,0.18);
}
.admin-dashboard-hero {
    display: grid;
    grid-template-columns: 1.25fr .75fr;
    gap: 12px;
    padding: 14px;
    background:
        radial-gradient(circle at 85% 20%, rgba(168,85,247,0.18), transparent 25%),
        linear-gradient(135deg, rgba(18, 24, 49, 0.94), rgba(10, 14, 31, 0.96));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow);
}
.admin-section-tint-overview {
    background:
        radial-gradient(circle at 0% 0%, rgba(34,211,238,0.18), transparent 26%),
        radial-gradient(circle at 100% 0%, rgba(168,85,247,0.22), transparent 28%),
        linear-gradient(135deg, rgba(12, 18, 41, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-section-tint-finance {
    background:
        radial-gradient(circle at 0% 0%, rgba(34,197,94,0.16), transparent 25%),
        radial-gradient(circle at 100% 0%, rgba(245,158,11,0.18), transparent 28%),
        linear-gradient(135deg, rgba(10, 18, 33, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-section-tint-content {
    background:
        radial-gradient(circle at 0% 0%, rgba(56,189,248,0.16), transparent 24%),
        radial-gradient(circle at 100% 0%, rgba(124,58,237,0.18), transparent 28%),
        linear-gradient(135deg, rgba(10, 16, 34, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-section-tint-people {
    background:
        radial-gradient(circle at 0% 0%, rgba(244,63,94,0.14), transparent 24%),
        radial-gradient(circle at 100% 0%, rgba(168,85,247,0.18), transparent 28%),
        linear-gradient(135deg, rgba(17, 14, 34, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-section-tint-planning {
    background:
        radial-gradient(circle at 0% 0%, rgba(245,158,11,0.14), transparent 24%),
        radial-gradient(circle at 100% 0%, rgba(34,211,238,0.16), transparent 26%),
        linear-gradient(135deg, rgba(18, 18, 34, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-section-tint-operations,
.admin-section-tint-project-types,
.admin-section-tint-ad-countries,
.admin-section-tint-user-roles,
.admin-section-tint-client-project-status,
.admin-section-tint-subscription-status,
.admin-section-tint-bank-status {
    background:
        radial-gradient(circle at 0% 0%, rgba(168,85,247,0.18), transparent 26%),
        radial-gradient(circle at 100% 0%, rgba(56,189,248,0.16), transparent 26%),
        linear-gradient(135deg, rgba(11, 16, 31, 0.96), rgba(7, 10, 22, 0.98));
}
.admin-dashboard-hero-copy h1 {
    margin: 10px 0 12px;
    font-size: clamp(1.7rem, 2.6vw, 2.6rem);
}
.admin-dashboard-hero-grid {
    display: grid;
    gap: 12px;
}
.admin-dashboard-mini {
    border-radius: 20px;
    padding: 10px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    min-height: 138px;
    display: grid;
    align-items: end;
}
.admin-dashboard-mini strong {
    display: block;
    margin-bottom: 6px;
    font-size: 1rem;
}
.admin-dashboard-mini p { margin: 0; color: var(--muted); line-height: 1.8; }
.admin-dashboard-hero .admin-actions { margin-top: 18px; }
.admin-summary-strip > div {
    position: relative;
    overflow: hidden;
}
.admin-summary-strip > div::after {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(34,211,238,0.9), rgba(124,58,237,0.9));
}
.admin-summary-strip > div[data-priority="1"]::after { background: linear-gradient(90deg, #22d3ee, #38bdf8); }
.admin-summary-strip > div[data-priority="2"]::after { background: linear-gradient(90deg, #7c3aed, #a855f7); }
.admin-summary-strip > div[data-priority="3"]::after { background: linear-gradient(90deg, #f59e0b, #fb923c); }
.admin-summary-strip > div[data-priority="4"]::after { background: linear-gradient(90deg, #22c55e, #16a34a); }
.admin-sidebar-cta {
    width: 100%;
    min-height: 38px;
    justify-content: flex-start;
    padding-inline: 12px;
    border-radius: 14px;
    border-color: rgba(168,85,247,0.20);
    background: linear-gradient(135deg, rgba(18, 28, 58, 0.90), rgba(12, 18, 38, 0.90));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.admin-sidebar-cta svg { width: 16px; height: 16px; }
.admin-sidebar-cta:hover,
.admin-sidebar-cta.active {
    transform: translateY(-1px);
    border-color: rgba(168,85,247,0.42);
    background: linear-gradient(135deg, rgba(124,58,237,0.24), rgba(59,130,246,0.14));
    box-shadow: 0 14px 28px rgba(124,58,237,0.14), inset 0 1px 0 rgba(255,255,255,0.06);
}
.admin-sidebar-cta.active {
    color: #fff;
}
.admin-sidebar-label,
.admin-nav-title {
    color: #d6c2ff;
    font-size: .7rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.admin-sidebar-nav { display: grid; gap: 8px; }
.admin-nav-links { display: grid; gap: 6px; margin-top: 8px; }
.admin-nav-link {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 12px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(168,85,247,0.08);
    color: #eef1ff;
    transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.admin-nav-icon {
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(168,85,247,0.12);
    color: #d8b4fe;
    flex-shrink: 0;
}
.admin-nav-icon svg { width: 16px; height: 16px; }
.admin-nav-main {
    display: grid;
    gap: 2px;
    min-width: 0;
    flex: 1;
}
.admin-nav-main strong {
    display: block;
    font-size: .9rem;
    line-height: 1.2;
    color: #f5f3ff;
}
.admin-nav-main span:last-child {
    color: var(--muted);
    font-size: .75rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.admin-nav-link:hover,
.admin-nav-link.active {
    transform: translateX(-1px);
    border-color: rgba(168,85,247,0.32);
    background: rgba(124,58,237,0.14);
}
.admin-nav-link.active {
    box-shadow: 0 0 0 1px rgba(168,85,247,0.12) inset;
}
.admin-sidebar-footer {
    margin-top: auto;
    padding: 8px;
    border-radius: 18px;
    border: 1px solid rgba(168,85,247,0.10);
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
    display: grid;
    gap: 0;
}
.admin-sidebar-footer::before {
    content: '';
    display: block;
    height: 1px;
    margin-bottom: 6px;
    background: linear-gradient(90deg, transparent, rgba(168,85,247,0.45), transparent);
}
.admin-sidebar-footer strong,
.admin-sidebar-footer p { display: none; }
.admin-mini-spark {
    height: 132px;
    border-radius: 18px;
    padding: 10px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.07);
}
.admin-mini-spark svg {
    width: 100%;
    height: 100%;
    display: block;
}
.admin-spark-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.admin-spark-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.06);
    color: var(--muted);
    font-size: .8rem;
}
.admin-spark-legend strong { color: #fff; }
.admin-mini-chart-metrics {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
    color: var(--muted);
    font-size: .8rem;
}
.admin-mini-chart-metrics span {
    padding: 7px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.03);
}
.admin-page { display: grid; gap: 12px; }
.admin-topbar-compact { margin-bottom: 0; }
.admin-topbar-compact h1 { font-size: clamp(1.4rem, 2vw, 2rem); }
.admin-topbar-compact .admin-muted { font-size: .9rem; }
.admin-quick-card { padding: 16px; }
.admin-summary-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
}
.admin-summary-strip div {
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-summary-strip strong { display: block; font-size: .92rem; margin-bottom: 4px; }
.admin-summary-strip span { color: var(--muted); font-size: .78rem; }
.admin-section-card { min-height: 112px; }
.admin-items-grid { margin-top: 8px; }
.admin-group-stack { display: grid; gap: 12px; }
.admin-group-card { padding: 16px; }
.admin-group-head { margin-bottom: 12px; }
.admin-section-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-homepage-banner {
    padding: 22px;
    background: linear-gradient(135deg, rgba(124,58,237,0.12), rgba(16,185,129,0.08) 55%, rgba(255,255,255,0.02));
}
.admin-homepage-banner .admin-topbar { margin-bottom: 10px; }
.admin-homepage-summary { margin-top: 14px; }
.admin-homepage-hero-panel {
    padding: 18px;
    display: grid;
    gap: 18px;
}
.admin-homepage-hero-grid {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}
.admin-homepage-preview,
.admin-homepage-fields {
    padding: 18px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.02);
}
.admin-homepage-preview,
.admin-homepage-fields {
    min-width: 0;
}
.admin-homepage-preview {
    position: sticky;
    top: 16px;
    padding: 12px;
}
.admin-homepage-preview h2,
.admin-homepage-fields h2 {
    margin: 6px 0 10px;
    font-size: 1.05rem;
}
.admin-homepage-preview .admin-hero-image-preview {
    min-height: 92px;
}
.admin-homepage-fields { display: grid; gap: 14px; }
.admin-preview-card {
    margin-top: 10px;
    padding: 10px;
    border-radius: 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-instructor-table-card { padding: 0 0 18px; }
.admin-instructor-topbar {
    padding: 18px 18px 8px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}
.admin-instructor-preview { display: grid; gap: 14px; }
.admin-instructor-cards {
    display: grid;
    gap: 14px;
    margin-top: 12px;
}
.admin-instructor-table td { vertical-align: middle; }
.admin-instructor-table th:nth-child(1),
.admin-instructor-table td:nth-child(1) { width: 24%; }
.admin-instructor-table th:nth-child(3),
.admin-instructor-table td:nth-child(3) { width: 28%; }
.admin-instructor-table th:nth-child(4),
.admin-instructor-table td:nth-child(4) { width: 22%; }
.admin-instructor-table-media {
    display: flex;
    align-items: center;
    gap: 12px;
}
.admin-instructor-table-media strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
}
.admin-instructor-table-media p {
    margin: 0;
    color: var(--muted);
    font-size: .82rem;
}
.admin-instructor-chooser {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.admin-instructor-chooser-item {
    width: 100%;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    text-align: right;
    cursor: pointer;
}
.admin-instructor-chooser-item.is-selected {
    border-color: rgba(59,130,246,0.5);
    background: rgba(59,130,246,0.12);
}
.admin-instructor-chooser-media {
    display: flex;
    align-items: center;
    gap: 12px;
}
.admin-instructor-chooser-media strong {
    display: block;
    margin-bottom: 4px;
}
.admin-instructor-chooser-media p {
    margin: 0;
    color: var(--muted);
    font-size: .8rem;
}
.admin-instructor-course-cell {
    display: grid;
    gap: 8px;
    justify-items: start;
}
.admin-instructor-courses-list {
    display: grid;
    gap: 10px;
}
.admin-instructor-course-item {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.admin-instructor-course-meta strong {
    display: block;
    margin-bottom: 4px;
}
.admin-instructor-course-meta p {
    margin: 0;
    color: var(--muted);
    font-size: .82rem;
}
.admin-instructor-card {
    padding: 16px;
    border-radius: 20px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    display: grid;
    gap: 14px;
}
.admin-instructor-card-head {
    display: flex;
    align-items: center;
    gap: 12px;
}
.admin-instructor-card-head strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
}
.admin-instructor-card-head p {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
    font-size: .92rem;
}
.admin-instructor-avatar {
    width: min(280px, 100%);
    aspect-ratio: 1;
    border-radius: 50%;
    overflow: hidden;
    margin-inline: auto;
    border: 1px solid rgba(255,255,255,0.10);
    background: radial-gradient(circle at 30% 30%, rgba(168,85,247,0.22), rgba(59,130,246,0.10) 45%, rgba(15,23,42,0.92));
    box-shadow: 0 24px 50px rgba(0,0,0,0.22);
}
.admin-instructor-avatar-large { width: min(300px, 100%); }
.admin-instructor-avatar-small {
    width: 68px;
    height: 68px;
    min-width: 68px;
    min-height: 68px;
    flex-shrink: 0;
}
.admin-instructor-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.admin-instructor-avatar-placeholder {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    color: #f3e8ff;
    font-weight: 900;
    letter-spacing: .02em;
    text-align: center;
    padding: 18px;
}
.admin-instructor-points {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}
.admin-instructor-points-table { margin-top: 0; }
.admin-instructor-points span {
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(59,130,246,0.12);
    border: 1px solid rgba(59,130,246,0.22);
    color: #dbeafe;
    font-size: .82rem;
}
.admin-instructor-preview-box { display: grid; gap: 10px; }
.admin-instructor-point-row { grid-template-columns: minmax(0, 1fr) auto; }
.admin-instructor-page .projects-empty-inline { margin-top: 0; }
.admin-preview-pill {
    display: inline-flex;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(124,58,237,0.14);
    border: 1px solid rgba(168,85,247,0.18);
    color: #efe5ff;
    font-size: .76rem;
    font-weight: 800;
    margin-bottom: 8px;
}
.admin-preview-card strong {
    display: block;
    font-size: .92rem;
    margin-bottom: 4px;
}
.admin-preview-card span { color: var(--muted); display: block; font-size: .76rem; }
.admin-preview-card p { margin: 8px 0 0; color: var(--muted); line-height: 1.5; font-size: .78rem; }
.admin-preview-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.admin-preview-tags span {
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #eae7f9;
    font-size: .7rem;
}
.admin-status-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: .74rem;
    font-weight: 800;
    margin-bottom: 8px;
    border: 1px solid rgba(168,85,247,0.16);
    background: rgba(124,58,237,0.1);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.admin-status-pill.is-active {
    background: rgba(16,185,129,0.15);
    border: 1px solid rgba(16,185,129,0.25);
    color: #bff7df;
}
.admin-status-pill.is-warning {
    background: rgba(245,158,11,0.16);
    border: 1px solid rgba(245,158,11,0.28);
    color: #fde68a;
}
.admin-status-pill.is-primary {
    background: rgba(59,130,246,0.16);
    border: 1px solid rgba(59,130,246,0.28);
    color: #dbeafe;
}
.admin-status-pill.is-success {
    background: rgba(16,185,129,0.15);
    border: 1px solid rgba(16,185,129,0.25);
    color: #bff7df;
}
.admin-status-pill.is-inactive {
    background: rgba(239,68,68,0.14);
    border: 1px solid rgba(239,68,68,0.24);
    color: #ffd2d2;
}
.admin-ad-preview { display: grid; gap: 0; }
.admin-ad-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.admin-ad-meta span {
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #eae7f9;
    font-size: .76rem;
}
.admin-ad-gallery {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.admin-ad-gallery img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-ad-existing-image {
    position: relative;
    display: block;
}
.admin-ad-existing-image img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-label {
    display: block;
    margin-bottom: 8px;
    color: #eae7f9;
    font-weight: 700;
    font-size: .85rem;
}
.admin-ad-table {
    margin-top: 6px;
}
.admin-modal-trigger-card {
    display: grid;
    gap: 12px;
    align-content: start;
    min-height: 180px;
    padding: 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
}
.admin-ads-page { gap: 12px; }
.admin-ads-page .admin-ads-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(138px, 1fr));
    gap: 14px;
    margin-top: 10px;
    margin-bottom: 10px;
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle {
    min-height: 168px;
    border-radius: 999px;
    padding: 18px 14px;
    text-align: center;
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.09);
    background:
        radial-gradient(circle at 30% 25%, rgba(255,255,255,0.12), transparent 26%),
        radial-gradient(circle at 70% 0%, rgba(251,146,60,0.16), transparent 24%),
        linear-gradient(145deg, rgba(17,21,43,0.96), rgba(11,14,28,0.98));
    box-shadow: 0 18px 46px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.05);
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle::after {
    content: '';
    position: absolute;
    inset: 12px;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,0.06);
    pointer-events: none;
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle::before {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 4px;
    background: linear-gradient(90deg, rgba(168,85,247,0.98), rgba(251,146,60,0.98));
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle .admin-stat-icon {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    margin-bottom: 10px;
    color: #fff;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.10);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle span {
    font-size: .76rem;
    margin-bottom: 8px;
    color: #d8def3;
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-circle strong {
    font-size: clamp(1.45rem, 2vw, 2rem);
    line-height: 1;
}
.admin-ads-page .admin-ads-stats .admin-stat-card.is-success::after { background: linear-gradient(90deg, rgba(34,197,94,0.98), rgba(16,185,129,0.92)); }
.admin-ads-page .admin-ads-stats .admin-stat-card.is-warning::after { background: linear-gradient(90deg, rgba(245,158,11,0.98), rgba(251,146,60,0.94)); }
.admin-ads-page .admin-ads-stats .admin-stat-card.is-accent::after { background: linear-gradient(90deg, rgba(124,58,237,0.98), rgba(168,85,247,0.94)); }
.admin-ads-page .admin-ads-stats .admin-stat-card.is-primary::after { background: linear-gradient(90deg, rgba(59,130,246,0.98), rgba(34,211,238,0.92)); }
.admin-ads-page .admin-ads-stats .admin-stat-card.is-total::after { background: linear-gradient(90deg, rgba(251,146,60,0.98), rgba(245,158,11,0.98)); }
.admin-ads-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 16px 18px;
}
.admin-ads-header h1 { margin: 4px 0 6px; font-size: clamp(1.7rem, 2.4vw, 2.2rem); }
.admin-ads-header-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-sub-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 12px;
}
.admin-subscriptions-page .admin-sub-stats {
    gap: 14px;
}
.admin-cost-stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
}
.admin-stat-card {
    padding: 16px;
    border-radius: 20px;
    border: 1px solid rgba(168,85,247,0.12);
    background:
        radial-gradient(circle at 20% 0%, rgba(251,146,60,0.10), transparent 28%),
        linear-gradient(145deg, rgba(16,18,38,0.96), rgba(9,12,25,0.98));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 18px 36px rgba(0,0,0,0.20);
    position: relative;
    overflow: hidden;
}
.admin-stat-card::after {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(168,85,247,0.95), rgba(251,146,60,0.95));
}
.admin-stat-card.is-total::after { background: linear-gradient(90deg, rgba(251,146,60,0.98), rgba(245,158,11,0.98)); }
.admin-stat-card.is-warning::after { background: linear-gradient(90deg, rgba(245,158,11,0.98), rgba(251,146,60,0.92)); }
.admin-stat-card.is-success::after { background: linear-gradient(90deg, rgba(34,197,94,0.96), rgba(16,185,129,0.96)); }
.admin-stat-card.is-accent::after { background: linear-gradient(90deg, rgba(124,58,237,0.98), rgba(168,85,247,0.92)); }
.admin-stat-card.is-primary::after { background: linear-gradient(90deg, rgba(59,130,246,0.98), rgba(34,211,238,0.92)); }
.admin-stat-icon {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    margin-bottom: 10px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #fbbf24;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.admin-stat-card.is-total .admin-stat-icon,
.admin-stat-card.is-warning .admin-stat-icon {
    color: #fdba74;
}
.admin-stat-card.is-success .admin-stat-icon { color: #86efac; }
.admin-stat-card.is-accent .admin-stat-icon { color: #d8b4fe; }
.admin-stat-card.is-primary .admin-stat-icon { color: #7dd3fc; }
.admin-stat-icon svg { width: 18px; height: 18px; }
.admin-cost-stat {
    position: relative;
    width: clamp(128px, 11vw, 156px);
    height: clamp(128px, 11vw, 156px);
    padding: 18px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.10);
    background:
        radial-gradient(circle at 30% 28%, rgba(255,255,255,0.12), transparent 34%),
        linear-gradient(145deg, rgba(124,58,237,0.18), rgba(17,21,43,0.92));
    box-shadow: 0 16px 44px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.05);
    display: grid;
    place-items: center;
    text-align: center;
    overflow: hidden;
}
.admin-cost-stat > * { position: relative; z-index: 1; }
.admin-cost-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.10);
    color: #fff;
    margin-bottom: 8px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.admin-cost-icon svg {
    width: 16px;
    height: 16px;
}
.admin-cost-stat::before {
    content: '';
    position: absolute;
    inset: 10px;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,0.06);
    pointer-events: none;
}
.admin-cost-stat span {
    display: block;
    color: #d8def3;
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .02em;
    margin-bottom: 8px;
}
.admin-cost-stat strong {
    display: block;
    font-size: clamp(1.35rem, 1.8vw, 1.85rem);
    font-weight: 900;
    line-height: 1;
    color: #fff;
}
.admin-client-project-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin: 18px 0 0;
}
.admin-client-project-stats .admin-cost-stat {
    min-height: 112px;
}
.admin-client-users-stats {
    margin-top: 18px;
}
.admin-client-users-stats .admin-cost-stat {
    min-height: 112px;
}
.admin-client-project-table td .btn {
    min-width: 0;
}
.admin-cost-stat.is-success { background: linear-gradient(145deg, rgba(16,185,129,0.22), rgba(17,21,43,0.92)); }
.admin-cost-stat.is-accent { background: linear-gradient(145deg, rgba(124,58,237,0.25), rgba(17,21,43,0.92)); }
.admin-cost-stat.is-paid { background: linear-gradient(145deg, rgba(34,197,94,0.22), rgba(17,21,43,0.92)); }
.admin-cost-stat.is-warning { background: linear-gradient(145deg, rgba(245,158,11,0.22), rgba(17,21,43,0.92)); }
.admin-cost-stat.is-primary { background: linear-gradient(145deg, rgba(59,130,246,0.22), rgba(17,21,43,0.92)); }
.admin-cost-stat.is-total { background: linear-gradient(145deg, rgba(168,85,247,0.24), rgba(17,21,43,0.92)); }
.admin-stat-card span {
    display: block;
    color: #d7d2ea;
    font-size: .82rem;
    margin-bottom: 8px;
}
.admin-stat-card strong {
    display: block;
    font-size: 1.55rem;
    font-weight: 900;
    color: #fff;
    letter-spacing: -.02em;
}
.admin-ads-page .admin-stat-card.is-circle {
    border-color: rgba(251,146,60,0.10);
}
.admin-ads-page .admin-stat-card.is-circle .admin-stat-icon {
    color: #fdba74;
}
.admin-sub-filters {
    display: grid;
    grid-template-columns: 1.4fr 1fr auto;
    gap: 12px;
    margin: 14px 0 16px;
    padding: 0 18px;
}
.admin-subscriptions-page .admin-topbar {
    background:
        radial-gradient(circle at 0% 0%, rgba(251,146,60,0.10), transparent 22%),
        radial-gradient(circle at 100% 0%, rgba(168,85,247,0.12), transparent 26%),
        linear-gradient(135deg, rgba(18, 23, 47, 0.95), rgba(10, 14, 28, 0.92));
    border-color: rgba(251,146,60,0.12);
    box-shadow: 0 16px 36px rgba(0,0,0,0.20);
}
.admin-subscriptions-page .admin-table-card {
    border-color: rgba(251,146,60,0.10);
    box-shadow: 0 24px 60px rgba(0,0,0,0.22);
}
.admin-subscriptions-page .admin-table thead th {
    background: linear-gradient(180deg, rgba(251,146,60,0.12), rgba(168,85,247,0.08));
    border-bottom-color: rgba(251,146,60,0.14);
}
.admin-subscriptions-page .admin-table tbody tr:hover {
    background: rgba(251,146,60,0.05);
}
.admin-sub-filters label span {
    display: block;
    margin-bottom: 6px;
    color: #f1e7d8;
    font-size: .84rem;
    font-weight: 700;
}
.admin-filter-actions {
    align-self: end;
}
.admin-addon-list {
    display: grid;
    gap: 10px;
}
.admin-addon-summary {
    display: grid;
    gap: 8px;
}
.admin-addon-summary strong {
    display: block;
    font-size: .92rem;
}
.admin-addon-summary span {
    color: var(--muted);
    font-size: .82rem;
}
.admin-addon-item,
.admin-addon-view-card {
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    display: grid;
    gap: 10px;
}
.admin-addon-item-main {
    background: rgba(124,58,237,0.08);
    border-color: rgba(168,85,247,0.18);
}
.admin-addon-item strong,
.admin-addon-view-card strong {
    display: block;
    margin-bottom: 4px;
    font-size: .9rem;
}
.admin-addon-item span,
.admin-addon-view-card p {
    margin: 0;
    color: var(--muted);
    font-size: .82rem;
}
.admin-addon-mini-actions,
.admin-addon-view-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.admin-addon-view-list {
    display: grid;
    gap: 12px;
}
.admin-addon-table-wrap {
    overflow: auto;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-addon-table {
    min-width: 760px;
    margin: 0;
}
.admin-addon-table td,
.admin-addon-table th {
    vertical-align: top;
}
.admin-task-table {
    min-width: 960px;
}
.admin-task-table td,
.admin-task-table th {
    vertical-align: top;
}
.admin-task-history {
    display: grid;
    gap: 10px;
    max-height: 420px;
    overflow: auto;
}
.admin-task-history-box {
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-task-history-item {
    padding: 12px;
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-task-history-item p {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}
.admin-task-history-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 8px;
}
.admin-task-history-meta strong { font-size: .86rem; }
.admin-task-history-meta span { color: var(--muted); font-size: .78rem; }
.admin-addon-view-toolbar {
    margin-bottom: 10px;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-addon-view-filter {
    grid-template-columns: 1fr auto;
    gap: 10px;
    padding: 0;
    margin: 0;
}
.admin-addon-view-filter label span {
    display: block;
    margin-bottom: 6px;
    color: #eae7f9;
    font-size: .82rem;
    font-weight: 700;
}
.admin-addon-view-card-main {
    background: rgba(16,185,129,0.08);
    border-color: rgba(16,185,129,0.16);
}
.admin-page-hero,
.admin-ads-split,
.admin-ads-preview-card,
.admin-ads-quick-card { display: none; }
.admin-modal-panel-wide { width: min(1120px, 100%); }
.admin-modal-panel-small { width: min(560px, 100%); }
.admin-modal-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 18px;
}
.admin-modal-grid-single {
    grid-template-columns: 1fr;
}
.admin-modal-section {
    padding: 16px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
}
.admin-modal-section h3 {
    margin: 0 0 14px;
    font-size: 1rem;
}
.admin-modal-help-box {
    margin-top: 14px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(124,58,237,0.08);
    border: 1px solid rgba(168,85,247,0.12);
}
.admin-modal-help-box strong { display: block; margin-bottom: 6px; }
.admin-modal-help-box p { margin: 0; color: var(--muted); line-height: 1.7; }
.admin-pdf-preview-frame-wrap {
    margin-top: 12px;
    overflow: hidden;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2, 6, 23, 0.55);
}
.admin-pdf-preview-frame {
    display: block;
    width: 100%;
    height: 460px;
    border: 0;
    background: #0b1020;
}
.admin-modal-form { display: grid; gap: 16px; }
.admin-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
    padding: 20px;
}
.admin-modal[hidden] { display: none; }
.admin-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 23, 0.72);
    backdrop-filter: blur(8px);
}
.admin-modal-panel {
    position: relative;
    z-index: 1;
    width: min(980px, 100%);
    max-height: min(84vh, 760px);
    overflow: auto;
    padding: 20px;
    border-radius: 26px;
    border: 1px solid rgba(168,85,247,0.16);
    background:
        radial-gradient(circle at 0% 0%, rgba(168,85,247,0.16), transparent 28%),
        linear-gradient(180deg, rgba(12,16,33,0.98), rgba(8,10,22,0.98));
    box-shadow: 0 24px 60px rgba(0,0,0,0.38), 0 0 0 1px rgba(124,58,237,0.08) inset;
}
.admin-modal-panel .admin-input,
.admin-modal-panel .admin-textarea {
    width: 100%;
}
.admin-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}
.admin-modal-head p { margin: 6px 0 0; }
.admin-modal-head h2 { margin: 6px 0 0; font-size: 1.4rem; }
.admin-modal-close {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.04);
    color: #fff;
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    box-shadow: 0 8px 20px rgba(0,0,0,0.25);
}
.admin-modal-close:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.18);
}
.admin-modal-head .admin-modal-close {
    margin-inline-start: auto;
}
.admin-modal-form { margin-top: 0; }
.admin-modal-actions { justify-content: flex-start; }
.modal-open { overflow: hidden; }
.admin-goal-create-box { margin-bottom: 16px; }
.admin-goal-list { display: grid; gap: 16px; }
.admin-goal-card {
    padding: 16px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    display: grid;
    gap: 14px;
}
.admin-goal-card.is-dragging { opacity: 0.65; transform: scale(0.995); }
.admin-goal-card-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.admin-goal-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.admin-goal-card h3 { margin: 6px 0 0; font-size: 1.1rem; }
.admin-goal-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; align-items: center; }
.admin-goal-edit-form, .admin-goal-note-form, .admin-goal-delete-form { margin: 0; }
.admin-goal-body { display: grid; gap: 14px; }
.admin-goal-body[hidden] { display: none; }
.admin-goal-progress {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-goal-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #22c55e, #a855f7);
}
.admin-goal-drag-handle { cursor: grab; user-select: none; }
.admin-goal-toggle { min-width: 110px; }
.admin-goal-note-list { display: grid; gap: 10px; }
.admin-goal-note-list {
    max-height: 520px;
    overflow: auto;
    padding-inline-end: 6px;
}
.admin-goal-note {
    padding: 12px;
    border-radius: 16px;
    background: rgba(2, 6, 23, 0.4);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-goal-note > summary { list-style: none; }
.admin-goal-note > summary::-webkit-details-marker { display: none; }
.admin-goal-note-summary {
    display: grid;
    grid-template-columns: auto auto 1fr auto;
    gap: 8px;
    align-items: center;
    cursor: pointer;
}
.admin-goal-note-row .admin-goal-note-summary {
    grid-template-columns: 1fr auto;
    gap: 14px;
    align-items: start;
}
.admin-goal-note-row .admin-note-summary-main {
    align-items: center;
    min-height: 36px;
}
.admin-goal-note-summary strong { font-size: .9rem; }
.admin-goal-note-content { margin-top: 10px; display: grid; gap: 10px; }
.admin-goal-note-row {
    padding: 10px 12px;
}
.admin-note-summary-main {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    min-width: 0;
}
.admin-note-summary-side {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    text-align: end;
}
.admin-note-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.admin-note-actions form { margin: 0; }
.admin-goal-note-row .admin-goal-note-content {
    padding-top: 4px;
}
.admin-goal-note-row p {
    margin-top: 2px;
}
.admin-goal-note-row[open] {
    box-shadow: 0 18px 40px rgba(2, 6, 23, 0.28);
    border-color: rgba(255,255,255,0.1);
}
.admin-goal-note-row[open] > summary {
    padding-bottom: 8px;
    margin-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.admin-goal-note.is-private {
    background: linear-gradient(180deg, rgba(124,58,237,0.18), rgba(2, 6, 23, 0.5));
    border-color: rgba(168,85,247,0.35);
    box-shadow: 0 12px 30px rgba(124,58,237,0.12);
}
.admin-goal-note-head { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 8px; }
.admin-goal-note p { margin: 0; color: #e5e7eb; line-height: 1.7; }
.admin-goal-note-private-label {
    display: inline-flex;
    align-items: center;
    margin-bottom: 10px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(168,85,247,0.16);
    border: 1px solid rgba(168,85,247,0.28);
    color: #f5d0fe;
    font-size: .78rem;
    font-weight: 800;
}
.admin-goal-note-form { display: grid; gap: 10px; }
.admin-goal-note-edit-form { display: grid; gap: 10px; margin-top: 10px; }
.admin-goal-note-delete-form { margin-top: 8px; }
.admin-goal-note-footer { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.admin-goal-note-footer .admin-input { min-width: 160px; }
.admin-goal-index-list,
.admin-note-list { display: grid; gap: 14px; }
.admin-goal-index-list {
    max-height: 68vh;
    overflow: auto;
    padding-inline-end: 6px;
}
.admin-goal-table-head {
    display: grid;
    grid-template-columns: 1.4fr .8fr .8fr .8fr 1.2fr;
    gap: 12px;
    padding: 0 14px 8px;
    color: #cbd5e1;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.admin-goal-tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-start;
}
.admin-goal-tabs .is-active {
    background: rgba(34,197,94,0.18);
    border-color: rgba(34,197,94,0.35);
    color: #dcfce7;
}
.admin-goal-index-card {
    padding: 10px 12px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.03);
}
.admin-goal-index-card.is-dragging { opacity: 0.65; }
.admin-goal-index-head {
    display: grid;
    grid-template-columns: 1.4fr .8fr .8fr .8fr 1.2fr;
    gap: 10px;
    align-items: center;
}
.admin-goal-main { grid-column: 1 / span 4; min-width: 0; }
.admin-goal-main h3,
.admin-goal-index-head h3 { margin: 4px 0 0; font-size: 1rem; line-height: 1.25; }
.admin-goal-progress-bar {
    margin-top: 8px;
    height: 6px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    overflow: hidden;
}
.admin-goal-progress-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #06b6d4, #22c55e);
}
.admin-goal-search { min-width: 180px; height: 38px; }
.admin-goal-main { min-width: 0; }
.admin-goal-main .admin-goal-meta { margin-top: 6px; gap: 6px; }
.admin-goal-actions { grid-column: 5; justify-content: flex-end; gap: 6px; }
.admin-goal-actions .btn { padding: 8px 10px; }
.admin-goal-actions .admin-status-pill { padding: 6px 8px; }
.admin-note-list-wrap {
    max-height: 70vh;
    overflow: auto;
    padding-inline-end: 6px;
}
.admin-client-project-list {
    display: grid;
    gap: 14px;
    max-height: 70vh;
    overflow: auto;
    padding-inline-end: 6px;
}
.admin-client-project-table-wrap {
    max-height: 70vh;
    overflow: auto;
    padding-inline-end: 6px;
}
.admin-client-project-table {
    width: 100%;
    margin-top: 10px;
}
.admin-client-project-table thead th {
    white-space: nowrap;
}
.admin-client-project-table tbody td {
    vertical-align: top;
    white-space: normal;
    padding-top: 18px;
    padding-bottom: 18px;
}
.admin-client-project-table tbody tr:hover {
    background: rgba(255,255,255,0.03);
}
.admin-client-project-table-name {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.admin-client-project-table-name img,
.admin-client-project-table-thumb {
    width: 58px;
    height: 58px;
    border-radius: 14px;
    object-fit: cover;
    flex: 0 0 auto;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2, 6, 23, 0.55);
}
.admin-client-project-table-thumb {
    display: grid;
    place-items: center;
    color: #cbd5e1;
    font-weight: 800;
    font-size: .8rem;
}
.admin-client-project-table-name strong {
    display: block;
    font-size: .95rem;
    margin-bottom: 4px;
}
.admin-client-project-table-name span,
.admin-table-subtext {
    display: block;
    color: #94a3b8;
    font-size: .78rem;
}
.admin-client-project-table .admin-table-subtext {
    margin-top: 5px;
}
.admin-client-project-table .admin-status-pill {
    margin-bottom: 0;
}
.admin-client-project-table .admin-table-media,
.admin-client-project-table .admin-note-actions {
    align-items: stretch;
}
.admin-client-project-table .admin-table-media .btn,
.admin-client-project-table .admin-note-actions .btn,
.admin-client-project-table .admin-note-actions form .btn {
    min-width: 126px;
    justify-content: space-between;
    padding-inline: 14px;
    border-radius: 14px;
}
.admin-client-project-table .admin-note-actions .btn.btn-danger {
    min-width: 92px;
}
.admin-client-project-table .admin-note-actions .btn.btn-outline {
    background: rgba(59, 130, 246, 0.1);
}
.admin-client-project-table .admin-note-actions .btn.btn-violet {
    background: rgba(139, 92, 246, 0.14);
}
.admin-client-project-table .admin-note-actions .btn.btn-slate {
    background: rgba(100, 116, 139, 0.14);
}
.admin-client-owner-field {
    display: grid;
    gap: 8px;
}
.admin-client-owner-field > span {
    color: #eae7f9;
    font-weight: 700;
    font-size: .85rem;
}
.admin-client-owner-button {
    justify-content: space-between;
    min-width: 100%;
    padding-inline: 14px;
}
.admin-client-owner-summary {
    color: #94a3b8;
    font-size: .78rem;
}
.admin-modal-panel-owners {
    width: min(980px, 100%);
}
.admin-client-owner-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 12px;
}
.admin-client-owner-list .projects-empty {
    grid-column: 1 / -1;
}
.admin-client-owner-card {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(59,130,246,0.22);
    background: rgba(255,255,255,0.03);
    color: #f8fafc;
    cursor: pointer;
    text-align: right;
}
.admin-client-owner-card:hover {
    background: rgba(59,130,246,0.09);
    border-color: rgba(59,130,246,0.34);
}
.admin-client-owner-card img,
.admin-client-owner-card span {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    object-fit: cover;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2, 6, 23, 0.55);
    color: #cbd5e1;
    font-weight: 800;
}
.admin-client-owner-card strong {
    display: block;
    margin-bottom: 3px;
    font-size: .95rem;
}
.admin-client-owner-card small {
    color: #94a3b8;
    font-size: .76rem;
}
.admin-project-preview-layout {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    gap: 18px;
}
.admin-project-preview-media-wrap {
    display: grid;
    gap: 12px;
}
.admin-project-preview-media {
    min-height: 280px;
    overflow: hidden;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2, 6, 23, 0.55);
}
.admin-project-preview-media img {
    width: 100%;
    height: 100%;
    min-height: 280px;
    object-fit: cover;
    display: block;
}
.admin-project-preview-links {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.admin-project-preview-content {
    display: grid;
    gap: 14px;
    align-content: start;
}
.admin-project-preview-description {
    margin: 0;
    color: #e5e7eb;
    line-height: 1.8;
    font-size: 1rem;
}
.admin-project-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.admin-project-preview-grid div,
.admin-project-preview-notes {
    padding: 14px;
    border-radius: 18px;
    background: rgba(2, 6, 23, 0.45);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-project-preview-grid span,
.admin-project-preview-notes span {
    display: block;
    margin-bottom: 8px;
    color: #94a3b8;
    font-size: .8rem;
    font-weight: 700;
}
.admin-project-preview-grid strong,
.admin-project-preview-notes p {
    margin: 0;
    color: #f8fafc;
    line-height: 1.7;
}
.admin-project-preview-notes { display: grid; }
.admin-project-preview-gallery-wrap {
    display: grid;
    gap: 10px;
}
.admin-project-preview-gallery {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.admin-project-preview-gallery-item,
.admin-project-image-existing,
.admin-project-image-chip {
    display: block;
    overflow: hidden;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2, 6, 23, 0.55);
}
.admin-project-preview-gallery-item img,
.admin-project-image-existing img,
.admin-project-image-chip img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}
.admin-project-images-preview-head,
.admin-project-images-existing {
    display: grid;
    gap: 10px;
    margin-top: 14px;
}
.admin-project-images-preview {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.admin-project-image-chip {
    position: relative;
    padding: 0;
    text-align: start;
    cursor: pointer;
}
.admin-project-image-chip span {
    position: absolute;
    inset-inline-start: 10px;
    inset-block-end: 10px;
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(239,68,68,0.92);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
}
.admin-project-images-existing-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}
.admin-project-cost-summary {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
.admin-project-cost-summary div {
    padding: 14px;
    border-radius: 18px;
    background: rgba(2, 6, 23, 0.45);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-project-cost-summary span {
    display: block;
    margin-bottom: 8px;
    color: #94a3b8;
    font-size: .8rem;
    font-weight: 700;
}
.admin-project-cost-summary strong {
    font-size: 1rem;
    color: #f8fafc;
}
.admin-project-payment-history {
    position: relative;
    display: grid;
    gap: 14px;
    margin-top: 10px;
    padding-inline-start: 12px;
}
.admin-project-payment-history::before {
    content: '';
    position: absolute;
    inset-block: 8px 8px;
    inset-inline-start: 22px;
    width: 2px;
    background: linear-gradient(180deg, rgba(167,139,250,0.1), rgba(96,165,250,0.7), rgba(52,211,153,0.25));
    border-radius: 999px;
}
.admin-project-payment-timeline-item {
    position: relative;
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
}
.admin-project-payment-timeline-dot {
    width: 16px;
    height: 16px;
    margin-top: 18px;
    margin-inline-start: 6px;
    border-radius: 50%;
    border: 3px solid #0b1020;
    box-shadow: 0 0 0 6px rgba(124,58,237,0.08);
    background: linear-gradient(180deg, #c4b5fd, #60a5fa);
    z-index: 1;
}
.admin-project-payment-timeline-item.is-paid .admin-project-payment-timeline-dot {
    background: linear-gradient(180deg, #34d399, #10b981);
    box-shadow: 0 0 0 6px rgba(16,185,129,0.12);
}
.admin-project-payment-timeline-item.is-waiting .admin-project-payment-timeline-dot {
    background: linear-gradient(180deg, #fbbf24, #f59e0b);
    box-shadow: 0 0 0 6px rgba(245,158,11,0.12);
}
.admin-project-payment-timeline-item.is-scheduled .admin-project-payment-timeline-dot {
    background: linear-gradient(180deg, #93c5fd, #60a5fa);
    box-shadow: 0 0 0 6px rgba(96,165,250,0.12);
}
.admin-project-payment-history-item {
    padding: 14px 14px 12px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(10,14,29,0.95), rgba(2,6,23,0.55));
    border: 1px solid rgba(255,255,255,0.07);
    box-shadow: 0 16px 34px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.03);
    color: #e2e8f0;
}
.admin-project-payment-history-item > div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    font-size: .86rem;
}
.admin-project-payment-history-top {
    align-items: center;
}
.admin-project-payment-history-heading {
    display: grid;
    gap: 4px;
}
.admin-project-payment-history-item strong { color: #f8fafc; }
.admin-project-payment-history-item span,
.admin-project-payment-history-item p {
    color: #94a3b8;
    margin: 0;
    line-height: 1.6;
}
.admin-project-payment-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.admin-project-payment-meta-chip {
    padding: 10px 12px;
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-project-payment-meta-chip span {
    display: block;
    margin-bottom: 4px;
    color: #94a3b8;
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.admin-project-payment-meta-chip strong {
    display: block;
    color: #f8fafc;
    font-size: .9rem;
    font-weight: 700;
    word-break: break-word;
}
.admin-project-payment-note {
    padding-top: 2px;
}
.admin-payment-shell,
.admin-payment-entry-shell {
    width: min(1180px, 100%);
}
.admin-payment-hero {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}
.admin-payment-hero > div,
.admin-payment-entry-mini-card {
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(124,58,237,0.14), rgba(2,6,23,0.5));
    border: 1px solid rgba(168,85,247,0.16);
}
.admin-payment-hero-label,
.admin-payment-entry-mini-card span {
    display: block;
    margin-bottom: 8px;
    color: #a5b4fc;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.admin-payment-hero strong,
.admin-payment-entry-mini-card strong {
    font-size: 1.15rem;
    color: #f8fafc;
}
.admin-payment-grid,
.admin-payment-entry-grid {
    grid-template-columns: 1.35fr .95fr;
}
.admin-payment-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 14px;
}
.admin-payment-panel-head h3 { margin: 0; }
.admin-payment-panel-head p { margin: 6px 0 0; }
.admin-payment-history-panel { min-height: 360px; }
.admin-payment-entry-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    align-content: start;
}
.admin-payment-entry-badge {
    grid-column: 1 / -1;
    padding: 12px 14px;
    border-radius: 999px;
    text-align: center;
    background: rgba(59,130,246,0.14);
    border: 1px solid rgba(96,165,250,0.18);
    color: #dbeafe;
    font-weight: 800;
    letter-spacing: .04em;
}
.admin-payment-entry-shell .admin-modal-section {
    min-height: 100%;
}
.admin-daily-logs-shell { width: min(1260px, 100%); }
.admin-daily-logs-hero {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}
.admin-daily-logs-hero > div {
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(14,21,43,0.95), rgba(2,6,23,0.55));
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-daily-logs-selected-card {
    display: grid;
    gap: 4px;
    background: linear-gradient(180deg, rgba(59,130,246,0.16), rgba(2,6,23,0.55)) !important;
    border-color: rgba(96,165,250,0.24) !important;
}
.admin-daily-logs-selected-card strong { font-size: 1rem; line-height: 1.35; }
.admin-daily-logs-selected-card small { color: #bfdbfe; font-size: .78rem; line-height: 1.5; }
.admin-daily-logs-hero span,
.admin-daily-logs-day-chip,
.admin-daily-log-day i {
    display: block;
    margin-bottom: 6px;
    color: #94a3b8;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .03em;
}
.admin-daily-logs-hero strong {
    color: #f8fafc;
    font-size: 1.02rem;
}
.admin-daily-logs-grid {
    grid-template-columns: .92fr 1.08fr;
}
.admin-daily-logs-list-panel {
    min-height: 560px;
}
.admin-daily-logs-editor-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 14px;
}
.admin-daily-logs-editor-head h3 { margin: 0; }
.admin-daily-logs-editor-head p { margin: 6px 0 0; }
.admin-daily-logs-day-chip {
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid rgba(96,165,250,0.18);
    background: rgba(59,130,246,0.12);
    color: #dbeafe;
    white-space: nowrap;
}
.admin-daily-logs-list {
    display: grid;
    gap: 10px;
    max-height: 650px;
    overflow: auto;
    padding-inline-end: 4px;
}
.admin-daily-log-day {
    display: grid;
    gap: 4px;
    text-align: right;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.03);
    color: #e2e8f0;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.admin-daily-log-day:hover {
    transform: translateY(-1px);
    border-color: rgba(96,165,250,0.18);
    background: rgba(59,130,246,0.08);
}
.admin-daily-log-day strong { color: #f8fafc; font-size: .96rem; }
.admin-daily-log-day span { color: #93c5fd; font-size: .8rem; }
.admin-daily-log-day i { margin-bottom: 0; }
.admin-daily-log-day.is-done { border-color: rgba(52,211,153,0.18); }
.admin-daily-log-day.is-open { border-color: rgba(251,191,36,0.18); }
.admin-daily-log-day.is-empty {
    opacity: .82;
    background: linear-gradient(180deg, rgba(124,58,237,0.12), rgba(255,255,255,0.03));
    border-color: rgba(167,139,250,0.16);
}
.admin-daily-log-day.is-active {
    border-color: rgba(96,165,250,0.38);
    background: rgba(59,130,246,0.14);
    box-shadow: 0 0 0 1px rgba(96,165,250,0.12), 0 14px 30px rgba(15,23,42,0.22);
}
.admin-daily-log-day.is-done i { color: #86efac; }
.admin-daily-log-day.is-open i { color: #fde68a; }
.admin-daily-log-day.is-empty i { color: #c4b5fd; }
.admin-daily-log-day.is-empty span { color: #a78bfa; }
.admin-daily-log-day.is-done {
    background: linear-gradient(180deg, rgba(16,185,129,0.12), rgba(255,255,255,0.03));
}
.admin-daily-log-day.is-open {
    background: linear-gradient(180deg, rgba(245,158,11,0.12), rgba(255,255,255,0.03));
}
.admin-project-daily-log-gallery {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 10px;
}
.admin-project-daily-log-image {
    position: relative;
    overflow: hidden;
    display: block;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2,6,23,0.55);
}
.admin-project-daily-log-image img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}
.admin-project-daily-log-image-chip {
    padding: 0;
    cursor: pointer;
}
.admin-project-daily-log-image-chip span {
    position: absolute;
    inset-inline: 8px;
    inset-block-end: 8px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(15,23,42,0.9);
    color: #fff;
    font-size: .74rem;
    font-weight: 800;
    text-align: center;
}
.admin-daily-logs-progress {
    margin-bottom: 16px;
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(14,21,43,0.95), rgba(2,6,23,0.55));
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-daily-logs-progress-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    margin-bottom: 10px;
}
.admin-daily-logs-progress-head span { color: #94a3b8; font-size: .78rem; font-weight: 800; }
.admin-daily-logs-progress-head strong { color: #f8fafc; }
.admin-daily-logs-progress-track {
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255,255,255,0.05);
}
.admin-daily-logs-progress-fill {
    height: 100%;
    width: 0;
    border-radius: inherit;
    background: linear-gradient(90deg, #60a5fa, #34d399);
}
.admin-daily-log-slider {
    display: grid;
    gap: 12px;
}
.admin-daily-log-slider-stage {
    position: relative;
    overflow: hidden;
    min-height: 280px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(2,6,23,0.55);
}
.admin-daily-log-slider-stage img {
    width: 100%;
    height: 280px;
    object-fit: cover;
    display: block;
}
.admin-daily-log-slider-thumbs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}
.admin-daily-log-thumb {
    flex: 0 0 72px;
    padding: 0;
    overflow: hidden;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    cursor: pointer;
    opacity: .82;
    scroll-snap-align: start;
}
.admin-daily-log-thumb.is-active {
    border-color: rgba(96,165,250,0.4);
    box-shadow: 0 0 0 1px rgba(96,165,250,0.14);
    opacity: 1;
}
.admin-daily-log-thumb img {
    display: block;
    width: 100%;
    height: 56px;
    object-fit: cover;
}
.admin-daily-log-slider-meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}
.admin-daily-log-slider-meta strong { color: #f8fafc; }
.admin-daily-log-slider-meta span { color: #94a3b8; }
.admin-daily-log-slider-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.admin-daily-log-delete-confirm {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(2,6,23,0.72);
    backdrop-filter: blur(6px);
    z-index: 6;
}
.admin-daily-log-delete-confirm-panel {
    width: min(520px, 100%);
    padding: 18px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(14,21,43,0.98), rgba(2,6,23,0.98));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 24px 50px rgba(0,0,0,0.35);
}
.admin-daily-log-delete-confirm-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 14px;
}
.admin-daily-log-delete-confirm-head h3 { margin: 0; }
.admin-daily-log-delete-confirm-head p { margin: 6px 0 0; }
.admin-daily-log-delete-confirm[hidden] { display: none; }
.admin-client-project-card {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 16px;
    padding: 14px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.03);
}
.admin-client-project-media {
    overflow: hidden;
    border-radius: 18px;
    min-height: 180px;
    background: rgba(2, 6, 23, 0.55);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-client-project-media img {
    width: 100%;
    height: 100%;
    min-height: 180px;
    object-fit: cover;
    display: block;
}
.admin-client-project-placeholder {
    min-height: 180px;
    display: grid;
    place-items: center;
    color: #cbd5e1;
    font-weight: 800;
    letter-spacing: .04em;
}
.admin-client-project-body {
    display: grid;
    gap: 12px;
    align-content: start;
}
.admin-client-project-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    align-items: start;
}
.admin-client-project-head h2 {
    margin: 6px 0 0;
    font-size: 1.15rem;
}
.admin-client-project-description,
.admin-client-project-notes {
    margin: 0;
    color: #e5e7eb;
    line-height: 1.75;
}
.admin-client-project-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.admin-client-project-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}
.admin-client-project-meta div {
    padding: 10px 12px;
    border-radius: 16px;
    background: rgba(2, 6, 23, 0.45);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-client-project-meta span {
    display: block;
    margin-bottom: 6px;
    color: #94a3b8;
    font-size: .78rem;
}
.admin-client-project-meta strong { font-size: .95rem; }
.admin-modal-help-box a { color: #93c5fd; }
.admin-project-create-grid [data-project-domain-field],
.admin-project-create-grid [data-project-hosting-field] {
    display: grid;
}
.admin-project-create-grid [hidden] {
    display: none !important;
}
.admin-goal-table-card .admin-topbar-compact h1,
.admin-goal-tabs-card .admin-topbar-compact h1 { font-size: 1rem; }
.admin-goal-actions form { margin: 0; }
.admin-pagination-wrap { margin-top: 18px; display: flex; justify-content: center; }
.admin-table-media {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.admin-table-media span {
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #eae7f9;
    font-size: .76rem;
}
.admin-table-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.admin-table-actions .btn svg {
    width: 18px;
    height: 18px;
}
.admin-table-actions .btn {
    gap: 8px;
}
.admin-table-actions form { margin: 0; }
.admin-client-project-table .is-hidden-column { display: none; }
.admin-cost-table {
    margin-top: 10px;
    border-collapse: separate;
    border-spacing: 0;
}
.admin-cost-table thead th,
.admin-cost-table tbody td {
    padding-top: 16px;
    padding-bottom: 16px;
}
.admin-cost-table tbody tr td:first-child {
    border-start-start-radius: 16px;
    border-end-start-radius: 16px;
}
.admin-cost-table tbody tr td:last-child {
    border-start-end-radius: 16px;
    border-end-end-radius: 16px;
}
.admin-cost-filters {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}
.admin-cost-filters .admin-input {
    min-width: 150px;
    height: 42px;
}
.admin-banks-filters {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    flex-wrap: wrap;
    margin: 0;
    padding: 12px 14px;
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 16px;
    background: rgba(7, 10, 22, 0.45);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
    width: 100%;
}
.admin-banks-filters .admin-input {
    width: auto;
    flex: 1 1 170px;
    min-width: 170px;
    max-width: 220px;
    height: 42px;
}
.admin-topbar-compact .admin-banks-filters {
    flex: 1 1 100%;
    order: 2;
    justify-content: flex-start;
}
.admin-table-card .admin-table {
    margin-top: 10px;
    width: calc(100% - 18px);
    margin-inline: auto;
}
.admin-course-thumb {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    overflow: hidden;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(124,58,237,0.24), rgba(251,146,60,0.14));
    border: 1px solid rgba(168,85,247,0.14);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 12px 24px rgba(0,0,0,0.18);
}
.admin-course-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.admin-course-thumb span {
    color: #f3e8ff;
    font-weight: 900;
    font-size: 1.1rem;
    line-height: 1;
}
.admin-course-image-preview {
    min-height: 220px;
    border-radius: 20px;
    border: 1px solid rgba(168,85,247,0.12);
    background:
        radial-gradient(circle at 20% 0%, rgba(251,146,60,0.12), transparent 28%),
        linear-gradient(135deg, rgba(16,18,38,0.96), rgba(9,12,25,0.98));
    display: grid;
    place-items: center;
    overflow: hidden;
    margin-bottom: 12px;
}
.admin-course-image-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.admin-course-image-preview-empty {
    color: #d7d2ea;
    font-size: .92rem;
    font-weight: 700;
    padding: 14px;
    text-align: center;
}
.admin-table-card thead th {
    background: rgba(255,255,255,0.03);
    font-size: .84rem;
    letter-spacing: .02em;
}
.admin-table-card tbody tr:hover {
    background: rgba(255,255,255,0.03);
}
.admin-pagination-wrap {
    margin-top: 14px;
    display: flex;
    justify-content: center;
    padding: 0 18px;
}
.admin-table-card tbody td,
.admin-table-card thead th {
    padding-inline: 14px;
}
.admin-ad-table td strong {
    display: block;
    margin-bottom: 4px;
    font-size: .94rem;
}
.admin-homepage-form-grid { margin-top: 4px; }
.admin-preview-note {
    margin-top: 12px;
    color: var(--muted);
    font-size: .88rem;
    line-height: 1.7;
}
.admin-card-icon {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(124,58,237,0.16);
    border: 1px solid rgba(168,85,247,0.18);
    margin-bottom: 10px;
    color: #e9d5ff;
}
.admin-icon svg {
    width: 18px;
    height: 18px;
    display: block;
}
.admin-project-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.admin-table-card { padding: 0 0 18px; }
.admin-projects-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-project-create-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-span-2 { grid-column: span 2; }
.admin-project-card {
    display: grid;
    gap: 14px;
    min-height: 100%;
}
.admin-project-thumb {
    aspect-ratio: 16 / 9;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
}
.admin-project-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.admin-project-meta h2 { margin: 10px 0 8px; }
.admin-project-slug {
    display: inline-flex;
    margin-top: 10px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(124,58,237,0.12);
    color: #e9d5ff;
    font-size: .82rem;
    font-weight: 800;
}
.admin-summary-stats {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.admin-summary-stats div {
    min-width: 132px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-summary-stats strong { display: block; font-size: .92rem; }
.admin-summary-stats span { color: var(--muted); font-size: .78rem; }
.admin-project-toc {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 12px 14px;
}
.admin-project-toc a {
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(124,58,237,0.12);
    border: 1px solid rgba(168,85,247,0.18);
    color: #f0e7ff;
    font-weight: 800;
    font-size: .82rem;
}
.admin-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0;
}
.admin-kpi-card { display: grid; gap: 8px; }
.admin-kpi-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: inline-grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(124,58,237,0.26), rgba(34,211,238,0.16));
    border: 1px solid rgba(168,85,247,0.2);
    color: #f5eaff;
    box-shadow: 0 14px 28px rgba(124,58,237,0.16), inset 0 1px 0 rgba(255,255,255,0.05);
}
.admin-kpi-icon svg { width: 24px; height: 24px; }
.admin-kpi-icon-rocket,
.admin-kpi-icon-wallet,
.admin-kpi-icon-layout,
.admin-kpi-icon-target,
.admin-kpi-icon-users,
.admin-kpi-icon-bank-strong {
    background: linear-gradient(135deg, rgba(168,85,247,0.34), rgba(124,58,237,0.18));
}
.admin-kpi-icon-megaphone,
.admin-kpi-icon-trending,
.admin-kpi-icon-addon,
.admin-kpi-icon-transfer {
    background: linear-gradient(135deg, rgba(56,189,248,0.28), rgba(124,58,237,0.16));
}
.admin-kpi-icon-briefcase,
.admin-kpi-icon-receipt,
.admin-kpi-icon-clipboard,
.admin-kpi-icon-book,
.admin-kpi-icon-journal {
    background: linear-gradient(135deg, rgba(245,158,11,0.26), rgba(124,58,237,0.16));
}
.admin-kpi-icon-inbox,
.admin-kpi-icon-user-star,
.admin-kpi-icon-link-user,
.admin-kpi-icon-spark-user,
.admin-kpi-icon-settings {
    background: linear-gradient(135deg, rgba(34,197,94,0.26), rgba(124,58,237,0.16));
}
.admin-kpi-icon-bank,
.admin-kpi-icon-note-check,
.admin-kpi-icon-shield-goal,
.admin-kpi-icon-shield-note {
    background: linear-gradient(135deg, rgba(244,63,94,0.24), rgba(168,85,247,0.16));
}
.admin-kpi-card span { color: var(--muted); font-size: .84rem; }
.admin-kpi-card strong { font-size: 1.6rem; line-height: 1; }
.admin-kpi-card p { margin: 0; color: var(--muted); }
.admin-donut-card {
    display: grid;
    grid-template-columns: 152px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    margin: 6px 0 12px;
}
.admin-donut {
    width: 152px;
    height: 152px;
    border-radius: 50%;
    background: conic-gradient(var(--donut-color) 0 calc(var(--donut-value) * 1%), rgba(255,255,255,0.08) 0 100%);
    position: relative;
    display: grid;
    place-items: center;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06), 0 16px 30px rgba(0,0,0,0.18);
}
.admin-donut::before {
    content: '';
    position: absolute;
    inset: 16px;
    border-radius: 50%;
    background: linear-gradient(180deg, rgba(11,16,31,0.98), rgba(7,10,22,0.98));
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-donut-center {
    position: relative;
    z-index: 1;
    text-align: center;
}
.admin-donut-center strong {
    display: block;
    font-size: 1.9rem;
    line-height: 1;
    color: #fff;
}
.admin-donut-center span {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: .8rem;
    font-weight: 700;
}
.admin-donut-legend {
    display: grid;
    gap: 10px;
}
.admin-donut-legend span {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #eef2ff;
    font-weight: 700;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
}
.admin-donut-legend i {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 0 6px rgba(255,255,255,0.04);
}
.admin-saas-grid { grid-template-columns: 1.2fr .8fr; align-items: stretch; margin-bottom: 18px; }
.admin-chart-card { display: grid; gap: 16px; }
.admin-chart-bars { display: grid; gap: 14px; }
.admin-chart-row { display: grid; gap: 8px; }
.admin-chart-meta { display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.admin-chart-meta strong { font-size: .9rem; }
.admin-chart-meta span { color: #e9d5ff; font-weight: 800; }
.admin-chart-track {
    height: 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    overflow: hidden;
}
.admin-chart-track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #a855f7, #7c3aed, #4f46e5);
}
.admin-mini-panel { display: grid; gap: 14px; align-content: start; }
.admin-mini-panel h2 { margin: 0; font-size: 1.2rem; }
.admin-repeater-card { display: grid; gap: 16px; }
.admin-repeater { display: grid; gap: 12px; }
.admin-hero-lead-card {
    padding: 22px;
    gap: 16px;
    max-height: none;
    overflow: visible;
}
.admin-hero-lead-card h1 { font-size: 1.55rem; margin-top: 6px; }
.admin-hero-lead-card .admin-topbar { margin-bottom: 10px; }
.admin-hero-lead-card .admin-repeater { gap: 12px; }
.admin-hero-lead-card .admin-repeater-row {
    padding: 14px;
    gap: 12px;
}
.admin-hero-lead-card .admin-input {
    min-height: 44px;
    font-size: .92rem;
}
.admin-hero-lead-card .btn {
    padding: 10px 14px;
    font-size: .85rem;
}
.admin-repeater-row,
.admin-feature-card,
.admin-service-card,
.admin-gallery-card,
.admin-faq-card {
    padding: 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
}
.admin-repeater-row { display: flex; gap: 12px; align-items: center; }
.admin-order-badge {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(108, 92, 231, 0.18);
    color: #e9e6ff;
    font-weight: 800;
    font-size: .85rem;
    flex: 0 0 auto;
}
.admin-drag-handle {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    background: rgba(7, 10, 22, 0.75);
    color: #cfd7ff;
    cursor: grab;
    flex: 0 0 auto;
    user-select: none;
    touch-action: none;
    -webkit-user-drag: element;
}
.admin-drag-handle svg { width: 16px; height: 16px; }
.admin-repeater-row.is-dragging {
    opacity: .55;
    transform: scale(.99);
}
.admin-repeater-row.is-drop-target {
    outline: 1px solid rgba(80, 200, 255, 0.55);
    background: rgba(80, 200, 255, 0.08);
}
.admin-lessons-groups {
    display: grid;
    gap: 14px;
}
.admin-lesson-section {
    display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
}
.admin-lesson-section.is-current {
    background: rgba(7, 10, 22, 0.44);
}
.admin-lesson-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: #eef2ff;
}
.admin-lesson-cards {
    display: grid;
    gap: 10px;
}
.admin-lesson-card {
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(7, 10, 22, 0.72);
    display: grid;
    gap: 10px;
    cursor: grab;
}
.admin-lesson-card-head,
.admin-lesson-card-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}
.admin-lesson-card.is-dragging {
    opacity: .55;
}
.admin-lesson-card.is-drop-target {
    outline: 1px solid rgba(80, 200, 255, 0.55);
    background: rgba(80, 200, 255, 0.08);
}
.admin-lesson-card.is-static {
    cursor: default;
}
.admin-lesson-drag {
    margin-inline-end: 8px;
}
.admin-lessons-current {
    display: grid;
    gap: 12px;
    margin-bottom: 14px;
}
.admin-current-tabs {
    display: grid;
    gap: 12px;
}
.admin-current-tabs-nav {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.admin-current-tab {
    --tab-bg: rgba(7, 10, 22, 0.72);
    --tab-border: rgba(255,255,255,0.08);
    border: 1px solid var(--tab-border);
    background: linear-gradient(180deg, var(--tab-bg), rgba(7, 10, 22, 0.82));
    color: #dfe6ff;
    border-radius: 18px;
    padding: 12px 14px;
    font-weight: 800;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 170px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.admin-current-tab.is-active {
    background: linear-gradient(180deg, rgba(86, 124, 255, 0.24), rgba(86, 124, 255, 0.12));
    color: #fff;
    border-color: rgba(86, 124, 255, 0.45);
}
.admin-current-tab-icon {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: rgba(255,255,255,0.06);
    color: #fff;
    flex: 0 0 auto;
}
.admin-current-tab-icon svg {
    width: 16px;
    height: 16px;
}
.admin-current-tab-text {
    display: grid;
    gap: 2px;
    text-align: start;
}
.admin-current-tab-text strong {
    font-size: .95rem;
    line-height: 1.2;
}
.admin-current-tab-text small {
    color: rgba(223, 230, 255, 0.76);
    font-size: .78rem;
    font-weight: 700;
}
.admin-current-tabs-panels {
    display: grid;
}
.admin-current-tab-panel {
    display: none;
}
.admin-current-tab-panel.is-active {
    display: block;
}
.projects-empty-inline {
    padding: 18px 12px;
}
.admin-feature-card,
.admin-service-card,
.admin-gallery-card,
.admin-faq-card { display: grid; gap: 12px; }
.admin-gallery-preview {
    min-height: 170px;
    border-radius: 18px;
    border: 1px dashed rgba(255,255,255,0.12);
    background: rgba(7,10,22,0.72);
    background-size: cover;
    background-position: center;
}
.admin-hero-image-preview {
    min-height: 220px;
    border-radius: 18px;
    border: 1px dashed rgba(255,255,255,0.12);
    background: rgba(7,10,22,0.72);
    display: grid;
    place-items: center;
    overflow: hidden;
}
.admin-hero-image-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.admin-mt-12 { margin-top: 12px; }
.admin-mt-16 { margin-top: 16px; }
.admin-login-note-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}
.admin-table-card { overflow: hidden; padding: 0; }
.admin-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.admin-table th,
.admin-table td {
    padding: 12px 14px;
    text-align: right;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    vertical-align: top;
}
.admin-table thead th {
    background: linear-gradient(180deg, rgba(124,58,237,0.16), rgba(255,255,255,0.04));
    border-bottom: 1px solid rgba(168,85,247,0.12);
}
.admin-table tbody tr:hover { background: rgba(124,58,237,0.07); }
.admin-status-pill {
    border-color: rgba(168,85,247,0.16);
    background: rgba(124,58,237,0.1);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.admin-table th {
    color: #e9d5ff;
    font-size: .82rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: rgba(255,255,255,0.03);
}
.admin-table tr:hover td { background: rgba(255,255,255,0.02); }
.admin-tech-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.admin-tech-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    cursor: pointer;
}
.admin-tech-chip input { accent-color: #a855f7; }
.admin-tech-chip svg {
    width: 18px;
    height: 18px;
    color: #d8b4fe;
    flex-shrink: 0;
}
.admin-tech-chip strong { font-size: .9rem; }
.auth-shell {
    display: grid;
    align-items: center;
    min-height: 100vh;
}
.admin-auth-grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 20px;
    align-items: stretch;
}
.admin-auth-aside {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    border: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(180deg, rgba(12, 16, 33, 0.9), rgba(7, 10, 22, 0.9));
    box-shadow: var(--shadow);
    padding: 28px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 640px;
}
.admin-brand { align-self: flex-start; }
.admin-auth-copy { position: relative; z-index: 2; max-width: 560px; }
.admin-auth-copy h1 { margin: 8px 0 12px; font-size: clamp(2.4rem, 4vw, 4rem); }
.admin-auth-list {
    display: grid;
    gap: 12px;
    margin-top: 24px;
}
.admin-auth-list div {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: #ece7ff;
    font-weight: 700;
}
.admin-auth-list span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: linear-gradient(135deg, #a855f7, #7c3aed);
    box-shadow: 0 0 0 6px rgba(124,58,237,0.12);
    flex-shrink: 0;
}
.admin-auth-figure {
    position: relative;
    min-height: 230px;
    margin-top: 24px;
}
.admin-auth-orb {
    position: absolute;
    inset: 22px 0 auto auto;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(168,85,247,0.2), transparent 62%);
    filter: blur(8px);
}
.admin-auth-frame {
    position: absolute;
    right: 40px;
    bottom: 0;
    width: min(460px, 100%);
    padding: 18px;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(22, 24, 49, 0.92), rgba(12, 16, 33, 0.88));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow);
}
.admin-auth-bar {
    height: 18px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(168,85,247,0.95), rgba(124,58,237,0.55));
    width: 46%;
    margin-bottom: 16px;
}
.admin-auth-bars { display: grid; gap: 10px; }
.admin-auth-bars span { display: block; height: 10px; border-radius: 999px; background: rgba(255,255,255,0.08); }
.admin-auth-bars span:nth-child(2) { width: 76%; }
.admin-auth-bars span:nth-child(3) { width: 54%; }
.admin-badge {
    display: inline-flex;
    align-self: flex-start;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(124,58,237,0.14);
    border: 1px solid rgba(168,85,247,0.16);
    color: #efe5ff;
    font-size: .86rem;
    font-weight: 800;
}
.admin-center {
    display: grid;
    place-items: center;
    min-height: calc(100vh - 80px);
}
.admin-card {
    background:
        radial-gradient(circle at 0% 0%, rgba(168,85,247,0.12), transparent 28%),
        linear-gradient(180deg, rgba(18, 23, 47, 0.94), rgba(10, 14, 28, 0.9));
    border: 1px solid rgba(168,85,247,0.12);
    border-radius: var(--radius);
    box-shadow: 0 24px 60px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.03);
    padding: 18px;
}
.admin-page .admin-card,
.admin-page .admin-table-card,
.admin-page .admin-chart-card,
.admin-page .admin-group-card,
.admin-page .admin-mini-panel,
.admin-page .admin-hero-lead-card,
.admin-page .admin-dashboard-hero {
    border-color: rgba(168,85,247,0.14);
    box-shadow: 0 22px 60px rgba(124,58,237,0.14), 0 18px 40px rgba(0,0,0,0.26);
}
.admin-login-card {
    width: min(560px, 100%);
}
.admin-login-card h2 { margin: 10px 0 8px; font-size: clamp(1.8rem, 2.8vw, 2.4rem); }
.admin-card h1, .admin-topbar h1 {
    margin: 8px 0 0;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
}
.admin-muted { color: var(--muted); line-height: 1.9; }
.admin-note { color: var(--muted); margin-top: 12px; line-height: 1.8; }
.admin-backlink {
    display: inline-flex;
    margin-top: 18px;
    color: #d8b4fe;
    font-weight: 800;
}
.admin-alert, .admin-success {
    margin: 16px 0;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.08);
}
.admin-alert { background: rgba(239,68,68,0.12); color: #fecaca; }
.admin-success { background: rgba(34,197,94,0.12); color: #bbf7d0; }
.admin-form { display: grid; gap: 14px; }
.admin-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-form-head,
.admin-form > .admin-actions,
.admin-form > .admin-row,
.admin-form > .admin-span-2 {
    grid-column: 1 / -1;
}
.admin-form > .admin-card,
.admin-form > .admin-repeater-card {
    padding: 12px;
}
.admin-form label span { display: block; margin-bottom: 6px; color: #eae7f9; font-weight: 700; font-size: .85rem; }
.admin-input, .admin-textarea {
    width: 100%;
    border: 1px solid rgba(168,85,247,0.16);
    background: rgba(7, 10, 22, 0.82);
    color: var(--text);
    border-radius: 14px;
    padding: 11px 13px;
    font: inherit;
    outline: none;
}
.admin-input { min-height: 42px; }
.admin-textarea { min-height: 180px; resize: vertical; line-height: 1.65; font-family: Consolas, 'Courier New', monospace; }
.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
    flex-wrap: wrap;
    padding: 12px 14px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(124,58,237,0.08), rgba(255,255,255,0.03));
    border: 1px solid rgba(168,85,247,0.12);
}
.admin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.admin-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}
.admin-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-editor { width: min(100%, 1200px); }

@media (max-width: 1280px) {
    .admin-layout { grid-template-columns: clamp(214px, 19vw, 244px) minmax(0, 1fr); }
    .admin-content { padding: 14px; }
    .admin-sidebar { padding: 10px 9px 10px; }
    .admin-sidebar-panel,
    .admin-nav-group,
    .admin-sidebar-footer,
    .admin-sidebar .admin-brand { border-radius: 16px; }
    .admin-sidebar-cta { min-height: 38px; padding-inline: 10px; }
    .admin-sidebar-note { font-size: .73rem; }
    .admin-sidebar-toggle { width: 34px; height: 34px; }
}

@media (max-width: 1440px) and (max-height: 920px) and (min-width: 961px) {
    .admin-layout { grid-template-columns: clamp(188px, 16vw, 214px) minmax(0, 1fr); }
    .admin-sidebar { padding: 6px 6px 6px; gap: 6px; top: 18px; height: calc(100vh - 36px); }
    .admin-sidebar .admin-brand { padding: 6px 8px; }
    .admin-sidebar .brand-mark { width: 40px; height: 40px; }
    .admin-sidebar .brand-text strong { font-size: .92rem; }
    .admin-sidebar .brand-text span { font-size: .7rem; }
    .admin-sidebar-note { font-size: .67rem; line-height: 1.4; }
    .admin-sidebar-scroll { gap: 4px; padding-block: 2px 6px; }
    .admin-sidebar-panel,
    .admin-nav-group,
    .admin-sidebar-footer { padding: 6px; }
    .admin-sidebar-actions { gap: 4px; margin-top: 4px; }
    .admin-sidebar-cta { min-height: 32px; padding-inline: 8px; border-radius: 12px; font-size: .84rem; }
    .admin-sidebar-cta svg { width: 13px; height: 13px; }
    .admin-sidebar-label,
    .admin-nav-title { font-size: .64rem; }
    .admin-sidebar-footer strong { font-size: .92rem; }
    .admin-sidebar-footer p { font-size: .75rem; }
    .admin-sidebar-footer { gap: 0; padding: 6px; }
    .admin-sidebar-footer .btn { min-height: 32px; }
}

@media (hover: none) {
    .admin-sidebar-collapsed .admin-sidebar-cta::before,
    .admin-sidebar-collapsed .admin-sidebar-cta::after,
    .admin-sidebar-collapsed .admin-sidebar-footer .btn::before,
    .admin-sidebar-collapsed .admin-sidebar-footer .btn::after {
        display: none;
    }
}

@media (max-width: 1100px) {
    .admin-layout { grid-template-columns: clamp(200px, 22vw, 228px) minmax(0, 1fr); }
    .admin-sidebar { padding: 9px 8px 9px; }
    .admin-sidebar-actions { gap: 6px; }
    .admin-sidebar-cta { min-height: 36px; }
    .admin-sidebar .admin-brand { padding: 9px 10px; }
    .admin-sidebar .brand-mark { width: 46px; height: 46px; }
    .admin-sidebar .brand-mark svg { width: 24px; height: 24px; }
    .admin-sidebar .brand-text strong { font-size: .96rem; }
    .admin-sidebar .brand-text span { font-size: .74rem; }
    .admin-sidebar-toggle { width: 32px; height: 32px; }
}

@media (max-width: 960px) {
    .admin-layout { grid-template-columns: 1fr; }
    .admin-sidebar {
        position: relative;
        height: auto;
        border-left: 0;
        border-bottom: 1px solid rgba(255,255,255,0.06);
        box-shadow: inset 0 -1px 0 rgba(255,255,255,0.03), 0 10px 26px rgba(0,0,0,0.12);
    }
    .admin-sidebar-toggle { display: none; }
    .admin-content { padding: 14px; }
}

@media (max-width: 720px) {
    .admin-layout { grid-template-columns: 1fr; }
    .admin-sidebar { position: relative; height: auto; border-left: 0; border-bottom: 1px solid rgba(255,255,255,0.06); }
    .admin-content { padding: 14px; }
    .admin-header { flex-wrap: wrap; }
    .admin-header-actions { width: 100%; }
    .admin-sub-stats { grid-template-columns: 1fr; }
    .admin-auth-grid { grid-template-columns: 1fr; }
    .admin-auth-aside { min-height: auto; padding: 22px; }
    .admin-auth-figure { display: none; }
    .admin-grid { grid-template-columns: 1fr; }
    .admin-section-grid { grid-template-columns: 1fr; }
    .admin-tech-grid { grid-template-columns: 1fr; }
    .admin-kpi-grid, .admin-saas-grid { grid-template-columns: 1fr; }
    .admin-project-summary { flex-direction: column; align-items: flex-start; }
    .admin-projects-grid { grid-template-columns: 1fr; }
    .admin-topbar, .admin-row { flex-direction: column; align-items: flex-start; }
    .admin-textarea { min-height: 320px; }
    .admin-repeater-row { flex-direction: column; align-items: stretch; }
    .admin-table { display: block; overflow-x: auto; }
    .admin-dashboard-hero { grid-template-columns: 1fr; padding: 20px; }
    .admin-summary-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); display: grid; }
    .admin-summary-strip > div[data-priority="1"] { order: 1; }
    .admin-summary-strip > div[data-priority="2"] { order: 2; }
    .admin-summary-strip > div[data-priority="3"] { order: 3; }
    .admin-summary-strip > div[data-priority="4"] { order: 4; }
    .admin-kpi-grid { grid-template-columns: 1fr; }
    .admin-section-card[data-priority="1"] { order: 1; }
    .admin-section-card[data-priority="2"] { order: 2; }
    .admin-section-card[data-priority="3"] { order: 3; }
    .admin-section-card[data-priority="4"] { order: 4; }
    .admin-mini-spark { height: 110px; }
    .admin-spark-legend { gap: 6px; }
    .admin-donut-card { grid-template-columns: 1fr; justify-items: center; }
    .admin-donut { width: 136px; height: 136px; }
    .admin-kpi-icon { width: 48px; height: 48px; border-radius: 16px; }
    .admin-kpi-icon svg { width: 22px; height: 22px; }
}

.admin-sidebar-collapsed .admin-sidebar .brand-text,
.admin-sidebar-collapsed .admin-sidebar-note,
.admin-sidebar-collapsed .admin-sidebar-user-meta,
.admin-sidebar-collapsed .admin-sidebar-panel .admin-sidebar-label,
.admin-sidebar-collapsed .admin-nav-title,
.admin-sidebar-collapsed .admin-sidebar-footer p,
.admin-sidebar-collapsed .admin-nav-main span:last-child {
    display: none;
}

@media (max-width: 1100px) {
    .hero-grid, .footer-grid, .grid-4, .about-grid, .contact-grid { grid-template-columns: 1fr; }
    .grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .nav { height: auto; padding: 16px 0; flex-wrap: wrap; }
    .nav-links { order: 3; width: 100%; justify-content: center; gap: 18px; flex-wrap: wrap; }
    .hero-visual { min-height: 520px; }
    .floating-card { right: 0; }
    .courses-hero { grid-template-columns: 1fr; }
    .courses-hero-stats { grid-template-columns: 1fr; }
    .course-hero { grid-template-columns: 1fr; }
    .course-meta-grid, .course-details-grid { grid-template-columns: 1fr; }
    .course-live-grid { grid-template-columns: 1fr; }
    .course-live-hero,
    .course-info-strip,
    .course-cards-grid,
    .course-bottom-grid,
    .course-recorded-layout { grid-template-columns: 1fr; }
    .course-info-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .project-hero-grid, .overview-grid, .tech-grid, .gallery-grid { grid-template-columns: 1fr; }
    .project-copy { order: 1; }
    .project-visual-card { order: 2; min-height: 440px; }
    .project-meta-grid, .features-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cta-band { flex-direction: column; align-items: flex-start; }
    .projects-filters { grid-template-columns: 1fr 1fr; }
    .admin-sub-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-page-hero-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-modal-grid { grid-template-columns: 1fr; }
    .admin-sub-filters { grid-template-columns: 1fr; }
    .admin-addon-mini-actions,
    .admin-addon-view-actions { flex-direction: column; align-items: stretch; }
    .admin-addon-view-filter { grid-template-columns: 1fr; }
    .admin-client-project-card { grid-template-columns: 1fr; }
    .admin-client-project-meta { grid-template-columns: 1fr; }
    .admin-project-preview-layout { grid-template-columns: 1fr; }
    .admin-project-preview-grid { grid-template-columns: 1fr; }
    .admin-project-preview-gallery,
    .admin-project-images-preview,
    .admin-project-images-existing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-payment-hero,
    .admin-payment-grid,
    .admin-payment-entry-grid,
    .admin-payment-entry-summary,
    .admin-project-payment-meta-grid { grid-template-columns: 1fr; }
    .admin-daily-logs-hero,
    .admin-daily-logs-grid,
    .admin-project-daily-log-gallery { grid-template-columns: 1fr; }
    .admin-daily-logs-progress-head,
    .admin-daily-log-slider-meta { flex-direction: column; align-items: flex-start; }
    .admin-project-payment-history::before { inset-inline-start: 8px; }
    .admin-project-payment-timeline-item { grid-template-columns: 16px minmax(0, 1fr); }
}

@media (max-width: 720px) {
    .grid-3 { grid-template-columns: 1fr; }
    .hero { padding-top: 24px; }
    .hero-grid { min-height: auto; }
    .hero-visual { min-height: 520px; }
    .benefits { grid-template-columns: 1fr; }
    .btn { width: 100%; }
    .hero-actions { flex-direction: column; align-items: stretch; }
    .courses-results-top { flex-direction: column; align-items: flex-start; }
    .course-actions { flex-direction: column; align-items: flex-start; }
    .course-meta-grid, .course-details-grid { grid-template-columns: 1fr; }
    .course-info-strip { grid-template-columns: 1fr; }
    .course-live-metrics { grid-template-columns: 1fr; }
    .course-recorded-layout-grid { grid-template-columns: 1fr; }
    .course-teacher-detail-grid { grid-template-columns: 1fr; }
    .course-description-panel { min-height: 280px; padding: 22px 18px 18px; }
    .course-description-panel h2 { font-size: 2.2rem; }
    .course-description-art { min-height: 126px; }
    .course-description-folder { width: 126px; height: 84px; }
    .course-description-folder-back { width: 100px; height: 68px; left: calc(50% - 62px); bottom: 28px; }
    .course-teacher-card-top { grid-template-columns: 1fr; justify-items: center; }
    .course-teacher-avatar-hero { width: 128px; height: 128px; }
    .course-teacher-card-copy { text-align: center; }
    .course-sessions-table { min-width: 560px; }
    .course-sessions-table { min-width: 560px; }
    .floating-card { width: 220px; right: 50%; transform: translateX(50%); bottom: 8%; }
    h1 { font-size: 1.95rem; }
    .lead { font-size: 1rem; }
    .project-hero-grid { min-height: auto; gap: 18px; }
    .project-visual-card { min-height: 270px; }
    .project-device.project-screen-lg { height: 230px; left: 0; top: 0; padding: 12px; }
    .project-device.project-phone { display: none; }
    .project-meta-grid, .features-grid, .gallery-grid, .overview-stats { grid-template-columns: 1fr; }
    .project-actions { flex-direction: column; }
    .project-actions .icon-only { width: 100%; }
    .price { font-size: 2.4rem; }
    .project-breadcrumbs { font-size: .72rem; gap: 6px; margin-bottom: 12px; overflow-x: auto; }
    .project-title-row { gap: 10px; }
    .project-icon-bubble { width: 48px; height: 48px; font-size: 1.1rem; box-shadow: 0 0 0 8px rgba(124,58,237,0.05); }
    .project-copy h1 { font-size: 2.08rem; }
    .tabs-row { justify-content: flex-start; padding-inline: 8px; }
    .gallery-controls { gap: 10px; }
    .gallery-controls button { width: 30px; height: 30px; }
    .overview-highlight { padding: 12px 14px; font-size: .95rem; }
    .tech-note { margin-top: 14px; font-size: .95rem; }
    .access-grid { grid-template-columns: 1fr; }
    .access-card-wide { grid-column: span 1; }
    .credential-grid { grid-template-columns: 1fr; }
    .faq-grid { grid-template-columns: 1fr; }
    .projects-filters { grid-template-columns: 1fr; }
    .projects-results-top { flex-direction: column; align-items: flex-start; }
    .admin-page-hero-stats { grid-template-columns: 1fr; }
    .admin-ads-header-actions { width: 100%; }
    .admin-ads-header-actions .btn { width: 100%; }
    .admin-sub-filters { grid-template-columns: 1fr; padding: 0; }
    .admin-addon-mini-actions,
    .admin-addon-view-actions { flex-direction: column; align-items: stretch; }
    .admin-addon-view-filter { grid-template-columns: 1fr; }
    .admin-addon-table { min-width: 680px; }
    .admin-daily-logs-editor-head { flex-direction: column; }
    .admin-daily-logs-list-panel { min-height: auto; }
    .admin-daily-log-slider-stage img { height: 220px; }
    .admin-daily-log-slider-stage { min-height: 220px; }
    .admin-daily-log-thumb { flex-basis: 64px; }
}
