:root {
    --bg: #0F0F14;
    --surface: #1A1A22;
    --border: rgba(168, 85, 247, .12);
    --text: #E8E4F4;
    --text2: #9B92B8;
    --text3: #524D6B;
    --primary: #A855F7;
    --glow: rgba(168, 85, 247, .2);
    --sans: 'Inter', system-ui, sans-serif;
    --mono: 'JetBrains Mono', monospace;
    --r: 12px;
    --rs: 8px;
    --t: 200ms ease
}

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0
}

html {
    font-size: 15px;
    -webkit-font-smoothing: antialiased
}

body {
    font-family: var(--sans);
    background: var(--bg);
    color: var(--text);
    min-height: 100vh
}

.app-header {
    background: var(--surface);
    border-bottom: 1px solid var(--border)
}

.header-inner {
    max-width: 640px;
    margin: 0 auto;
    padding: 0 24px;
    height: 56px;
    display: flex;
    align-items: center
}

.header-inner h1 {
    font-size: 1.05rem;
    font-weight: 700
}

.app-main {
    max-width: 640px;
    margin: 0 auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px
}

.calc-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 20px
}

.calc-card h2 {
    font-size: .82rem;
    font-weight: 600;
    color: var(--text2);
    margin-bottom: 14px
}

.calc-card h2 .hl {
    color: var(--primary);
    font-weight: 700
}

.calc-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap
}

.calc-row input {
    width: 100px;
    padding: 10px 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--rs);
    font-family: var(--mono);
    font-size: 1rem;
    color: var(--text);
    transition: border-color var(--t)
}

.calc-row input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--glow)
}

.calc-op {
    font-size: .82rem;
    color: var(--text3);
    font-weight: 600
}

.calc-eq {
    font-size: 1.1rem;
    color: var(--text3);
    font-weight: 700
}

.calc-result {
    font-family: var(--mono);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--primary);
    min-width: 60px
}

.tip-detail {
    margin-top: 10px;
    font-size: .82rem;
    color: var(--text2)
}

@media(max-width:500px) {
    .calc-row input {
        width: 80px
    }

    .app-main {
        padding: 16px
    }
}