/* === Timesheets Page - Unique Styles ===
   Shared base styles are in functionPages.css
*/

/* ===== HERO ===== */

/* Hero floaters */

.hero-floaters {
        position: absolute;
        inset: 0;
        pointer-events: none;
        z-index: 1;
    }

.hero-floater {
        position: absolute;
        background: rgba(255,255,255,.04);
        border: 1px solid rgba(255,255,255,.08);
        border-radius: 16px;
        backdrop-filter: blur(4px);
        padding: 14px 18px;
    }

.hero-floater.left {
            left: 4%;
            bottom: 12%;
            transform: rotate(-6deg);
            animation: float-left 8s ease-in-out infinite;
        }

.hero-floater.right {
            right: 4%;
            top: 18%;
            transform: rotate(5deg);
            animation: float-right 7s ease-in-out infinite;
        }

.floater-row {
        display: flex;
        align-items: center;
        gap: 10px;
        margin-bottom: 6px;
    }

.floater-row:last-child {
            margin-bottom: 0;
        }

.floater-dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
    }

.floater-dot.green {
            background: rgba(22,163,74,.6);
        }

.floater-dot.blue {
            background: rgba(21,93,238,.6);
        }

.floater-dot.amber {
            background: rgba(217,119,6,.6);
        }

.floater-bar {
        height: 6px;
        border-radius: 3px;
        background: rgba(255,255,255,.08);
    }

.floater-check {
        color: rgba(22,163,74,.7);
        font-size: .7rem;
        font-weight: 700;
    }

.floater-time {
        font-size: .65rem;
        color: rgba(255,255,255,.3);
        font-family: var(--font-body);
    }

@media (max-width: 900px) {
        .hero-floater {
            display: none;
        }
    }

/* ===== SHARED SECTION ===== */

/* ===== SECTION 1: INTERACTIVE TABLE DEMO ===== */

.demo-wrapper {
        display: grid;
        grid-template-columns: 240px 1fr;
        gap: 0;
        background: var(--surface);
        border-radius: var(--radius-lg);
        border: 1px solid var(--border);
        box-shadow: var(--shadow-xl);
        overflow: hidden;
        min-height: 480px;
    }

@media (max-width: 800px) {
        .demo-wrapper {
            grid-template-columns: 1fr;
        }
    }

.demo-sidebar {
        background: linear-gradient(180deg, #0f2044, #1a3a7a);
        padding: 24px 18px;
        display: flex;
        flex-direction: column;
        gap: 5px;
    }

.demo-sidebar-title {
        color: rgba(255,255,255,.5);
        font-size: .68rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: .06em;
        margin-bottom: 4px;
    }

.demo-week-label {
        color: #fff;
        font-size: .9rem;
        font-weight: 600;
        margin-bottom: 12px;
    }

.demo-day-btn {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 9px 12px;
        border-radius: var(--radius-sm);
        border: none;
        background: rgba(255,255,255,.04);
        color: rgba(255,255,255,.6);
        font-family: var(--font-body);
        font-size: .82rem;
        font-weight: 500;
        cursor: pointer;
        transition: all .2s;
    }

.demo-day-btn:hover {
            background: rgba(255,255,255,.1);
            color: #fff;
        }

.demo-day-btn.active {
            background: var(--accent);
            color: #fff;
        }

.demo-day-count {
        font-size: .68rem;
        background: rgba(255,255,255,.12);
        padding: 2px 8px;
        border-radius: 100px;
    }

.demo-day-btn.active .demo-day-count {
        background: rgba(255,255,255,.25);
    }

.demo-main {
        padding: 20px;
        overflow-x: auto;
    }

.demo-toolbar {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 14px;
    }

.demo-toolbar-left {
        display: flex;
        align-items: center;
        gap: 10px;
    }

.demo-table-label {
        font-size: .75rem;
        font-weight: 600;
        color: var(--text-light);
        text-transform: uppercase;
        letter-spacing: .04em;
    }

.demo-badge {
        font-size: .66rem;
        font-weight: 600;
        padding: 3px 10px;
        border-radius: 100px;
    }

.demo-badge.green {
            background: var(--green-light);
            color: var(--green);
        }

.demo-table {
        width: 100%;
        border-collapse: separate;
        border-spacing: 0;
        font-size: .8rem;
        min-width: 640px;
    }

.demo-table thead th {
            text-align: left;
            padding: 7px 8px;
            color: var(--text-light);
            font-weight: 600;
            font-size: .65rem;
            text-transform: uppercase;
            letter-spacing: .04em;
            border-bottom: 2px solid var(--border);
            white-space: nowrap;
        }

.demo-table tbody td {
            padding: 9px 8px;
            border-bottom: 1px solid var(--border);
            vertical-align: middle;
        }

.demo-table tbody tr {
            transition: background .15s;
        }

.demo-table tbody tr:hover {
                background: var(--surface-alt);
            }

/* Stacked cell — mirrors real .stacked-cell */

.demo-stacked-cell {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

.demo-first-name {
        font-weight: 600;
        font-size: .82rem;
        color: var(--text);
        line-height: 1.2;
    }

.demo-last-name {
        font-weight: 400;
        font-size: .78rem;
        color: var(--text-mid);
        line-height: 1.2;
    }

.demo-area {
        font-size: .72rem;
        color: var(--text-light);
        font-weight: 500;
        line-height: 1.2;
    }

.demo-position {
        font-size: .78rem;
        color: var(--text-mid);
        font-weight: 600;
        line-height: 1.2;
    }

.demo-shift-time {
        font-size: .78rem;
        font-weight: 600;
        color: var(--text);
        line-height: 1.3;
    }

.demo-clock-time {
        font-size: .72rem;
        color: var(--text-light);
        line-height: 1.3;
    }

.demo-clock-time.late {
            color: var(--amber);
        }

.demo-elapsed-shift {
        font-size: .82rem;
        font-weight: 700;
        color: var(--text);
        line-height: 1.2;
    }

.demo-elapsed-true {
        font-size: .7rem;
        color: var(--text-light);
        line-height: 1.2;
    }

/* Pay option buttons — mirrors real .pay-option */

.demo-pay-options {
        display: flex;
        flex-direction: column;
        gap: 4px;
        align-items: flex-start;
    }

.demo-pay-group {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
    }

.demo-pay-label {
        font-size: .55rem;
        font-weight: 700;
        letter-spacing: .06em;
        color: var(--text-light);
        text-transform: uppercase;
    }

.demo-pay-opt {
        padding: 3px 10px;
        border-radius: 6px;
        font-size: .72rem;
        font-weight: 700;
        border: 1.5px solid var(--border);
        background: var(--surface);
        color: var(--text-light);
        cursor: pointer;
        transition: all .2s;
        white-space: nowrap;
    }

.demo-pay-opt.active {
            background: var(--accent);
            color: #fff;
            border-color: var(--accent);
        }

.demo-pay-opt.active.no-show {
                background: var(--red);
                border-color: var(--red);
            }

.demo-pay-opt:hover:not(.active) {
            border-color: var(--accent);
            color: var(--accent);
        }

.demo-pay-row {
        display: flex;
        gap: 5px;
        align-items: center;
    }

/* Adjustment + note — mirrors real adjustment-note-container */

.demo-adj-note {
        display: flex;
        align-items: center;
        gap: 6px;
    }

.demo-adj {
        display: flex;
        align-items: center;
        gap: 4px;
    }

.demo-adj-btn {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        border: 1.5px solid var(--border);
        background: var(--surface);
        color: var(--text-light);
        font-size: .7rem;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all .15s;
        padding: 0;
        line-height: 1;
    }

.demo-adj-btn svg {
            width: 14px;
            height: 14px;
            fill: currentColor;
        }

.demo-adj-btn:hover {
            border-color: var(--accent);
            color: var(--accent);
        }

.demo-adj-val {
        min-width: 38px;
        text-align: center;
        font-weight: 600;
        font-size: .76rem;
        color: var(--text);
    }

.demo-note-btn {
        width: 26px;
        height: 26px;
        border-radius: 6px;
        border: 1.5px solid var(--border);
        background: var(--surface);
        color: var(--text-light);
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        transition: all .15s;
        flex-shrink: 0;
    }

.demo-note-btn svg {
            width: 13px;
            height: 13px;
            fill: currentColor;
        }

.demo-note-btn:hover {
            border-color: var(--accent);
            color: var(--accent);
        }

.demo-note-btn.has-note svg {
            fill: var(--accent);
        }

.demo-footer {
        margin-top: 14px;
        display: flex;
        gap: 10px;
        justify-content: flex-end;
        padding-top: 10px;
        border-top: 1px solid var(--border);
    }

.demo-footer-btn {
        padding: 8px 20px;
        border-radius: 100px;
        font-family: var(--font-body);
        font-size: .8rem;
        font-weight: 600;
        cursor: pointer;
        transition: all .2s;
        display: flex;
        align-items: center;
        gap: 6px;
    }

.demo-footer-btn.save {
            background: var(--surface);
            color: var(--text-mid);
            border: 1.5px solid var(--border);
        }

.demo-footer-btn.save:hover {
                border-color: var(--accent);
                color: var(--accent);
            }

.demo-footer-btn.approve {
            background: var(--green);
            color: #fff;
            border: 1.5px solid var(--green);
        }

.demo-footer-btn.approve:hover {
                background: #15803d;
            }

.demo-footer-btn.approved {
            background: var(--green-light);
            color: var(--green);
            border: 1.5px solid var(--green);
        }

/* ===== SECTION 2: FLOW DIAGRAM ===== */

.flow-track {
        display: flex;
        gap: 0;
        align-items: stretch;
        overflow-x: auto;
        padding-bottom: 10px;
    }

.flow-node {
        flex: 1;
        min-width: 200px;
        text-align: center;
        padding: 2rem 1.5rem;
        position: relative;
    }

.flow-node::after {
            content: '';
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 0;
            height: 0;
            border-top: 14px solid transparent;
            border-bottom: 14px solid transparent;
            border-left: 14px solid var(--border);
        }

.flow-node:last-child::after {
            display: none;
        }

.flow-icon {
        width: 60px;
        height: 60px;
        border-radius: 50%;
        margin: 0 auto 1rem;
        display: flex;
        align-items: center;
        justify-content: center;
    }

.flow-icon svg {
            width: 26px;
            height: 26px;
        }

.flow-icon.blue {
            background: var(--accent-light);
        }

.flow-icon.blue svg {
                fill: var(--accent);
            }

.flow-icon.green {
            background: var(--green-light);
        }

.flow-icon.green svg {
                fill: var(--green);
            }

.flow-icon.amber {
            background: var(--amber-light);
        }

.flow-icon.amber svg {
                fill: var(--amber);
            }

.flow-icon.purple {
            background: var(--purple-light);
        }

.flow-icon.purple svg {
                fill: var(--purple);
            }

.flow-node h4 {
        font-size: 1rem;
        font-weight: 600;
        margin-bottom: .4rem;
    }

.flow-node p {
        font-size: .85rem;
        color: var(--text-mid);
        line-height: 1.55;
    }

@media (max-width: 768px) {
        .flow-track {
            flex-direction: column;
            gap: 8px;
        }

        .flow-node::after {
            display: none;
        }

        .flow-node {
            min-width: 0;
            padding: 1.2rem;
        }
    }

/* ===== SECTION 3: SPLIT SHOWCASES ===== */

.showcase-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 3rem;
        align-items: center;
        margin-bottom: 5rem;
    }

.showcase-row:last-child {
            margin-bottom: 0;
        }

.showcase-row.reverse {
            direction: rtl;
        }

.showcase-row.reverse > * {
                direction: ltr;
            }

@media (max-width: 800px) {
        .showcase-row, .showcase-row.reverse {
            grid-template-columns: 1fr;
            direction: ltr;
        }
    }

.showcase-label {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 5px 14px;
        border-radius: 100px;
        font-size: .72rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: .04em;
        margin-bottom: 1rem;
    }

.showcase-label.blue {
            background: var(--accent-light);
            color: var(--accent);
        }

.showcase-label.green {
            background: var(--green-light);
            color: var(--green);
        }

.showcase-label.amber {
            background: var(--amber-light);
            color: var(--amber);
        }

.showcase-label.purple {
            background: var(--purple-light);
            color: var(--purple);
        }

.showcase-text h3 {
        font-family: var(--font-display);
        font-size: clamp(1.5rem, 3vw, 2rem);
        font-weight: 400;
        margin-bottom: .75rem;
        line-height: 1.2;
    }

.showcase-text p {
        font-size: .95rem;
        color: var(--text-mid);
        line-height: 1.7;
        margin-bottom: 1.25rem;
    }

.showcase-bullets {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

.showcase-bullet {
        display: flex;
        align-items: center;
        gap: 10px;
        font-size: .88rem;
        color: var(--text-mid);
    }

.showcase-bullet-icon {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        background: var(--green-light);
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        color: var(--green);
        font-size: .7rem;
        font-weight: 700;
    }

.showcase-visual {
        display: flex;
        justify-content: center;
    }

/* Visual cards */

.vis-card {
        background: var(--surface);
        border-radius: var(--radius-lg);
        border: 1px solid var(--border);
        box-shadow: var(--shadow-lg);
        overflow: hidden;
        width: 100%;
        max-width: 440px;
    }

.vis-card-header {
        background: linear-gradient(135deg, #0f2044, #1a3a7a);
        padding: 14px 18px;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

.vis-card-header span {
            color: #fff;
            font-size: .82rem;
            font-weight: 600;
        }

.vis-card-header-pills {
        display: flex;
        gap: 4px;
    }

.vis-pill {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: rgba(255,255,255,.2);
    }

.vis-pill.active {
            background: var(--green);
        }

.vis-card-body {
        padding: 18px;
    }

/* Match visual */

.match-row {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 12px;
        border: 1px solid var(--border);
        border-radius: var(--radius-sm);
        margin-bottom: 8px;
        transition: border-color .2s;
    }

.match-row:hover {
            border-color: var(--accent);
        }

.match-row:last-child {
            margin-bottom: 0;
        }

.match-name {
        font-size: .82rem;
        font-weight: 600;
        color: var(--text);
        min-width: 70px;
    }

.match-times {
        flex: 1;
        display: flex;
        align-items: center;
        gap: 6px;
        justify-content: center;
    }

.match-time-block {
        text-align: center;
    }

.match-time-label {
        font-size: .58rem;
        color: var(--text-light);
        text-transform: uppercase;
        font-weight: 600;
        letter-spacing: .03em;
    }

.match-time-val {
        font-size: .78rem;
        font-weight: 600;
        color: var(--text);
    }

.match-connector {
        color: var(--green);
        font-weight: 600;
        font-size: .7rem;
    }

.match-tag {
        font-size: .6rem;
        font-weight: 600;
        padding: 2px 8px;
        border-radius: 100px;
        flex-shrink: 0;
    }

.match-tag.ok {
            background: var(--green-light);
            color: var(--green);
        }

.match-tag.warn {
            background: var(--amber-light);
            color: var(--amber);
        }

/* Holiday visual */

.hol-banner {
        background: linear-gradient(135deg, var(--purple), #a78bfa);
        padding: 16px;
        border-radius: var(--radius-md);
        text-align: center;
        margin-bottom: 14px;
        color: #fff;
    }

.hol-banner-name {
        font-size: .95rem;
        font-weight: 600;
    }

.hol-banner-date {
        font-size: .72rem;
        opacity: .7;
    }

.hol-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 9px 0;
        border-bottom: 1px solid var(--border);
        font-size: .82rem;
    }

.hol-row:last-child {
            border-bottom: none;
        }

.hol-name {
        font-weight: 600;
        color: var(--text);
    }

.hol-tag {
        font-size: .65rem;
        font-weight: 600;
        padding: 2px 10px;
        border-radius: 100px;
    }

.hol-tag.yes {
            background: var(--green-light);
            color: var(--green);
        }

.hol-tag.no {
            background: var(--red-light);
            color: var(--red);
        }

.hol-hours {
        font-weight: 600;
        color: var(--text-mid);
        font-size: .78rem;
    }

/* ===== SECTION 4: STATS BAR ===== */

.stats-bar {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 20px;
    }

@media (max-width: 700px) {
        .stats-bar {
            grid-template-columns: repeat(2, 1fr);
        }
    }

.stat-card {
        background: rgba(255,255,255,.06);
        border: 1px solid rgba(255,255,255,.1);
        border-radius: var(--radius-lg);
        padding: 2rem 1.5rem;
        text-align: center;
        backdrop-filter: blur(6px);
        transition: transform .3s, border-color .3s;
    }

.stat-card:hover {
            transform: translateY(-4px);
            border-color: rgba(255,255,255,.25);
        }

.stat-number {
        font-family: var(--font-display);
        font-size: 2.2rem;
        font-weight: 700;
        color: #fff;
        margin-bottom: .25rem;
    }

.stat-label {
        font-size: .88rem;
        color: rgba(255,255,255,.5);
    }

/* ===== SCROLL REVEAL ===== */

/* ===== KEYFRAMES ===== */

/* ===== MOBILE ===== */

@media (max-width: 600px) {
        .hero {
            min-height: 70vh;
            padding: 4rem 1.5rem;
        }

        .section {
            padding: 3.5rem 1.5rem;
        }
    }

/* FAQ */

.faq-list {
        max-width: 720px;
        margin: 0 auto;
        display: flex;
        flex-direction: column;
        gap: 8px
    }

.faq-item {
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: var(--radius-md);
        overflow: hidden;
        transition: border-color .25s;
    }

.faq-item.open {
            border-color: var(--accent);
        }

.faq-trigger {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 18px 20px;
        background: none;
        border: none;
        font-family: var(--font-body);
        font-size: .95rem;
        font-weight: 600;
        color: var(--text);
        cursor: pointer;
        text-align: left;
        gap: 12px
    }

.faq-chevron {
        width: 20px;
        height: 20px;
        fill: var(--text-light);
        transition: transform .3s;
        flex-shrink: 0;
    }

.faq-item.open .faq-chevron {
        transform: rotate(180deg)
    }

.faq-body {
        max-height: 0;
        overflow: hidden;
        transition: max-height .35s ease;
    }

.faq-body-inner {
        padding: 0 20px 18px;
        font-size: .9rem;
        color: var(--text-mid);
        line-height: 1.7;
    }