:root{--rose: #F9A8A8;--rose-light: #FDE8E8;--rose-dark: #E87878;--lavender: #C4B5E8;--lavender-light: #EDE8F8;--lavender-dark: #9B8AC4;--periwinkle: #A8B8F0;--periwinkle-light: #E0E8FF;--periwinkle-dark: #7890D8;--amber: #F5A623;--amber-light: #FEF3D8;--green: #4CAF50;--green-light: #E8F5E9;--bg: #F5F5F7;--bg-card: #FFFFFF;--text-primary: #1A1A2E;--text-secondary: #6B7280;--text-muted: #9CA3AF;--border: #E5E7EB;--border-light: #F3F4F6;--bcos-black-deep: #000000;--bcos-black: #0A0A0F;--bcos-black-soft: #14141C;--bcos-black-mid: #1F1F2C;--bcos-gold-bright: #FFD24A;--bcos-gold: #F5C842;--bcos-gold-warm: #F2B73D;--bcos-gold-deep: #C8901F;--bcos-gold-shadow: #8C6612;--bcos-indigo: #6366F1;--bcos-indigo-soft: #818CF8;--bcos-indigo-bg: #E0E7FF;--bcos-amber: #F59E0B;--bcos-amber-soft: #FBBF24;--bcos-amber-bg: #FEF3C7;--bcos-emerald: #10B981;--bcos-emerald-soft: #34D399;--bcos-emerald-bg: #D1FAE5;--bcos-red: #DC2626;--bcos-red-soft: #EF4444;--bcos-red-bg: #FEE2E2;--bcos-success: #10B981;--bcos-warning: #F59E0B;--bcos-white: #FFFFFF;--bcos-cream: #FFF8E7;--bcos-gray-50: #FAFAFB;--bcos-gray-100: #F5F5F7;--bcos-gray-200: #ECECF0;--bcos-gray-300: #D4D4D8;--bcos-gray-400: #A1A1AA;--bcos-gray-500: #71717A;--bcos-gray-600: #525258;--bcos-gray-700: #3F3F46;--bcos-gray-800: #1F1F2C;--bcos-gray-900: #14141C;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--border-1: 1px;--border-2: 2px;--border-4: 4px;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-md: 15px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-4xl: 32px;--text-5xl: 42px;--text-6xl: 56px;--font-display: "Inter", sans-serif;--font-jp: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "BIZ UDPGothic", sans-serif;--font-body: "Inter", "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;--font-mono: "DM Mono", ui-monospace, monospace;--weight-light: 300;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--weight-black: 900;--leading-tight: 1.3;--leading-snug: 1.5;--leading-normal: 1.7;--leading-relaxed: 1.85;--leading-loose: 2;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 28px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.04);--shadow-xl: 0 24px 48px rgba(0,0,0,.14), 0 8px 16px rgba(0,0,0,.06);--shadow-gold-glow: 0 8px 24px rgba(245,200,66,.25), 0 0 0 1px rgba(245,200,66,.4);--shadow-gold-glow-strong: 0 16px 40px rgba(245,200,66,.4), 0 0 0 2px rgba(245,200,66,.5);--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .6, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--bcos-black);background:var(--bcos-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer}a{color:var(--bcos-gold-deep);text-decoration:none}a:hover{text-decoration:underline}input,textarea,select{font-family:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}body{background:var(--bg);color:var(--text-primary);font-family:Hiragino Sans,Yu Gothic,Meiryo,Arial,sans-serif;-webkit-font-smoothing:antialiased}.card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);padding:16px;box-shadow:0 1px 2px #0000000a;transition:box-shadow .15s,border-color .15s,transform .15s}.card:hover{box-shadow:0 4px 12px #00000014}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--text-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}button,a{-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (max-width: 768px){input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],input[type=search],textarea,select{font-size:16px!important}html,body{overflow-x:hidden;max-width:100vw}}@media (max-width: 768px){.m-page{padding:16px 14px 32px!important}.m-page-tight{padding:14px 12px 28px!important}.m-stack{grid-template-columns:1fr!important}.m-col{flex-direction:column!important}.m-fullw{width:100%!important;max-width:100%!important;flex-basis:auto!important}.m-static{position:static!important;max-height:none!important;height:auto!important;top:auto!important}.m-scroll-x{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.m-gap-sm{gap:12px!important}}
