/* UtilMonster Components — reusable, token-driven UI classes (Wanted-style).
   Load AFTER design-tokens + um-base. Use these instead of per-page inline styles. */

/* ---------- Buttons ---------- */
.um-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
    height: 44px; padding: 0 var(--space-5);
    font-size: var(--fs-md); font-weight: var(--fw-semibold); letter-spacing: var(--tracking-label);
    border-radius: var(--radius-md);
    transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), color var(--dur-fast) var(--ease-out);
    white-space: nowrap; user-select: none;
}
.um-btn:focus-visible { outline: none; box-shadow: var(--ring-focus); }
.um-btn--primary { background: var(--color-primary); color: var(--color-primary-fg); box-shadow: var(--shadow-xs); }
.um-btn--primary:hover { background: var(--color-primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.um-btn--primary:active { background: var(--color-primary-active); transform: translateY(0); box-shadow: var(--shadow-xs); }
.um-btn--secondary { background: var(--color-primary-weak); color: var(--color-primary-active); }
.um-btn--secondary:hover { background: color-mix(in srgb, var(--color-primary) 14%, var(--color-primary-weak)); }
.um-btn--ghost { background: transparent; color: var(--color-text-sub); border: 1px solid var(--color-border); }
.um-btn--ghost:hover { background: var(--color-surface-2); border-color: var(--color-border-strong); }
.um-btn--lg { height: 52px; padding: 0 var(--space-6); font-size: var(--fs-lg); }
.um-btn--sm { height: 36px; padding: 0 var(--space-4); font-size: var(--fs-sm); }
.um-btn--block { width: 100%; }

/* ---------- Cards ---------- */
.um-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-6);
}
.um-card--interactive { transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); will-change: transform; }
.um-card--interactive:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg);
    border-color: color-mix(in srgb, var(--color-primary) 32%, var(--color-border)); }
.um-card__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); margin-bottom: var(--space-2); }
.um-card__desc { font-size: var(--fs-sm); color: var(--color-text-sub); }

.um-grid { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

/* ---------- Form fields ---------- */
.um-field { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
.um-label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text-sub); }
.um-input, .um-select, .um-textarea {
    width: 100%; height: 48px; padding: 0 var(--space-4);
    background: var(--color-surface); color: var(--color-text);
    border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
    transition: border-color var(--transition), box-shadow var(--transition);
}
.um-textarea { height: auto; min-height: 96px; padding: var(--space-3) var(--space-4); }
.um-input:hover, .um-select:hover, .um-textarea:hover { border-color: var(--color-text-muted); }
.um-input:focus, .um-select:focus, .um-textarea:focus {
    outline: none; border-color: var(--color-primary);
    box-shadow: var(--ring-primary);
}

/* ---------- Result panel (the emotional peak — the answer, made rewarding) ---------- */
.um-result {
    background: linear-gradient(160deg, var(--color-primary-faint), var(--color-primary-weak));
    border: 1px solid transparent;
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 22%, transparent), var(--shadow-md);
}
.um-result__value { font-size: clamp(1.875rem, 1.2rem + 2.6vw, 2.5rem); font-weight: var(--fw-bold);
    color: var(--color-primary-active); letter-spacing: -0.02em; line-height: 1.15; font-feature-settings: "tnum"; }
.um-result__label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text-sub); }

/* ---------- Hero ---------- */
.um-hero { text-align: center; padding-block: var(--space-12) var(--space-10); }
.um-hero__title { font-size: clamp(2rem, 1.3rem + 3vw, 3rem); letter-spacing: var(--tracking-title);
    margin-bottom: var(--space-4); text-wrap: balance; }
.um-hero__subtitle { font-size: var(--fs-lg); line-height: var(--lh-normal); color: var(--color-text-sub);
    max-width: 62ch; margin-inline: auto; text-wrap: pretty; }
@media (max-width: 640px) { .um-hero { padding-block: var(--space-8); } }

/* ---------- Header ---------- */
.um-header {
    position: sticky; top: 0; z-index: var(--z-header);
    display: flex; align-items: center; gap: var(--space-4);
    height: 64px; padding-inline: var(--space-5);
    background: color-mix(in srgb, var(--color-surface) 82%, transparent);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}
.um-header__logo { font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--color-text); display: flex; align-items: center; gap: var(--space-2); }
.um-header__spacer { flex: 1; }
.um-header__actions { display: flex; align-items: center; gap: var(--space-2); }

/* ---------- Breadcrumb ---------- */
.um-breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2);
    font-size: var(--fs-sm); color: var(--color-text-sub); padding-block: var(--space-4); }
.um-breadcrumb a { color: var(--color-text-sub); }
.um-breadcrumb a:hover { color: var(--color-primary); }
.um-breadcrumb__sep { color: var(--color-border-strong); }

/* ---------- Chip ---------- */
.um-chip { display: inline-flex; align-items: center; gap: var(--space-1);
    padding: var(--space-1) var(--space-3); font-size: var(--fs-xs); font-weight: var(--fw-medium);
    background: var(--color-surface-2); color: var(--color-text-sub); border-radius: var(--radius-full); }

/* ---------- Footer ---------- */
.um-footer { background: var(--color-surface-2); border-top: 1px solid var(--color-border);
    padding-block: var(--space-10); margin-top: var(--space-16); color: var(--color-text-sub); }
.um-footer__grid { display: grid; gap: var(--space-8); grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.um-footer__title { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-text); margin-bottom: var(--space-3); }
.um-footer__links a { display: block; font-size: var(--fs-sm); color: var(--color-text-sub); padding-block: var(--space-1); }
.um-footer__links a:hover { color: var(--color-primary); }
.um-footer__copy { text-align: center; font-size: var(--fs-xs); color: var(--color-text-sub);
    margin-top: var(--space-8); padding-top: var(--space-6); border-top: 1px solid var(--color-border); }

/* ---------- Header extras (lang switch, icon button) ---------- */
.um-langswitch { display: inline-flex; gap: 2px; padding: 2px; background: var(--color-surface-2); border-radius: var(--radius-full); }
.um-langswitch a { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--color-text-muted);
    padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); }
.um-langswitch a.is-active { background: var(--color-surface); color: var(--color-primary); box-shadow: var(--shadow-xs); }
.um-iconbtn { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px;
    border-radius: var(--radius-full); background: var(--color-surface-2); transition: background var(--transition); }
.um-iconbtn:hover { background: var(--color-border); }

/* ---------- Tool layout (input + result, responsive) ---------- */
.um-tool-grid { display: grid; gap: var(--space-5); grid-template-columns: 1.2fr 1fr;
    align-items: start; margin-bottom: var(--space-16); }
.um-result { align-self: start; position: sticky; top: 84px; }
@media (max-width: 760px) { .um-tool-grid { grid-template-columns: 1fr; } .um-result { position: static; } }

/* ---------- SEO guide (refined editorial, SSR for crawlers) ---------- */
.um-guide { max-width: 880px; margin: var(--space-16) auto var(--space-12); }
.um-eyebrow { display:inline-block; font-size: var(--fs-xs); font-weight: var(--fw-bold);
    letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-primary-active);
    padding: var(--space-1) var(--space-3); background: var(--color-primary-weak); border-radius: var(--radius-full); }
.um-guide__head { text-align: center; margin-bottom: var(--space-10); }
.um-guide__title { font-size: var(--fs-2xl); letter-spacing: var(--tracking-title); margin-top: var(--space-4); }
.um-guide__item { display: grid; grid-template-columns: 56px 1fr; gap: var(--space-6);
    padding: var(--space-8) 0; border-top: 1px solid var(--color-border); }
.um-guide__item:first-child { border-top: none; padding-top: 0; }
.um-guide__num { font-size: 2rem; font-weight: var(--fw-bold); line-height: 1; letter-spacing: -0.02em;
    color: var(--color-primary); opacity: 0.85; font-feature-settings: "tnum"; }
.um-guide__h { font-size: var(--fs-lg); font-weight: var(--fw-bold); letter-spacing: var(--tracking-heading);
    margin-bottom: var(--space-3); text-wrap: balance; }
.um-guide__p { font-size: var(--fs-md); line-height: 1.85; color: var(--color-text-sub);
    max-width: 72ch; word-break: keep-all; text-wrap: pretty; }
@media (max-width: 640px) {
    .um-guide__item { grid-template-columns: 1fr; gap: var(--space-2); padding-block: var(--space-6); }
    .um-guide__num { font-size: var(--fs-xl); }
}

/* FAQ (refined accordion, FAQPage schema in markup) */
.um-faq { max-width: 880px; margin: var(--space-12) auto 0; }
.um-faq__title { text-align:center; font-size: var(--fs-xl); letter-spacing: var(--tracking-heading); margin-bottom: var(--space-6); }
.um-faq__item { border-bottom: 1px solid var(--color-border); }
.um-faq__q { font-size: var(--fs-md); font-weight: var(--fw-semibold); color: var(--color-text);
    padding: var(--space-5) var(--space-1); cursor: pointer; list-style: none; display:flex;
    justify-content:space-between; align-items:center; gap: var(--space-4); transition: color var(--transition); }
.um-faq__q::-webkit-details-marker { display:none; }
.um-faq__q:hover { color: var(--color-primary); }
.um-faq__q::after { content: '+'; font-size: var(--fs-xl); font-weight: 300; color: var(--color-text-muted); }
.um-faq__item[open] .um-faq__q::after { content: '−'; color: var(--color-primary); }
.um-faq__a { padding: 0 var(--space-1) var(--space-5); color: var(--color-text-sub); line-height: 1.85; font-size: var(--fs-base); word-break: keep-all; }

/* ============ App shell (header + left sidebar + main) ============ */
.um-shell { display: grid; grid-template-columns: 264px minmax(0, 1fr); align-items: start;
    max-width: 1320px; margin-inline: auto; }
.um-main { min-width: 0; padding-bottom: var(--space-12); }

/* Sidebar */
.um-sidebar { position: sticky; top: 64px; height: calc(100vh - 64px); overflow-y: auto;
    border-right: 1px solid var(--color-border); background: var(--color-surface); }
.um-sidebar__inner { padding: var(--space-5) var(--space-3); }
.um-sidebar__section { margin-bottom: var(--space-6); }
.um-sidebar__title { font-size: var(--fs-xs); font-weight: var(--fw-bold); letter-spacing: 0.04em;
    text-transform: uppercase; color: var(--color-text-muted); padding: 0 var(--space-3) var(--space-2); }
.um-navlist { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.um-navlink { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm); color: var(--color-text-sub); font-weight: var(--fw-medium);
    font-size: var(--fs-sm); transition: background var(--transition), color var(--transition); }
.um-navlink:hover { background: var(--color-surface-2); color: var(--color-text); }
.um-navlink.is-active { background: var(--color-primary-weak); color: var(--color-primary-active); font-weight: var(--fw-semibold); }
.um-navlink__icon { font-size: 16px; width: 20px; text-align: center; }
.um-navlink--sm { font-size: var(--fs-sm); color: var(--color-text-muted); }
.um-navlist--chips { flex-direction: row; flex-wrap: wrap; gap: var(--space-2); padding: 0 var(--space-3); }
.um-navchip { display:inline-flex; align-items:center; gap:4px; padding: var(--space-1) var(--space-3);
    border: 1px solid var(--color-border); border-radius: var(--radius-full); font-size: var(--fs-xs);
    font-weight: var(--fw-semibold); color: var(--color-text-sub); }
.um-navchip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.um-navchip.is-active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }

/* Header search */
.um-search { flex: 0 1 360px; }
.um-search__input { width: 100%; height: 40px; padding: 0 var(--space-4); border-radius: var(--radius-full);
    background: var(--color-surface-2); border: 1px solid transparent; color: var(--color-text); transition: all var(--transition); }
.um-search__input:focus { outline: none; background: var(--color-surface); border-color: var(--color-primary);
    box-shadow: var(--ring-primary); }
/* Search autocomplete dropdown */
.um-search__pop { position: absolute; left: 0; right: 0; top: calc(100% + 6px); z-index: var(--z-dropdown);
    background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg); padding: var(--space-1); max-height: min(60vh, 420px); overflow-y: auto;
    animation: um-pop var(--dur-fast) var(--ease-out); }
.um-search__opt { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3);
    padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); color: var(--color-text); }
.um-search__opt:hover, .um-search__opt.is-active { background: var(--color-primary-weak); color: var(--color-primary-active); }
.um-search__opt-t { font-size: var(--fs-sm); font-weight: var(--fw-medium); }
.um-search__opt-c { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: capitalize; flex: none; }
/* Mobile: keep search reachable (shrinks but stays visible) */
@media (max-width: 760px) { .um-search { flex: 1 1 auto; min-width: 0; } .um-header__logo span { display: none; } }
@media (max-width: 400px) { .um-search { display: none; } }

/* Segmented control (unit toggle) */
.um-seg { display: inline-flex; padding: 2px; background: var(--color-surface-2); border-radius: var(--radius-full); }
.um-seg a { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--color-text-muted);
    padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); }
.um-seg a.is-active { background: var(--color-surface); color: var(--color-primary); box-shadow: var(--shadow-xs); }

/* Dropdown menu (language) */
.um-menu { position: relative; }
.um-menu > summary { list-style: none; }
.um-menu > summary::-webkit-details-marker { display: none; }
.um-iconbtn--wide { width: auto; padding: 0 var(--space-3); gap: 4px; font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.um-menu__pop { position: absolute; right: 0; top: calc(100% + 6px); min-width: 140px; z-index: var(--z-dropdown);
    background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg); padding: var(--space-2);
    transform-origin: top right; animation: um-pop var(--dur-fast) var(--ease-out); }
.um-menu__pop a { display: block; padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
    font-size: var(--fs-sm); color: var(--color-text-sub); }
.um-menu__pop a:hover { background: var(--color-surface-2); }
.um-menu__pop a.is-active { color: var(--color-primary); font-weight: var(--fw-semibold); }

/* Mobile drawer */
.um-header__menu { display: none; }
.um-scrim { position: fixed; inset: 0; background: rgba(15,17,21,0.45); z-index: var(--z-scrim);
    backdrop-filter: blur(2px); animation: um-fade var(--dur-base) var(--ease-out); }
@media (max-width: 960px) {
    .um-shell { grid-template-columns: 1fr; }
    .um-sidebar { position: fixed; top: 0; left: 0; height: 100vh; width: 280px; z-index: var(--z-drawer);
        transform: translateX(-100%); transition: transform var(--dur-slow) var(--ease-out); box-shadow: var(--shadow-xl); }
    body.um-sidebar-open .um-sidebar { transform: translateX(0); }
    .um-header__menu { display: inline-flex; }
}
@media (min-width: 961px) { .um-scrim { display: none; } }

/* ---------- Motion primitives + reduced-motion ---------- */
@keyframes um-pop { from { opacity: 0; transform: translateY(-4px) scale(0.98); } to { opacity: 1; transform: none; } }
@keyframes um-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes um-rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
/* Opt-in entrance for above-the-fold blocks (element is visible by default; animation only enhances) */
.um-reveal { animation: um-rise var(--dur-slow) var(--ease-out) both; }
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
    .um-card--interactive:hover, .um-btn--primary:hover { transform: none; }
}
