/* ============================================================
   Casio FX-580VN — keypad calculator UI
   ============================================================ */

.casio {
    --casio-bg: #1f2937;
    --casio-display-bg: #cad9b8;
    --casio-display-text: #1a2e1a;
    --casio-display-meta: #4a6741;
    --casio-key-func-bg: #2d3748;
    --casio-key-num-bg: #f1f5f9;
    --casio-key-op-bg: #c19a4b;
    --casio-key-equal-bg: var(--vjol-color-primary);
    --casio-key-warn-bg: #9b2c2c;

    background: linear-gradient(135deg, var(--casio-bg) 0%, #0f172a 100%);
    border-radius: var(--vjol-radius-lg);
    padding: clamp(var(--vjol-space-4), 2vw, var(--vjol-space-6));
    box-shadow: var(--vjol-shadow-xl);
    max-width: 480px;
    margin: 0 auto;
    outline: none;
}

.casio:focus-visible {
    outline: 2px solid var(--vjol-color-focus);
    outline-offset: 4px;
}

/* ---------- Display ---------- */

.casio__display {
    background: var(--casio-display-bg);
    color: var(--casio-display-text);
    padding: var(--vjol-space-4);
    border-radius: var(--vjol-radius-md);
    margin-bottom: var(--vjol-space-4);
    font-family: 'JetBrains Mono', ui-monospace, 'SF Mono', Consolas, monospace;
    text-align: right;
    min-height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-shadow: inset 0 2px 6px rgb(0 0 0 / 0.15);
    word-break: break-all;
    overflow-wrap: break-word;
}

.casio__mode {
    font-size: var(--vjol-fs-xs);
    color: var(--casio-display-meta);
    text-align: left;
    letter-spacing: 0.1em;
    font-weight: var(--vjol-fw-semibold);
    line-height: 1;
}

.casio__expr {
    font-size: var(--vjol-fs-base);
    min-height: 1.4em;
    color: var(--casio-display-meta);
    margin-top: var(--vjol-space-2);
    line-height: 1.3;
}

.casio__result {
    font-size: clamp(var(--vjol-fs-2xl), 5vw, var(--vjol-fs-3xl));
    font-weight: var(--vjol-fw-bold);
    line-height: 1;
    margin-top: var(--vjol-space-2);
}

/* ---------- Keypad ---------- */

.casio__keypad {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--vjol-space-2);
}

.casio__key {
    padding: var(--vjol-space-3) var(--vjol-space-2);
    background: var(--casio-key-func-bg);
    color: #e5e7eb;
    border: 1px solid rgb(255 255 255 / 0.08);
    border-radius: var(--vjol-radius-md);
    font-size: var(--vjol-fs-sm);
    font-weight: var(--vjol-fw-semibold);
    cursor: pointer;
    transition: background-color var(--vjol-duration-fast) var(--vjol-ease-out),
                transform var(--vjol-duration-fast) var(--vjol-ease-out),
                box-shadow var(--vjol-duration-fast) var(--vjol-ease-out);
    min-height: 44px;
    box-shadow: 0 2px 0 rgb(0 0 0 / 0.3);
    user-select: none;
}

.casio__key:hover { background: #3b4a5e; }
.casio__key:active {
    transform: translateY(2px);
    box-shadow: 0 0 0 rgb(0 0 0 / 0.3);
}
.casio__key:focus-visible {
    outline: 2px solid var(--vjol-color-focus);
    outline-offset: 2px;
}

.casio__key--num {
    background: var(--casio-key-num-bg);
    color: #0f172a;
    font-size: var(--vjol-fs-base);
}
.casio__key--num:hover { background: #e2e8f0; }

.casio__key--op {
    background: var(--casio-key-op-bg);
    color: #fff;
}
.casio__key--op:hover { background: #a8843e; }

.casio__key--equal {
    background: var(--casio-key-equal-bg);
    color: #fff;
    font-size: var(--vjol-fs-lg);
    grid-row: span 2;
}
.casio__key--equal:hover { background: var(--vjol-color-primary-hover); }

.casio__key--func {
    background: var(--casio-key-warn-bg);
    color: #fff;
}
.casio__key--func:hover { background: #7f1d1d; }

.casio__key--mode {
    background: #4a5568;
}
.casio__key--mode:hover { background: #5a6678; }

.casio__key--zero {
    grid-column: span 4;
}

@media (max-width: 480px) {
    .casio__keypad { gap: 6px; }
    .casio__key {
        font-size: var(--vjol-fs-xs);
        padding: var(--vjol-space-2) var(--vjol-space-1);
        min-height: 40px;
    }
    .casio__key--num { font-size: var(--vjol-fs-sm); }
    .casio__key--equal { font-size: var(--vjol-fs-base); }
}

