@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: 1200px; margin: 0 auto; padding: 3rem 2rem 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-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: grid; grid-template-columns: 280px 1fr; 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-right: 1px dashed var(--line); padding-right: 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-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-card { grid-template-columns: 1fr; } .mm-sidebar { border-right: none; border-bottom: 1px dashed var(--line); padding-right: 0; padding-bottom: 1rem; } } @media (max-width: 720px) { .mm-shell { padding: 2rem 1.25rem 3rem; } .mm-header { flex-direction: column; align-items: flex-start; } }