/*
 * questi-theme.css
 * Applies the Questi landing-page design system to the MVC application.
 * Overrides NiceAdmin (style.css) with the Questi brand colours / fonts.
 */

/* ── Google Fonts (also referenced in _Layout) ─────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Karina&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600&family=Nunito:wght@300;400;500;600;700;800&display=swap');

/* ── Design Tokens ──────────────────────────────────────────────────── */
:root {
    --pu:  #5b4fcf;
    --pdk: #4a3fb8;
    --plt: #7b6fd8;
    --pale:#edeafb;
    --vh:  #2d1b69;
    --or:  #e8653a;
    --olt: #f07a50;
    --tl:  #3abfb1;
    --ic:  #5b4fcf;
    --gc:  #2daa88;
    --rc:  #e05252;
    --td:  #1a1a2e;
    --tb:  #4a4a6a;
    --tm:  #7a7a9a;
    --bd:  #e8e6f0;
    --bg:  #f8f7ff;
    --sh:  0 4px 20px rgba(91,79,207,.12);
    --sl:  0 12px 40px rgba(91,79,207,.18);
    --r:   14px;
    --rl:  22px;
    --rs:  8px;
    /* Bootstrap 5 colour overrides */
    --bs-primary:         #5b4fcf;
    --bs-primary-rgb:     91,79,207;
    --bs-body-font-family:'Inter', sans-serif;
    --bs-body-color:      #2d2d2d;
    --bs-body-bg:         #f8f7ff;
    --bs-border-color:    #e8e6f0;
    --bs-border-radius:   14px;
    --bs-border-radius-sm:8px;
    --bs-border-radius-lg:22px;
    --bs-link-color:      #5b4fcf;
    --bs-link-hover-color:#4a3fb8;
}

/* ── Base ───────────────────────────────────────────────────────────── */
body {
    font-family: 'Inter', sans-serif;
    color: #2d2d2d;
    background: var(--bg);
    line-height: 1.6;
}

h1,h2,h3,h4,h5,h6 {
    font-family: 'Poppins', sans-serif;
    color: var(--td);
}

a { color: var(--pu); }
a:hover { color: var(--pdk); }

.qb, .brand-font {
    font-family: 'Karina', cursive !important;
    font-style: normal !important;
    letter-spacing: .01em;
}

/* ── Navbar ─────────────────────────────────────────────────────────── */
.questi-navbar {
    background: rgba(255,255,255,.97) !important;
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--bd) !important;
    box-shadow: none !important;
    transition: box-shadow .3s;
    height: 62px;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.questi-navbar.scrolled {
    box-shadow: var(--sh) !important;
}

.questi-navbar .navbar-brand {
    font-family: 'Karina', cursive;
    font-size: 1.7rem;
    color: var(--pu) !important;
    line-height: 1;
    padding: 0;
    text-decoration: none;
}

.questi-navbar .nav-link {
    color: var(--tb) !important;
    font-size: .875rem;
    font-weight: 500;
}

.questi-navbar .nav-link:hover { color: var(--pu) !important; }

/* Navbar action buttons */
.btn-outline-questi {
    font-size: .875rem;
    font-weight: 600;
    color: var(--pu) !important;
    padding: 7px 18px;
    border-radius: 6px;
    border: 1.5px solid var(--pu) !important;
    background: transparent !important;
    transition: all .2s;
    text-decoration: none;
}
.btn-outline-questi:hover {
    background: var(--pu) !important;
    color: #fff !important;
}

.btn-questi-cta {
    background: var(--pu) !important;
    color: #fff !important;
    padding: 8px 22px;
    border-radius: 6px;
    font-size: .875rem;
    font-weight: 600;
    border: none;
    box-shadow: 0 3px 12px rgba(91,79,207,.3);
    transition: background .2s, transform .15s;
    text-decoration: none;
}
.btn-questi-cta:hover {
    background: var(--pdk) !important;
    transform: translateY(-1px);
    color: #fff !important;
}

/* Upgrade pill */
.upgrade-btn {
    font-size: .72rem;
    font-weight: 700;
    color: var(--or) !important;
    border: 1.5px solid var(--or);
    border-radius: 100px;
    padding: 4px 14px;
    transition: all .2s;
    background: transparent;
    text-decoration: none;
    white-space: nowrap;
}
.upgrade-btn:hover {
    background: var(--or);
    color: #fff !important;
}

/* User name in nav */
.user-hello {
    font-size: .875rem;
    color: var(--tb) !important;
    font-weight: 500;
}

/* Logout button */
.logout-btn {
    font-size: .875rem;
    font-weight: 500;
    color: var(--tb);
    background: none;
    border: none;
    padding: .375rem .5rem;
    transition: color .2s;
    cursor: pointer;
}
.logout-btn:hover { color: var(--pu); }

/* Toggle sidebar icon */
.toggle-sidebar-btn {
    cursor: pointer;
    filter: invert(30%) sepia(90%) saturate(400%) hue-rotate(218deg) brightness(80%) contrast(90%);
    opacity: .75;
    transition: opacity .2s;
}
.toggle-sidebar-btn:hover { opacity: 1; }

/* View toggle switch */
.switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 22px;
}
.switch input { opacity: 0; width: 0; height: 0; }
.slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--bd);
    transition: .3s;
}
.slider.round { border-radius: 22px; }
.slider::before {
    position: absolute;
    content: "";
    height: 16px; width: 16px;
    left: 3px; bottom: 3px;
    background: #fff;
    transition: .3s;
    box-shadow: 0 1px 4px rgba(0,0,0,.18);
}
.slider.round::before { border-radius: 50%; }
input:checked + .slider { background: var(--pu); }
input:checked + .slider::before { transform: translateX(18px); }

/* View label */
.userview-toggle-btn,
#userViewLink {
    font-size: .75rem;
    color: var(--tm) !important;
    text-decoration: none;
}

/* ══════════════════════════════════════════════════════════════════════
   SIDEBAR  — full Questi dark-purple override of NiceAdmin style.css
   ══════════════════════════════════════════════════════════════════════ */

/* Container */
#sidebar {
    background: linear-gradient(180deg, var(--vh) 0%, #1e0f5c 100%) !important;
    border-right: none !important;
}

/* ── Section headings ─────────────────────────────────────────────── */
#sidebar .nav-heading {
    color: rgba(255,255,255,.32) !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: .62rem !important;
    font-weight: 700 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
    padding: 18px 22px 5px !important;
    margin: 0 !important;
}

/* ── All nav-link states (override NiceAdmin .collapsed & default) ─── */
#sidebar .sidebar-nav .nav-link,
#sidebar .sidebar-nav .nav-link.collapsed {
    display: flex !important;
    align-items: center !important;
    color: rgba(255,255,255,.65) !important;
    background: transparent !important;
    border-radius: var(--rs) !important;
    margin: 2px 10px !important;
    padding: 10px 14px !important;
    font-size: .875rem !important;
    font-weight: 500 !important;
    border-left: 3px solid transparent !important;
    transition: background .2s, color .2s, border-color .2s !important;
    text-decoration: none !important;
}

/* All SVG icon images — white at 65% opacity */
#sidebar .sidebar-nav .nav-link img {
    filter: brightness(0) invert(1) !important;
    opacity: .65 !important;
    transition: opacity .2s !important;
    flex-shrink: 0;
}

/* ── Hover ────────────────────────────────────────────────────────── */
#sidebar .sidebar-nav .nav-link:hover,
#sidebar .sidebar-nav .nav-link.collapsed:hover {
    background: rgba(91,79,207,.28) !important;
    color: #fff !important;
    border-left-color: var(--plt) !important;
}
#sidebar .sidebar-nav .nav-link:hover img,
#sidebar .sidebar-nav .nav-link.collapsed:hover img {
    opacity: 1 !important;
}

/* ── Active ────────────────────────────────────────────────────────── */
#sidebar .sidebar-nav .nav-item.active > .nav-link,
#sidebar .sidebar-nav .nav-link.active {
    background: var(--pu) !important;
    color: #fff !important;
    border-left-color: transparent !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 16px rgba(91,79,207,.45) !important;
}
#sidebar .sidebar-nav .nav-item.active > .nav-link img,
#sidebar .sidebar-nav .nav-link.active img {
    opacity: 1 !important;
}

/* Active + hover — slightly deeper */
#sidebar .sidebar-nav .nav-item.active > .nav-link:hover,
#sidebar .sidebar-nav .nav-link.active:hover {
    background: var(--pdk) !important;
    box-shadow: 0 6px 20px rgba(91,79,207,.55) !important;
}

/* ── Expand toggle — when sub-menu is open (not.collapsed) ────────── */
#sidebar .sidebar-nav .nav-link:not(.collapsed) {
    background: rgba(91,79,207,.32) !important;
    color: #fff !important;
    border-left-color: var(--plt) !important;
}
#sidebar .sidebar-nav .nav-link:not(.collapsed) img { opacity: 1 !important; }

/* Chevron rotation */
#sidebar .sidebar-nav .nav-link .chevron-icon {
    filter: brightness(0) invert(1) !important;
    opacity: .55;
    transition: transform .25s ease, opacity .2s !important;
}
#sidebar .sidebar-nav .nav-link:not(.collapsed) .chevron-icon {
    transform: rotate(180deg);
    opacity: 1;
}

/* ── Sub-nav (collapse content) ──────────────────────────────────── */
#sidebar .nav-content {
    background: rgba(0,0,0,.18) !important;
    border-radius: var(--rs) !important;
    margin: 2px 10px 6px !important;
    padding: 4px 0 !important;
    list-style: none !important;
}
#sidebar .nav-content a {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    color: rgba(255,255,255,.58) !important;
    font-size: .82rem !important;
    padding: 8px 12px 8px 22px !important;
    border-left: 3px solid transparent !important;
    border-radius: var(--rs) !important;
    transition: background .2s, color .2s, border-color .2s !important;
    text-decoration: none !important;
}
/* Sub-nav hover */
#sidebar .nav-content a:hover {
    color: #fff !important;
    background: rgba(91,79,207,.25) !important;
    border-left-color: var(--plt) !important;
}
/* Sub-nav active */
#sidebar .nav-content .nav-item.active > a,
#sidebar .nav-content a.active {
    color: #fff !important;
    background: var(--pu) !important;
    border-left-color: transparent !important;
    font-weight: 600 !important;
    box-shadow: 0 3px 10px rgba(91,79,207,.4) !important;
}
#sidebar .nav-content .nav-item.active > a img,
#sidebar .nav-content a.active img {
    opacity: 1 !important;
}
/* Sub-nav active + hover */
#sidebar .nav-content .nav-item.active > a:hover,
#sidebar .nav-content a.active:hover {
    background: var(--pdk) !important;
    box-shadow: 0 4px 14px rgba(91,79,207,.5) !important;
}
/* Sub-nav dot icons */
#sidebar .nav-content img {
    filter: brightness(0) invert(1) !important;
    opacity: .5 !important;
    transition: opacity .2s !important;
    flex-shrink: 0;
}
#sidebar .nav-content a:hover img,
#sidebar .nav-content .nav-item.active > a img,
#sidebar .nav-content a.active img {
    opacity: 1 !important;
}

/* ── Main area ──────────────────────────────────────────────────────── */
body.has-sidebar #main { background: var(--bg); }
.section.register     { background: var(--bg); }

/* ── Authenticated #main — sidebar offset + no inner padding ────────── */
#main.main {
    padding:    0 !important;          /* remove NiceAdmin's 20px 30px   */
    margin-top: 60px !important;       /* navbar clearance               */
    min-height: calc(100vh - 56px);    /* footer always pinned to bottom */
    transition: margin-left .3s;
}

/* Desktop ≥1200px: sidebar visible at 200px */
@media (min-width: 1200px) {
    #main.main { margin-left: 200px !important; }
    #sidebar   { width: 200px !important; }
}

/* Tablet / mobile <1200px: sidebar slides off-screen */
@media (max-width: 1199px) {
    #main.main { margin-left: 0 !important; }
    #sidebar   { width: 200px !important; left: -200px !important; }
    .toggle-sidebar #sidebar { left: 0 !important; }
}

/* Toggle-sidebar hides sidebar on desktop → reset main offset */
@media (min-width: 1200px) {
    .toggle-sidebar #main.main { margin-left: 0 !important; }
}

/* ── Content section — top-aligned with breathing room ──────────────
   Removes the login-style vertical centering that all Create views
   inherit via justify-content-center on the flex-column section.     */
#main.main .section,
#main.main .section.register {
    padding:          20px 24px !important;
    justify-content:  flex-start !important;  /* top-align, not center  */
    align-items:      stretch    !important;  /* fill full width        */
    min-height:       unset      !important;  /* don't force 100vh      */
}

/* Remove the extra top margin cards carry in these views */
#main.main .section .card.mt-4,
#main.main .section .card.mt-3 {
    margin-top: 0 !important;
}

/* Strip any inner .container that caps content width —
   covers both .section > .container and .card-body > .container  */
#main.main .section > .container,
#main.main .section.register > .container,
#main.main .card-body > .container {
    max-width:     none !important;
    padding-left:  0    !important;
    padding-right: 0    !important;
    width:         100% !important;
}

/* Normalize form-group margin (m-3 = 1rem all sides → bottom-only)   */
#main.main .form-group.m-3 {
    margin: 0 0 16px 0 !important;
}

/* Reset col-sm-2 label widths — they are too narrow inside full-width forms */
#main.main .col-sm-2.col-form-label,
#main.main .col-sm-4.col-form-label {
    width: auto  !important;
    flex:  none  !important;
    padding-left: 0 !important;
}

/* Neutralise legacy percentage-based padding helpers */
.custom-left-padding { padding-left: 0 !important; }
.custom-padding-top  { padding-top:  0 !important; }
.custom-padding-left { padding-left: 0 !important; }

/* Unauthenticated pages (no sidebar): strip any sidebar offset */
#main:not(.main) {
    margin-left:  0 !important;
    margin-top:   0 !important;
    padding-left: 0 !important;
}

/* ── Buttons ────────────────────────────────────────────────────────── */
.btn-primary {
    background-color: var(--pu) !important;
    border-color: var(--pu) !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
}
.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--pdk) !important;
    border-color: var(--pdk) !important;
    transform: translateY(-1px);
}

.btn-success {
    background-color: var(--gc) !important;
    border-color: var(--gc) !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
}
.btn-warning {
    background-color: var(--or) !important;
    border-color: var(--or) !important;
    color: #fff !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
}
.btn-warning:hover {
    background-color: var(--olt) !important;
    border-color: var(--olt) !important;
    color: #fff !important;
}
.btn-info {
    background-color: var(--tl) !important;
    border-color: var(--tl) !important;
    color: #fff !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
}
.btn-info:hover { color: #fff !important; }

.btn-danger {
    background-color: var(--rc) !important;
    border-color: var(--rc) !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
}

/* btn-dark → re-skin with Questi purple so all Create/Add buttons match */
.btn-dark {
    background-color: var(--pu) !important;
    border-color:     var(--pu) !important;
    color: #fff !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
    transition: background-color .2s, transform .15s;
}
.btn-dark:hover,
.btn-dark:focus {
    background-color: var(--pdk) !important;
    border-color:     var(--pdk) !important;
    color: #fff !important;
    transform: translateY(-1px);
}
.btn-dark:active {
    transform: translateY(0) scale(.98);
}

/* Orange CTA (landing page style) */
.btn-orange {
    background: var(--or);
    color: #fff;
    border: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    border-radius: 8px;
    padding: 13px 26px;
    box-shadow: 0 6px 24px rgba(232,101,58,.45);
    transition: all .2s;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}
.btn-orange:hover {
    background: var(--olt);
    color: #fff;
    transform: translateY(-2px);
}

/* ── Cards ──────────────────────────────────────────────────────────── */
.card {
    border: 1px solid var(--bd) !important;
    border-radius: var(--r) !important;
    box-shadow: var(--sh) !important;
    transition: transform .2s, box-shadow .2s;
}
.card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sl) !important;
}
.card-header {
    background: rgba(91,79,207,.05) !important;
    border-bottom: 1px solid var(--bd) !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    color: var(--td);
}

/* ── Forms ──────────────────────────────────────────────────────────── */
.form-control,
.form-select {
    border: 1.5px solid var(--bd);
    border-radius: var(--rs);
    font-family: 'Nunito', sans-serif;
    color: var(--td);
    background: #fff;
    transition: border-color .2s;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--pu);
    box-shadow: 0 0 0 3px rgba(91,79,207,.08);
    background: #fff;
}
.form-label,
.col-form-label,
#main.main .form-group label {
    font-family: 'Poppins', sans-serif;
    font-size: .78rem;
    font-weight: 600;
    color: var(--tb);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 6px;
    display: block;
}

/* ── Full Questi input styling for all form-controls inside #main ──── */
#main.main .form-control,
#main.main .form-select {
    border: 1.5px solid var(--bd) !important;
    border-radius: var(--rs) !important;
    background: #fff !important;
    color: var(--td) !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: .9rem !important;
    padding: 10px 14px !important;
    transition: border-color .2s, box-shadow .2s !important;
    width: 100%;
}
#main.main .form-control:focus,
#main.main .form-select:focus {
    border-color: var(--pu) !important;
    box-shadow: 0 0 0 3px rgba(91,79,207,.08) !important;
    background: #fff !important;
    outline: none !important;
}
#main.main .form-control::placeholder { color: #bbb8cc !important; }
#main.main textarea.form-control      { resize: vertical; min-height: 42px; }

/* ── Pagination ─────────────────────────────────────────────────────── */
.pagination .page-link {
    color: var(--pu);
    border-color: var(--bd);
    font-family: 'Poppins', sans-serif;
    font-size: .8rem;
    font-weight: 500;
    transition: all .2s;
}
.pagination .page-link:hover {
    background: var(--pale);
    border-color: var(--pu);
    color: var(--pdk);
}
.pagination .page-item.active .page-link {
    background-color: var(--pu) !important;
    border-color:     var(--pu) !important;
    color: #fff !important;
    box-shadow: 0 2px 8px rgba(91,79,207,.3);
}
.pagination .page-item.disabled .page-link {
    color: var(--tm);
    border-color: var(--bd);
    background: transparent;
}

/* ══════════════════════════════════════════════════════════════════════
   TABLES  —  mirrors the React app's survey_table / user_form_response
   ══════════════════════════════════════════════════════════════════════ */

/* ── Card wrapper (matches React's .user_form_par) ─────────────────── */
#main.main .card {
    border:        1px solid rgba(0,0,0,.06) !important;
    border-radius: 12px !important;
    background:    #fff;
    box-shadow:    0 10px 35px rgba(0,0,0,.06) !important;
    transition:    box-shadow .25s ease;
}
#main.main .card:hover {
    box-shadow: 0 14px 45px rgba(0,0,0,.08) !important;
}
#main.main .card-body {
    padding: 1.25rem 1.5rem !important;
}
#main.main .card-title {
    font-family: 'Poppins', sans-serif;
    font-size:   1.1rem;
    font-weight: 700;
    color:       var(--td);
    margin-bottom: .25rem;
}

/* ── Base table reset ───────────────────────────────────────────────── */
#main.main .table {
    width:           100%;
    border-collapse: collapse;
    font-size:       .9rem;
    margin-top:      .5rem;
    background:      transparent !important;
}

/* ── Header ─────────────────────────────────────────────────────────── */
#main.main .table thead {
    background: rgba(91,79,207,.05);
}
#main.main .table thead th {
    padding:        .85rem .75rem;
    font-family:    'Poppins', sans-serif;
    font-size:      .72rem;
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color:          var(--tm);
    border-bottom:  1px solid rgba(0,0,0,.06) !important;
    border-top:     none !important;
    background:     transparent !important;
    white-space:    nowrap;
}

/* ── Body rows ──────────────────────────────────────────────────────── */
#main.main .table tbody tr {
    transition:    background .2s ease;
    border-bottom: 1px solid rgba(0,0,0,.045);
    background:    transparent !important;  /* kill Bootstrap striping  */
}
/* subtle alternating rows (replaces .table-striped) */
#main.main .table tbody tr:nth-child(odd) {
    background: rgba(0,0,0,.018) !important;
}
#main.main .table tbody tr:hover {
    background: rgba(91,79,207,.05) !important;
}

/* ── Body cells ─────────────────────────────────────────────────────── */
#main.main .table tbody td {
    padding:        .85rem .75rem;
    border-bottom:  none !important;
    color:          var(--tb);
    vertical-align: middle;
    font-size:      .875rem;
}

/* ── Action icon buttons (manage column) ────────────────────────────── */
#main.main .table tbody td a {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           32px;
    height:          32px;
    border-radius:   7px;
    transition:      background .2s ease, transform .15s ease, box-shadow .15s ease;
    text-decoration: none;
    color:           var(--tb);
}
#main.main .table tbody td a:hover {
    transform: translateY(-2px);
}
#main.main .table tbody td a:active {
    transform: scale(.9);
}
/* View link — blue */
#main.main .table tbody td a[title="View"],
#main.main .table tbody td a .bi-eye,
#main.main .table tbody td a img[src*="eye"] {
    color: #3865d1;
}
#main.main .table tbody td a[title="View"]:hover {
    background:  rgba(56,101,209,.12);
    box-shadow:  0 4px 8px rgba(56,101,209,.15);
    color:       #3865d1;
}
/* Edit link — green */
#main.main .table tbody td a[id="Back"],
#main.main .table tbody td a img[src*="pen"] {
    color: #10b981;
}
#main.main .table tbody td a[id="Back"]:hover {
    background: rgba(16,185,129,.12);
    box-shadow: 0 4px 8px rgba(16,185,129,.15);
}
/* Delete link — red */
#main.main .table tbody td a.custom_delete_icon,
#main.main .table tbody td a img[src*="trash"] {
    color: #ef4444;
}
#main.main .table tbody td a.custom_delete_icon:hover {
    background: rgba(239,68,68,.12);
    box-shadow: 0 4px 8px rgba(239,68,68,.15);
}
/* Make SVG action icons inherit the link colour */
#main.main .table tbody td a img {
    pointer-events: none;
    filter: none;
    opacity: 1;
}

/* ── "View" text links in Responses table ───────────────────────────── */
#main.main .table tbody td a.me-4 {
    width:     auto;
    padding:   4px 10px;
    font-size: .8rem;
    font-weight: 600;
    border-radius: 6px;
    color: #3865d1;
    gap: 5px;
}
#main.main .table tbody td a.me-4:hover {
    background: rgba(56,101,209,.1);
    transform:  translateY(-1px);
}

/* ── Responsive table (uses data-cell attribute already in views) ─────
   At ≤768 px: hide thead, stack each cell as a labelled row.          */
@media (max-width: 768px) {
    #main.main .table-responsive .table thead tr {
        display: none;
    }
    #main.main .table-responsive .table tbody tr {
        display:       block;
        margin-bottom: .75rem;
        border:        1px solid rgba(0,0,0,.07);
        border-radius: 8px;
        background:    #fff !important;
        box-shadow:    0 2px 8px rgba(0,0,0,.05);
        padding:       .5rem 0;
    }
    #main.main .table-responsive .table tbody tr:nth-child(odd) {
        background: #fff !important;
    }
    #main.main .table-responsive .table tbody td {
        display:               grid;
        grid-template-columns: 16ch auto;
        padding:               .4rem 1rem;
        border-bottom:         none !important;
        font-size:             .85rem;
    }
    #main.main .table-responsive .table tbody td::before {
        content:     attr(data-cell) " :";
        font-weight: 600;
        color:       var(--tm);
        font-size:   .75rem;
        text-transform: uppercase;
        letter-spacing: .04em;
        align-self: center;
    }
    #main.main .table-responsive .table tbody td:first-child { padding-top: .85rem; }
    #main.main .table-responsive .table tbody td:last-child  { padding-bottom: .85rem; }
    /* action buttons — show inline on mobile */
    #main.main .table-responsive .table tbody td a {
        width:  28px;
        height: 28px;
    }
}

/* ── Badges ─────────────────────────────────────────────────────────── */
.badge.bg-primary  { background-color: var(--pu) !important; }
.badge.bg-success  { background-color: var(--gc) !important; }
.badge.bg-warning  { background-color: var(--or) !important; }
.badge.bg-danger   { background-color: var(--rc) !important; }
.badge.bg-info     { background-color: var(--tl) !important; }

/* ── Tag pill utility ───────────────────────────────────────────────── */
.questi-tag {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--pu);
    background: rgba(91,79,207,.08);
    padding: 5px 14px;
    border-radius: 100px;
    margin-bottom: 14px;
}

/* ── Section header ─────────────────────────────────────────────────── */
.section-header {
    text-align: center;
    margin-bottom: 48px;
}
.section-header h2 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.4rem,2.2vw,1.8rem);
    font-weight: 700;
    color: var(--td);
    margin-bottom: 10px;
}
.section-header h2 span { color: var(--pu); }
.section-header p {
    font-size: .875rem;
    color: var(--tm);
    max-width: 64ch;
    margin: 0 auto;
}

/* ── Alerts ─────────────────────────────────────────────────────────── */
.alert-primary {
    background: var(--pale);
    border-color: rgba(91,79,207,.3);
    color: var(--vh);
}

/* ── Pagetitle (NiceAdmin) ──────────────────────────────────────────── */
.pagetitle h1 {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    color: var(--td);
}
.pagetitle .breadcrumb-item a { color: var(--pu); }
.pagetitle .breadcrumb-item.active { color: var(--tm); }

/* ── Dashboard stat cards ───────────────────────────────────────────── */
.dashboard-card {
    background: #fff;
    border: 1px solid var(--bd);
    border-radius: var(--r);
    box-shadow: var(--sh);
    padding: 24px 22px;
    transition: transform .2s, box-shadow .2s;
    position: relative;
    overflow: hidden;
}
.dashboard-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--pu);
}
.dashboard-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sl);
}
.dashboard-card .card-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    background: rgba(91,79,207,.1);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    margin-bottom: 14px;
}
.dashboard-card .card-label {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--tm);
    margin-bottom: 6px;
}
.dashboard-card .card-value {
    font-family: 'Poppins', sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--td);
    line-height: 1;
}

/* ── Project card ───────────────────────────────────────────────────── */
.project-card {
    background: #fff;
    border: 1px solid var(--bd);
    border-radius: var(--r);
    box-shadow: var(--sh);
    padding: 28px 24px;
    transition: transform .2s, box-shadow .2s;
    position: relative;
    overflow: hidden;
}
.project-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--pu), var(--plt));
}
.project-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sl);
}
.project-card .project-name {
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--td);
    margin-bottom: 8px;
}
.project-card .project-meta {
    font-size: .8rem;
    color: var(--tm);
    margin-bottom: 18px;
}
.project-card .project-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* ── Footer ─────────────────────────────────────────────────────────── */
.questi-footer {
    background: linear-gradient(135deg, #1e0f5c, #2d1b69);
    color: rgba(255,255,255,.45);
    padding: 18px 0;
    font-size: .78rem;
    text-align: center;
    position: relative;
    bottom: 0;
    width: 100%;
}

/* ── Back to top ────────────────────────────────────────────────────── */
#btt {
    position: fixed;
    bottom: 28px; right: 28px;
    width: 46px; height: 46px;
    border-radius: 50%;
    background: var(--pu);
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 18px rgba(91,79,207,.45);
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .3s, transform .3s;
    z-index: 998;
}
#btt.show { opacity: 1; transform: translateY(0); }
#btt:hover { background: var(--pdk); transform: translateY(-3px); }
#btt svg { width: 20px; height: 20px; stroke: #fff; stroke-width: 2.5; fill: none; }

/* ── Animations ─────────────────────────────────────────────────────── */
.fade-in { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }
.fade-in.d1 { transition-delay: .08s; }
.fade-in.d2 { transition-delay: .16s; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .1s; }
.reveal-d2 { transition-delay: .2s; }
.reveal-d3 { transition-delay: .3s; }
.reveal-d4 { transition-delay: .4s; }

/* ── Landing page sections ──────────────────────────────────────────── */

/* Hero */
.lp-hero {
    padding-top: 62px;
    background: linear-gradient(135deg, #1e0f5c 0%, #2d1b69 35%, #3d2580 65%, #4a2d8a 100%);
    min-height: 520px;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}
.lp-hero::before {
    content: '';
    position: absolute;
    width: 700px; height: 700px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(107,90,205,.35) 0%, transparent 70%);
    top: -200px; right: -150px;
    pointer-events: none;
}
.lp-hero::after {
    content: '';
    position: absolute;
    width: 400px; height: 400px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(232,101,58,.2) 0%, transparent 70%);
    bottom: -100px; left: 5%;
    pointer-events: none;
}
.lp-hero-eyebrow {
    font-size: .9rem;
    font-weight: 400;
    letter-spacing: .02em;
    color: rgba(255,255,255,.65);
    margin-bottom: 12px;
}
.lp-hero-title {
    font-family: 'Karina', cursive;
    font-size: clamp(3rem,6vw,4.5rem);
    font-weight: 400;
    color: #fff;
    line-height: 1;
    margin-bottom: 16px;
}
.lp-hero-tagline {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.1rem,2.2vw,1.4rem);
    font-weight: 600;
    color: rgba(255,255,255,.9);
    margin-bottom: 18px;
}
.lp-hero-desc {
    font-size: .9rem;
    color: rgba(255,255,255,.65);
    line-height: 1.75;
    max-width: 46ch;
    margin-bottom: 36px;
}
.lp-hero-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--or);
    color: #fff;
    padding: 14px 28px;
    border-radius: 8px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: .95rem;
    box-shadow: 0 6px 24px rgba(232,101,58,.45);
    transition: all .2s;
    border: none;
    text-decoration: none;
}
.lp-hero-btn:hover {
    background: var(--olt);
    color: #fff;
    transform: translateY(-2px);
}

/* Mockup display */
.lp-mockup {
    background: linear-gradient(160deg, #0d0525 0%, #1a0e4f 50%, #2d1b69 100%);
    border-radius: 10px;
    border: 2.5px solid rgba(255,255,255,.22);
    padding: 24px;
    display: flex; align-items: center; justify-content: center;
    aspect-ratio: 16/9;
    position: relative; overflow: hidden;
}
.lp-mockup::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(107,90,205,.28), transparent 65%);
}
.lp-mockup-inner { text-align: center; position: relative; z-index: 1; }
.lp-mockup-inner .ql {
    font-family: 'Karina', cursive;
    font-size: 1.8rem;
    color: #fff;
    display: block;
    margin-bottom: 8px;
}
.lp-mockup-inner p { font-size: .6rem; color: rgba(255,255,255,.6); }
.lp-mockup-bars { display: flex; gap: 4px; margin-top: 10px; justify-content: center; }
.lp-mockup-bar { height: 4px; border-radius: 2px; background: rgba(255,255,255,.25); }
.lp-mockup-bar.active { background: var(--or); }

/* Feature section */
.lp-features { padding: 80px 0; background: var(--bg); position: relative; overflow: hidden; }
.lp-features::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(90deg,#0d052a,#2d1b69,#4a3fb8,#5b4fcf,#7b6fd8,#a095e8,#7b6fd8,#5b4fcf,#2d1b69,#0d052a);
}
.blob-bg {
    position: absolute; border-radius: 50%; filter: blur(70px);
    pointer-events: none; opacity: .22;
}

/* Feature card */
.lp-feature-card {
    background: #fff;
    border-radius: var(--r);
    padding: 24px 22px;
    border: 1px solid var(--bd);
    box-shadow: var(--sh);
    transition: transform .2s, box-shadow .2s;
    position: relative; overflow: hidden;
    height: 100%;
}
.lp-feature-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
}
.lp-feature-card:hover { transform: translateY(-4px); box-shadow: var(--sl); }
.lp-feature-card.blue::before  { background: var(--ic); }
.lp-feature-card.orange::before{ background: var(--or); }
.lp-feature-card.red::before   { background: var(--rc); }
.lp-feature-card.green::before { background: var(--gc); }
.lp-feature-card.teal::before  { background: var(--tl); }
.lp-feature-icon {
    width: 44px; height: 44px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; margin-bottom: 14px;
}
.blue  .lp-feature-icon { background: rgba(91,79,207,.1);  }
.orange.lp-feature-icon,
.lp-feature-card.orange .lp-feature-icon { background: rgba(232,101,58,.1); }
.red   .lp-feature-icon { background: rgba(224,82,82,.1);  }
.green .lp-feature-icon { background: rgba(45,170,136,.1); }
.teal  .lp-feature-icon { background: rgba(58,191,177,.1); }
.lp-feature-card h5 {
    font-family: 'Poppins', sans-serif;
    font-size: .9rem; font-weight: 700;
    color: var(--td); margin-bottom: 12px;
}
.lp-feature-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.lp-feature-card ul li {
    font-size: .8rem; color: #1a1a1a;
    display: flex; gap: 7px; align-items: flex-start;
}
.lp-feature-card ul li::before { content: '•'; color: var(--pu); font-weight: 700; flex-shrink: 0; }

/* Why section */
.lp-why {
    padding: 80px 0;
    background: linear-gradient(135deg, var(--vh) 0%, #1e2640 100%);
    color: #fff;
    position: relative; overflow: hidden;
}
.lp-why::before {
    content: '';
    position: absolute; top: -200px; right: -200px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(91,79,207,.3), transparent);
    border-radius: 50%;
    pointer-events: none;
}
.lp-why-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--rl);
    padding: 32px 24px;
    text-align: center;
    transition: all .25s;
}
.lp-why-card:hover {
    background: rgba(91,79,207,.18);
    border-color: rgba(107,90,205,.45);
    transform: translateY(-4px);
}
.lp-why-card .icon { font-size: 2.5rem; margin-bottom: 18px; display: block; }
.lp-why-card h4 { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 1rem; color: #fff; margin-bottom: 10px; }
.lp-why-card p  { font-size: .85rem; color: rgba(255,255,255,.5); line-height: 1.65; margin: 0; }

/* Pricing section */
.lp-pricing { padding: 100px 0; background: #fff; position: relative; overflow: hidden; }
.lp-pricing::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(90deg,#0d052a,#2d1b69,#4a3fb8,#5b4fcf,#7b6fd8,#a095e8,#7b6fd8,#5b4fcf,#2d1b69,#0d052a);
}
.price-card {
    border-radius: var(--r);
    border: 1.5px solid rgba(91,79,207,.18);
    background: var(--pale);
    display: flex; flex-direction: column;
    position: relative;
    transition: transform .2s, box-shadow .2s;
    overflow: visible;
    height: 100%;
}
.price-card:hover { transform: translateY(-4px); box-shadow: var(--sl); }
.price-card .badge-popular {
    position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
    background: var(--or); color: #fff;
    padding: 4px 18px; border-radius: 100px;
    font-family: 'Poppins', sans-serif; font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .07em; white-space: nowrap;
    box-shadow: 0 4px 14px rgba(232,101,58,.45); z-index: 3;
}
.price-card-header {
    padding: 20px 16px 14px; text-align: center;
    background: rgba(91,79,207,.08);
    border-bottom: 1px solid rgba(91,79,207,.12);
    border-radius: var(--r) var(--r) 0 0;
}
.price-card-header .plan-name {
    font-family: 'Poppins', sans-serif; font-size: .85rem; font-weight: 700;
    letter-spacing: .04em; text-transform: uppercase; color: var(--pu);
    margin-bottom: 4px;
}
.price-card-header .plan-desc {
    font-size: .68rem; color: var(--tm); line-height: 1.4; min-height: 2.8em;
}
.price-amount {
    padding: 14px 16px 10px; text-align: center;
    background: rgba(91,79,207,.05);
    border-bottom: 1px solid rgba(91,79,207,.1);
}
.price-amount .amount {
    font-family: 'Poppins', sans-serif; font-size: 1.55rem; font-weight: 800;
    line-height: 1; color: var(--pu);
}
.price-amount .period { font-size: .68rem; color: var(--tm); margin-top: 3px; }
.price-features {
    padding: 14px 16px 18px; flex: 1;
    display: flex; flex-direction: column;
}
.price-features ul { list-style: none; padding: 0; margin: 0 0 16px; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.price-features ul li { font-size: .75rem; color: var(--tb); display: flex; gap: 7px; align-items: flex-start; line-height: 1.4; }
.price-features ul li::before { content: '✓'; color: var(--pu); font-weight: 700; flex-shrink: 0; font-size: .7rem; margin-top: 1px; }
.price-btn {
    display: block; width: 100%; text-align: center;
    padding: 10px 12px; border-radius: 8px;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: .8rem;
    cursor: pointer; border: 2px solid var(--pu); color: var(--pu);
    background: #fff; transition: all .2s;
    text-transform: uppercase; letter-spacing: .05em;
    margin-top: auto; text-decoration: none;
}
.price-btn:hover { background: var(--pu); color: #fff; }

/* Pro plan */
.price-card.pro {
    background: linear-gradient(160deg, #2d1b69 0%, #4a3fb8 100%);
    border-color: var(--plt);
    box-shadow: 0 8px 32px rgba(91,79,207,.28);
}
.price-card.pro .price-card-header { background: rgba(255,255,255,.08); border-bottom-color: rgba(255,255,255,.12); }
.price-card.pro .plan-name { color: #fff; }
.price-card.pro .plan-desc { color: rgba(255,255,255,.65); }
.price-card.pro .price-amount { background: rgba(255,255,255,.06); border-bottom-color: rgba(255,255,255,.1); }
.price-card.pro .amount { color: #fff; }
.price-card.pro .period { color: rgba(255,255,255,.6); }
.price-card.pro .price-features ul li { color: rgba(255,255,255,.85); }
.price-card.pro .price-features ul li::before { color: rgba(255,255,255,.7); }
.price-card.pro .price-btn {
    background: var(--or); border-color: var(--or); color: #fff;
    box-shadow: 0 4px 14px rgba(232,101,58,.4);
}
.price-card.pro .price-btn:hover { background: var(--olt); border-color: var(--olt); }

/* CTA section */
.lp-cta {
    padding: 80px 0;
    background: var(--pale);
    border-top: 1px solid var(--bd);
    text-align: center;
}
.lp-cta h2 { font-family: 'Poppins', sans-serif; font-size: clamp(1.6rem,3vw,2.4rem); font-weight: 700; color: var(--td); margin-bottom: 16px; }
.lp-cta h2 span { color: var(--pu); }
.lp-cta p { font-size: .95rem; color: var(--tb); max-width: 52ch; margin: 0 auto 32px; }
