@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap'); :root { --bg: #f5efe6; --bg-accent: #eef1f8; --ink: #1d1d1f; --muted: #5b5b64; --card: #ffffff; --line: #e2e2e8; --accent: #ffb454; --accent-dark: #eb7b1c; --ok: #1f8a4c; --warn: #d97706; --no: #b91c1c; --shadow: 0 22px 60px rgba(20, 20, 45, 0.08); } * { box-sizing: border-box; } .app-body { margin: 0; font-family: 'Space Grotesk', system-ui, sans-serif; color: var(--ink); background: radial-gradient(circle at 20% 10%, rgba(255, 210, 150, 0.35), transparent 55%), radial-gradient(circle at 90% 5%, rgba(185, 221, 255, 0.35), transparent 60%), var(--bg); min-height: 100vh; } .mm-shell { max-width: 2000px; margin: 0 auto; padding: 2rem 1rem 4rem; animation: fadeUp 0.6s ease both; } .mm-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-bottom: 2rem; } .mm-brand { display: flex; align-items: center; gap: 1.25rem; } .mm-logo { height: 140px; width: auto; max-width: 320px; object-fit: contain; border-radius: 16px; background: #fff; border: 1px solid var(--line); box-shadow: 0 12px 28px rgba(16, 16, 24, 0.12); } .mm-kicker { text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.7rem; color: var(--muted); margin: 0 0 0.6rem 0; } .mm-title { font-size: clamp(2rem, 2.6vw, 2.8rem); margin: 0; } .mm-subtitle { margin: 0.5rem 0 0; color: var(--muted); max-width: 36rem; } .mm-status { font-family: 'IBM Plex Mono', ui-monospace, monospace; font-size: 0.85rem; padding: 0.4rem 0.8rem; border-radius: 999px; border: 1px solid var(--line); background: var(--card); } .mm-card { display: flex; flex-direction: column; gap: 1.5rem; background: var(--card); border: 1px solid var(--line); border-radius: 24px; padding: 1.75rem; box-shadow: var(--shadow); } .mm-sidebar { display: flex; flex-direction: column; gap: 1.5rem; border-bottom: 1px dashed var(--line); padding-bottom: 1.5rem; } .mm-panel h2 { font-size: 1rem; margin: 0 0 0.5rem 0; } .mm-panel label { display: block; font-weight: 600; font-size: 0.85rem; margin-bottom: 0.4rem; color: var(--muted); } .mm-panel select { width: 100%; border: 1px solid var(--line); border-radius: 12px; padding: 0.55rem 0.75rem; font-size: 0.95rem; background: #fff; } .mm-panel p { margin: 0.5rem 0 0; color: var(--muted); font-size: 0.85rem; } .mm-tip { font-size: 0.8rem; color: var(--muted); padding: 0.75rem; border-radius: 16px; background: var(--bg-accent); } .mm-main { display: flex; flex-direction: column; gap: 1rem; } .mm-table-wrap { overflow: auto; border-radius: 16px; border: 1px solid var(--line); background: #fff; max-height: 70vh; } .mm-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; } .mm-table thead th { position: sticky; top: 0; background: #f8f8fb; padding: 0.75rem; text-align: left; font-weight: 600; border-bottom: 1px solid var(--line); } .mm-table tbody td { padding: 0.7rem 0.75rem; border-bottom: 1px solid #f0f0f4; vertical-align: top; } .mm-info-btn { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.7rem; font-weight: 600; border-radius: 999px; border: 1px solid var(--line); background: #fff7ed; color: #9a3412; padding: 0.15rem 0.5rem; margin-top: 0.3rem; } .mm-tooltip { position: fixed; z-index: 50; max-width: 280px; background: #101018; color: #f4f4f7; border-radius: 12px; padding: 0.6rem 0.75rem; box-shadow: 0 16px 40px rgba(0, 0, 0, 0.25); font-size: 0.75rem; line-height: 1.35; pointer-events: none; opacity: 0; transform: translateY(6px); transition: opacity 0.12s ease, transform 0.12s ease; } .mm-tooltip.is-visible { opacity: 1; transform: translateY(0); } .mm-details-row { background: #fffaf3; } .mm-details { padding: 0.9rem 1rem; border-left: 3px solid var(--accent); display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.6rem 1rem; font-size: 0.85rem; color: var(--muted); position: relative; } .mm-details strong { color: var(--ink); display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; } .mm-row-toggle { cursor: pointer; } .mm-details-close { position: absolute; top: 0.6rem; right: 0.8rem; border: 1px solid var(--line); background: #fff; border-radius: 999px; padding: 0.2rem 0.6rem; font-size: 0.7rem; color: var(--muted); cursor: pointer; } .mm-table tbody tr:nth-child(even) { background: #fcfcff; } .mm-table tbody tr.is-alt { background: #fcfcff; } .mm-table [data-printer] { background: rgba(248, 247, 255, 0.8); } .mm-tag { display: inline-flex; align-items: center; gap: 0.4rem; border-radius: 999px; padding: 0.25rem 0.6rem; font-size: 0.75rem; font-weight: 600; } .mm-tag.ok { background: rgba(31, 138, 76, 0.12); color: var(--ok); } .mm-tag.warn { background: rgba(217, 119, 6, 0.12); color: var(--warn); } .mm-tag.no { background: rgba(185, 28, 28, 0.12); color: var(--no); } .mm-tag.addon { background: rgba(59, 130, 246, 0.12); color: #1d4ed8; } .mm-sub { font-size: 0.75rem; color: var(--muted); margin-top: 0.25rem; } .mm-error { padding: 0.75rem 1rem; border-radius: 12px; border: 1px solid rgba(185, 28, 28, 0.25); background: rgba(185, 28, 28, 0.08); color: var(--no); font-size: 0.9rem; } .mm-disclaimer { background: #f9fafc; border: 1px solid var(--line); border-radius: 16px; padding: 1rem 1.25rem; font-size: 0.85rem; color: var(--muted); } @keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } } @media (max-width: 980px) { .mm-sidebar { padding-bottom: 1rem; } } @media (max-width: 720px) { .mm-shell { padding: 2rem 1.25rem 3rem; } .mm-header { flex-direction: column; align-items: flex-start; } .mm-brand { flex-direction: column; align-items: flex-start; } }