/**
 * CSS Variables
 * カラー、スペーシング、フォント等の変数定義
 */

:root {
    /* Colors - Dark Theme */
    --color-bg-primary: #0D0D0D;
    --color-bg-secondary: #1A1A2E;
    --color-bg-tertiary: #252540;
    --color-bg-hover: #2F2F4A;
    
    /* Accent Colors */
    --color-accent: #7B2CBF;
    --color-accent-light: #9D4EDD;
    --color-accent-dark: #5A189A;
    --color-accent-alpha: rgba(123, 44, 191, 0.1);
    
    /* Text Colors */
    --color-text-primary: #E0E0E0;
    --color-text-secondary: #A0A0A0;
    --color-text-muted: #666666;
    --color-text-inverse: #FFFFFF;
    
    /* Status Colors */
    --color-success: #4CAF50;
    --color-success-light: #66BB6A;
    --color-warning: #FF9800;
    --color-warning-light: #FFB74D;
    --color-error: #F44336;
    --color-error-light: #EF5350;
    --color-info: #2196F3;
    --color-info-light: #42A5F5;
    
    /* Border & Divider */
    --color-border: #333333;
    --color-border-light: #444444;
    --color-divider: #222222;
    
    /* Overlay */
    --color-overlay: rgba(0, 0, 0, 0.7);
    --color-modal-bg: rgba(26, 26, 46, 0.95);
    
    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 48px;
    --spacing-3xl: 64px;
    
    /* Border Radius */
    --radius-xs: 2px;
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-2xl: 24px;
    --radius-full: 9999px;
    
    /* Shadows */
    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.2);
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.5);
    --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.6);
    
    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-normal: 300ms ease;
    --transition-slow: 500ms ease;
    
    /* Font Family */
    --font-family: 'M PLUS Rounded 1c', 'Noto Sans JP', -apple-system, BlinkMacSystemFont,
                   'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-family-mono: 'Courier New', Courier, monospace;
    
    /* Font Sizes */
    --font-size-xs: 12px;
    --font-size-sm: 14px;
    --font-size-md: 16px;
    --font-size-lg: 18px;
    --font-size-xl: 20px;
    --font-size-2xl: 24px;
    --font-size-3xl: 32px;
    --font-size-4xl: 40px;
    
    /* Font Weights */
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    
    /* Line Heights */
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;
    
    /* Z-Index */
    --z-dropdown: 100;
    --z-modal: 200;
    --z-toast: 300;
    --z-loading: 400;
    
    /* Max Width */
    --max-width-xs: 320px;
    --max-width-sm: 480px;
    --max-width-md: 768px;
    --max-width-lg: 1024px;
    --max-width-xl: 1280px;
    
    /* Container */
    --container-padding: var(--spacing-md);
    --container-max-width: 800px;
}

/* Media Queries Variables */
@media (max-width: 768px) {
    :root {
        --font-size-xs: 11px;
        --font-size-sm: 13px;
        --font-size-md: 16px;
        --font-size-lg: 17px;
        --font-size-xl: 19px;
        --font-size-2xl: 22px;
        --font-size-3xl: 28px;
        --font-size-4xl: 36px;
        
        --spacing-md: 12px;
        --spacing-lg: 20px;
        --spacing-xl: 28px;
    }
}
