:root,[data-theme=light]{--color-bg-primary: #f5f7fa;--color-bg-secondary: #ffffff;--color-bg-tertiary: #eef1f5;--color-surface: rgba(255, 255, 255, .9);--color-surface-hover: rgba(255, 255, 255, 1);--color-ocean: #b8d4e8;--color-ocean-gradient-start: #a8c8dc;--color-ocean-gradient-end: #c5dff0;--color-land: #7ab87a;--color-land-hover: #5fa85f;--color-land-stroke: rgba(0, 0, 0, .2);--color-accent-primary: #4f46e5;--color-accent-secondary: #0891b2;--color-accent-tertiary: #7c3aed;--color-accent-glow: rgba(79, 70, 229, .2);--color-text-primary: #1a1a2e;--color-text-secondary: rgba(0, 0, 0, .7);--color-text-muted: rgba(0, 0, 0, .5);--color-text-label: rgba(0, 0, 0, .8);--color-text-ocean: #1e5f74;--color-border: rgba(0, 0, 0, .1);--color-border-accent: rgba(79, 70, 229, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 20px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .15);--glow-accent: 0 0 20px var(--color-accent-glow);--font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg-primary: #0a0a0f;--color-bg-secondary: #12121a;--color-bg-tertiary: #1a1a25;--color-surface: rgba(255, 255, 255, .05);--color-surface-hover: rgba(255, 255, 255, .1);--color-ocean: #0c1929;--color-ocean-gradient-start: #0d1f35;--color-ocean-gradient-end: #061420;--color-land: #2d4a3e;--color-land-hover: #3d6a52;--color-land-stroke: rgba(255, 255, 255, .15);--color-text-primary: #f5f5f7;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .4);--color-text-label: rgba(255, 255, 255, .85);--color-text-ocean: #64b5f6;--color-border: rgba(255, 255, 255, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}body{font-family:var(--font-display);background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;max-height:100vh;overflow:hidden;line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}.app{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 0%,rgba(79,70,229,.08) 0%,transparent 50%),radial-gradient(ellipse at 100% 100%,rgba(6,182,212,.05) 0%,transparent 40%),var(--color-bg-primary)}.header{padding:var(--spacing-md) var(--spacing-xl);background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;z-index:100}.header__brand{display:flex;align-items:center;gap:var(--spacing-md)}.header__logo{width:40px;height:40px;background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:var(--glow-accent)}.header__title{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--color-text-primary),var(--color-accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__subtitle{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.header__actions{display:flex;align-items:center;gap:var(--spacing-md)}.theme-toggle{width:40px;height:40px;border:none;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-border-accent);transform:scale(1.05)}.header__info{display:flex;align-items:center;gap:var(--spacing-lg)}.header__badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.75rem;color:var(--color-text-secondary)}.header__badge-dot{width:8px;height:8px;background:var(--color-accent-secondary);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.main{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.map-container{flex:1;position:relative;display:flex;align-items:stretch;justify-content:stretch;padding:0;overflow:hidden;width:100%;height:100%}.map-wrapper{position:relative;width:100%;height:100%;max-width:1400px;display:flex;align-items:center;justify-content:center}.map-svg{width:100%;height:100%;overflow:visible}.map-ocean{fill:var(--color-ocean)}.map-country{fill:var(--color-land);stroke:var(--color-land-stroke);stroke-width:.5;cursor:pointer}.map-country.has-regions{stroke:transparent;stroke-width:0}.map-state,.map-region{fill:none;stroke:#ffffff40;stroke-width:.3px;pointer-events:none}.map-country.selected{fill:var(--color-accent-secondary);stroke:#ffffffe6;stroke-width:1.5}.map-controls{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:100}.map-controls__btn{width:40px;height:40px;border:none;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:1.25rem;cursor:pointer;border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.map-controls__btn:hover{background:var(--color-surface-hover);transform:scale(1.05)}.map-graticule{fill:none;stroke:var(--color-border);stroke-width:.5}.map-label{font-family:var(--font-display);font-size:8px;font-weight:500;fill:var(--color-text-label);text-anchor:middle;pointer-events:none;opacity:.9;transition:opacity .3s ease-out;will-change:transform,opacity}.map-label--continent{font-size:12px;font-weight:800;fill:var(--color-text-primary);opacity:.4;text-transform:uppercase;letter-spacing:2px}.map-label--ocean{font-size:9px;font-weight:600;font-style:italic;fill:var(--color-text-ocean);text-transform:uppercase;letter-spacing:1.5px;opacity:.85;text-shadow:none}.map-controls{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:50}.map-controls__btn{width:48px;height:48px;border:none;border-radius:var(--radius-md);background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);color:var(--color-text-primary);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.map-controls__btn:hover{background:var(--color-surface-hover);border-color:var(--color-border-accent);transform:scale(1.05)}.map-controls__btn:active{transform:scale(.98)}.info-panel{position:absolute;top:var(--spacing-xl);left:var(--spacing-xl);width:280px;background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);z-index:50;box-shadow:var(--shadow-lg)}.info-panel__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.info-panel__icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-tertiary));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}.info-panel__title{font-size:1rem;font-weight:600}.info-panel__content p{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);line-height:1.6}.info-panel__highlight{color:var(--color-accent-secondary);font-weight:600}.legend{position:fixed;bottom:var(--spacing-xl);left:var(--spacing-xl);background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);z-index:50;box-shadow:var(--shadow-md)}.legend__title{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-sm)}.legend__items{display:flex;gap:var(--spacing-lg)}.legend__item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8rem;color:var(--color-text-secondary)}.legend__color{width:16px;height:16px;border-radius:var(--radius-sm)}.legend__color--land{background:var(--color-land);border:1px solid var(--color-land-stroke)}.legend__color--ocean{background:var(--color-ocean);border:1px solid var(--color-border)}.loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);background:var(--color-bg-primary);z-index:200}.loading__spinner{width:64px;height:64px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading__text{font-size:1rem;color:var(--color-text-secondary)}@media(max-width:768px){.header{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.header__info,.header__subtitle,.info-panel{display:none}.legend{bottom:var(--spacing-md);left:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.legend__items{flex-direction:column;gap:var(--spacing-xs)}.map-controls{bottom:var(--spacing-md);right:var(--spacing-md)}.map-controls__btn{width:40px;height:40px;font-size:1.25rem}.map-container{padding:var(--spacing-sm)}}@media(max-width:768px)and (orientation:portrait){.map-wrapper{transform:rotate(90deg);transform-origin:center center;width:100vh;height:100vw;max-width:none}.map-container{overflow:hidden}.map-label{transform:rotate(var(--map-rotation, 0deg));transform-box:fill-box;transform-origin:center;transition:transform .3s ease}}.side-panel{position:absolute;top:var(--spacing-lg);left:var(--spacing-lg);width:260px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;animation:fadeIn .15s ease-out}.side-panel--collapsed{width:auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.side-panel__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);gap:var(--spacing-sm)}.side-panel--collapsed .side-panel__header{border-bottom:none}.side-panel__title{font-size:.95rem;font-weight:600;color:var(--color-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-panel__actions{display:flex;gap:var(--spacing-xs)}.side-panel__btn{width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted);font-size:1rem;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.side-panel__btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.side-panel__close{width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.side-panel__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.side-panel__content{padding:var(--spacing-sm) var(--spacing-md)}.side-panel__row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0;font-size:.8rem}.side-panel__row:not(:last-child){border-bottom:1px solid var(--color-border)}.side-panel__label{font-size:.875rem;color:var(--color-text-muted)}.side-panel__value{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.side-panel__placeholder{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.side-panel__placeholder p{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.side-panel__placeholder ul{font-size:.8rem;color:var(--color-text-muted);padding-left:var(--spacing-lg)}.side-panel__placeholder li{margin:var(--spacing-xs) 0}.map-country.selected{fill:var(--color-accent-secondary)!important;stroke:var(--color-text-primary);stroke-width:2}@media(max-width:768px){.side-panel{position:absolute;width:calc(100% - 32px);left:16px;right:16px;height:auto;max-height:35%;top:auto;bottom:16px;border-right:none;border-top:none;border-radius:var(--radius-lg)}@keyframes slideIn{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}}.globe-wrapper{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-ocean);overflow:hidden}.globe-canvas{display:block;width:100%;height:100%;touch-action:none}.view-toggle{position:absolute;top:16px;right:16px;padding:10px 16px;background:var(--color-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.875rem;font-weight:500;cursor:pointer;box-shadow:var(--shadow-md);transition:all .2s ease;z-index:100}.view-toggle:hover{background:var(--color-surface-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.view-toggle:active{transform:translateY(0)}@media(max-width:768px){.view-toggle{top:auto;bottom:80px;right:16px}}.map-mode-selector{position:absolute;top:var(--spacing-lg);left:var(--spacing-lg);z-index:200}.map-mode-select{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-display);font-size:.9rem;font-weight:500;cursor:pointer;outline:none;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:2rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.map-mode-select:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-accent);box-shadow:var(--shadow-md)}.map-mode-select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-glow)}
