:root{--ow-black: #000000;--ow-bg-primary: #000000;--ow-bg-secondary: #0a0a0a;--ow-bg-tertiary: #1a1a1a;--ow-bg-translucent: rgba(30, 41, 59, .3);--ow-text-primary: #e2e8f0;--ow-text-secondary: #94a3b8;--ow-text-tertiary: #64748b;--ow-text-white: #ffffff;--ow-cyan-primary: #22d3ee;--ow-cyan-light: #67e8f9;--ow-cyan-dark: #06b6d4;--ow-cyan-glow: rgba(34, 211, 238, .4);--ow-cyan-glow-strong: rgba(34, 211, 238, .6);--ow-gray-800: #1f2937;--ow-gray-900: #111827;--ow-border: rgba(34, 211, 238, .3);--ow-border-hover: rgba(34, 211, 238, .5);--ow-border-subtle: rgba(255, 255, 255, .05);--ow-success: #10b981;--ow-error: #ef4444;--ow-warning: #f59e0b;--ow-info: #22d3ee;--ow-font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--ow-text-xs: .75rem;--ow-text-sm: .875rem;--ow-text-base: 1rem;--ow-text-lg: 1.125rem;--ow-text-xl: 1.25rem;--ow-text-2xl: 1.5rem;--ow-text-3xl: 1.875rem;--ow-text-4xl: 2.25rem;--ow-leading-tight: 1.25;--ow-leading-normal: 1.5;--ow-leading-relaxed: 1.6;--ow-font-normal: 400;--ow-font-medium: 500;--ow-font-semibold: 600;--ow-font-bold: 700;--ow-space-1: 8px;--ow-space-2: 16px;--ow-space-3: 24px;--ow-space-4: 32px;--ow-space-5: 40px;--ow-space-6: 48px;--ow-space-8: 64px;--ow-space-12: 96px;--ow-space-16: 128px;--ow-radius-sm: 4px;--ow-radius-md: 8px;--ow-radius-lg: 12px;--ow-radius-xl: 16px;--ow-radius-full: 9999px;--ow-shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--ow-shadow-md: 0 2px 4px rgba(0, 0, 0, .5);--ow-shadow-lg: 0 4px 8px rgba(0, 0, 0, .5);--ow-shadow-xl: 0 8px 16px rgba(0, 0, 0, .5);--ow-text-glow-subtle: 0 0 10px rgba(34, 211, 238, .2);--ow-text-glow-medium: 0 0 20px rgba(34, 211, 238, .4);--ow-text-glow-strong: 0 0 30px rgba(34, 211, 238, .6);--ow-glow-subtle: 0 0 8px rgba(34, 211, 238, .15);--ow-glow-medium: 0 0 12px rgba(34, 211, 238, .25);--ow-glow-strong: 0 0 20px rgba(34, 211, 238, .4);--ow-glow-inset: inset 0 0 10px rgba(34, 211, 238, .1);--ow-glow-inset-strong: inset 0 0 15px rgba(34, 211, 238, .2);--ow-transition-quick: .15s ease-out;--ow-transition-standard: .25s ease-out;--ow-transition-complex: .35s ease-out}[data-theme=light]{--ow-bg-primary: #ffffff;--ow-bg-secondary: #f8fafc;--ow-bg-tertiary: #f1f5f9;--ow-text-primary: #1e293b;--ow-text-secondary: #475569;--ow-text-tertiary: #64748b;--ow-cyan-primary: #0891b2;--ow-border-subtle: rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--ow-font-sans);font-size:var(--ow-text-base);line-height:var(--ow-leading-normal);color:var(--ow-text-primary);background:var(--ow-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--ow-font-semibold);line-height:var(--ow-leading-tight);color:var(--ow-text-white)}h1{font-size:var(--ow-text-4xl)}h2{font-size:var(--ow-text-3xl)}h3{font-size:var(--ow-text-2xl)}h4{font-size:var(--ow-text-xl)}h5{font-size:var(--ow-text-lg)}h6{font-size:var(--ow-text-base)}a{color:var(--ow-cyan-primary);text-decoration:none;transition:color var(--ow-transition-quick)}a:hover{color:var(--ow-cyan-light)}button,.ow-btn{font-family:var(--ow-font-sans);font-size:var(--ow-text-base);font-weight:var(--ow-font-medium);text-transform:lowercase;cursor:pointer;border:none;background:none;padding:0}button:disabled,.ow-btn:disabled{opacity:.5;cursor:not-allowed}.ow-btn-primary{background:transparent;color:var(--ow-cyan-primary);border:1px solid var(--ow-cyan-primary);padding:12px 24px;border-radius:var(--ow-radius-lg);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-2);transition:all var(--ow-transition-quick);box-shadow:var(--ow-glow-subtle)}.ow-btn-primary:hover:not(:disabled){background:#22d3ee1a;border-color:var(--ow-cyan-light);color:var(--ow-cyan-light);box-shadow:var(--ow-glow-medium)}.ow-btn-primary:active:not(:disabled){transform:scale(.98);box-shadow:var(--ow-glow-subtle)}.ow-btn-primary:focus-visible{outline:none;box-shadow:var(--ow-glow-medium),0 0 0 3px #22d3ee33}.ow-btn-secondary{background:transparent;color:var(--ow-text-primary);border:1px solid var(--ow-text-secondary);padding:12px 24px;border-radius:var(--ow-radius-lg);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-2);transition:all var(--ow-transition-quick)}.ow-btn-secondary:hover:not(:disabled){border-color:var(--ow-text-primary);color:var(--ow-text-white)}.ow-btn-secondary:active:not(:disabled){transform:scale(.98)}.ow-btn-secondary:focus-visible{outline:none;border-color:var(--ow-cyan-primary);box-shadow:0 0 0 3px #22d3ee33}.btn-primary{background:var(--ow-cyan-primary);color:#fff!important;border:1px solid var(--ow-cyan-primary);padding:12px 24px;border-radius:var(--ow-radius-lg);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-2);transition:all var(--ow-transition-quick);box-shadow:var(--ow-glow-subtle);font-family:var(--ow-font-sans);font-size:var(--ow-text-base);font-weight:var(--ow-font-medium);text-transform:lowercase;cursor:pointer}.btn-primary:hover:not(:disabled){background:var(--ow-cyan-dark);border-color:var(--ow-cyan-light);color:#fff!important;box-shadow:var(--ow-glow-medium)}.btn-secondary{background:transparent;color:#fff!important;border:1px solid var(--ow-text-secondary);padding:12px 24px;border-radius:var(--ow-radius-lg);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-2);transition:all var(--ow-transition-quick);font-family:var(--ow-font-sans);font-size:var(--ow-text-base);font-weight:var(--ow-font-medium);text-transform:lowercase;cursor:pointer}.btn-secondary:hover:not(:disabled){border-color:var(--ow-text-primary);background:#ffffff1a;color:#fff!important}.btn-sm{padding:6px 12px!important;min-height:32px!important;font-size:var(--ow-text-sm)!important}.ow-btn-text{background:transparent;color:var(--ow-cyan-primary);border:none;padding:8px 16px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-1);transition:color var(--ow-transition-quick)}.ow-btn-text:hover:not(:disabled){color:var(--ow-cyan-light)}.ow-btn-text:active:not(:disabled){transform:scale(.98)}.ow-btn-text:focus-visible{outline:none;color:var(--ow-cyan-light);text-decoration:underline}.ow-btn-danger{background:transparent;color:var(--ow-error);border:1px solid var(--ow-error);padding:12px 24px;border-radius:var(--ow-radius-lg);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--ow-space-2);transition:all var(--ow-transition-quick)}.ow-btn-danger:hover:not(:disabled){background:#ef44441a}.ow-btn-danger:active:not(:disabled){transform:scale(.98)}.ow-btn-sm{padding:8px 16px;min-height:40px;font-size:var(--ow-text-sm)}.ow-btn-lg{padding:16px 32px;min-height:56px;font-size:var(--ow-text-lg)}.ow-card{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-3);box-shadow:var(--ow-shadow-sm);transition:box-shadow var(--ow-transition-quick),border-color var(--ow-transition-quick)}.ow-card:hover{border-color:#22d3ee33;box-shadow:var(--ow-shadow-md)}.ow-card-interactive{cursor:pointer}.ow-card-interactive:active{transform:scale(.99)}.ow-card-emphasis{background:var(--ow-bg-translucent);border:1px solid var(--ow-border);box-shadow:var(--ow-glow-subtle),var(--ow-glow-inset)}.ow-card-emphasis:hover{border-color:var(--ow-border-hover);box-shadow:var(--ow-glow-medium),var(--ow-glow-inset-strong)}input,textarea,select,.ow-input{font-family:var(--ow-font-sans);font-size:var(--ow-text-base);color:var(--ow-text-primary);background:var(--ow-bg-secondary);border:1px solid var(--ow-text-tertiary);border-radius:var(--ow-radius-md);padding:12px 16px;min-height:48px;width:100%;transition:border-color var(--ow-transition-quick),box-shadow var(--ow-transition-quick)}input:focus,textarea:focus,select:focus,.ow-input:focus{outline:none;border-color:var(--ow-cyan-primary);box-shadow:0 0 0 3px #22d3ee33}input::placeholder,textarea::placeholder,.ow-input::placeholder{color:var(--ow-text-tertiary)}input:disabled,textarea:disabled,select:disabled,.ow-input:disabled{opacity:.5;cursor:not-allowed}textarea{min-height:120px;resize:vertical}.ow-nav-top{position:fixed;top:0;left:0;right:0;background:var(--ow-gray-800);border-bottom:1px solid rgba(34,211,238,.2);display:flex;justify-content:space-around;align-items:center;padding:env(safe-area-inset-top,var(--ow-space-2)) var(--ow-space-2) var(--ow-space-2);z-index:100;height:calc(64px + env(safe-area-inset-top,0px))}.ow-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--ow-space-2);color:var(--ow-text-secondary);font-size:var(--ow-text-sm);text-transform:lowercase;text-decoration:none;transition:color var(--ow-transition-quick);min-width:48px;min-height:48px;position:relative;cursor:pointer;border:none;background:transparent}.ow-nav-tab:active{transform:scale(.95)}.ow-nav-tab.active{color:var(--ow-cyan-primary);font-weight:var(--ow-font-semibold)}.ow-nav-tab.active:after{content:"";position:absolute;bottom:-var(--ow-space-2);left:50%;transform:translate(-50%);width:32px;height:2px;background:var(--ow-cyan-primary)}.ow-nav-icon{font-size:24px}.ow-content-with-top-nav{padding-top:calc(64px + env(safe-area-inset-top,0px) + var(--ow-space-4))}.material-icons{color:var(--ow-cyan-primary);-webkit-user-select:none;user-select:none;vertical-align:middle;font-size:20px}button .material-icons,.ow-btn .material-icons,.ow-btn-primary .material-icons,.ow-btn-secondary .material-icons,.ow-btn-text .material-icons,.ow-btn-danger .material-icons{color:inherit}.ow-icon-error{color:var(--ow-error)}.ow-icon-success{color:var(--ow-success)}.ow-icon-warning{color:var(--ow-warning)}.ow-icon-neutral{color:var(--ow-text-secondary)}.ow-icon{display:inline-block;vertical-align:middle;line-height:1}.ow-icon-sm{font-size:18px}.ow-icon-md{font-size:24px}.ow-icon-lg{font-size:32px}.ow-icon-xl{font-size:48px}.ow-icon-interactive{color:var(--ow-cyan-primary);transition:color var(--ow-transition-quick)}.ow-icon-interactive:hover{color:var(--ow-cyan-light)}.ow-category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--ow-space-3);padding:var(--ow-space-4)}.ow-category-card{background:var(--ow-bg-translucent);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-4) var(--ow-space-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--ow-space-2);min-height:120px;cursor:pointer;transition:all var(--ow-transition-quick)}.ow-category-card:hover{background:#1e293b80;border-color:var(--ow-border);box-shadow:var(--ow-glow-subtle)}.ow-category-card:active{transform:scale(.98)}.ow-category-icon{color:var(--ow-cyan-primary);font-size:48px}.ow-category-label{color:var(--ow-text-primary);font-size:var(--ow-text-base);font-weight:var(--ow-font-medium);text-transform:capitalize;text-align:center}.ow-category-count{color:var(--ow-text-tertiary);font-size:var(--ow-text-sm)}.ow-toast{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border);border-radius:var(--ow-radius-lg);padding:var(--ow-space-3) var(--ow-space-4);box-shadow:var(--ow-shadow-lg),var(--ow-glow-subtle);color:var(--ow-text-primary);display:flex;align-items:center;gap:var(--ow-space-2);min-width:300px;max-width:500px}.ow-toast-success{border-color:var(--ow-success)}.ow-toast-error{border-color:var(--ow-error)}.ow-toast-warning{border-color:var(--ow-warning)}.ow-toast-info{border-color:var(--ow-cyan-primary)}.ow-toast-close{background:transparent;border:none;color:var(--ow-text-secondary);font-size:var(--ow-text-xl);cursor:pointer;padding:4px;min-width:32px;min-height:32px;border-radius:var(--ow-radius-sm);transition:all var(--ow-transition-quick)}.ow-toast-close:hover{color:var(--ow-text-white);background:#ffffff1a}.ow-toast-close:active{transform:scale(.95)}.ow-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--ow-space-4)}.ow-modal{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border);border-radius:var(--ow-radius-xl);box-shadow:var(--ow-shadow-xl),var(--ow-glow-medium);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;padding:var(--ow-space-6)}.ow-modal-header{border-bottom:1px solid var(--ow-border-subtle);padding-bottom:var(--ow-space-3);margin-bottom:var(--ow-space-4);display:flex;justify-content:space-between;align-items:center}.ow-modal-title{font-size:var(--ow-text-2xl);font-weight:var(--ow-font-semibold);color:var(--ow-text-white);text-transform:lowercase}.ow-modal-close{background:transparent;border:none;color:var(--ow-text-secondary);font-size:var(--ow-text-2xl);cursor:pointer;padding:var(--ow-space-1);min-width:32px;min-height:32px;transition:color var(--ow-transition-quick)}.ow-modal-close:hover{color:var(--ow-text-white)}.ow-modal-body{margin-bottom:var(--ow-space-4)}.ow-modal-footer{border-top:1px solid var(--ow-border-subtle);padding-top:var(--ow-space-3);display:flex;gap:var(--ow-space-2);justify-content:flex-end}.ow-footer{background:var(--ow-gray-900);border-top:1px solid rgba(34,211,238,.2);padding:var(--ow-space-6) var(--ow-space-4);margin-top:auto}.ow-footer-content{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:var(--ow-space-4);align-items:center}@media (min-width: 768px){.ow-footer-content{flex-direction:row;justify-content:space-between}}.ow-footer-brand{color:var(--ow-text-primary);font-weight:var(--ow-font-semibold);text-transform:lowercase;font-size:var(--ow-text-lg)}.ow-footer-brand:hover{color:var(--ow-cyan-primary)}.ow-footer-links{display:flex;gap:var(--ow-space-4)}.ow-footer-links a{color:var(--ow-text-secondary);font-size:var(--ow-text-sm);text-transform:lowercase;transition:color var(--ow-transition-quick)}.ow-footer-links a:hover{color:var(--ow-cyan-primary)}.ow-safe-top{padding-top:max(var(--ow-space-2),env(safe-area-inset-top))}.ow-safe-bottom{padding-bottom:max(var(--ow-space-2),env(safe-area-inset-bottom))}.ow-safe-left{padding-left:max(var(--ow-space-2),env(safe-area-inset-left))}.ow-safe-right{padding-right:max(var(--ow-space-2),env(safe-area-inset-right))}.ow-touch-target{min-width:48px;min-height:48px;display:inline-flex;align-items:center;justify-content:center}.ow-text-lowercase{text-transform:lowercase}.ow-text-center{text-align:center}.ow-text-right{text-align:right}.ow-mt-1{margin-top:var(--ow-space-1)}.ow-mt-2{margin-top:var(--ow-space-2)}.ow-mt-3{margin-top:var(--ow-space-3)}.ow-mt-4{margin-top:var(--ow-space-4)}.ow-mb-1{margin-bottom:var(--ow-space-1)}.ow-mb-2{margin-bottom:var(--ow-space-2)}.ow-mb-3{margin-bottom:var(--ow-space-3)}.ow-mb-4{margin-bottom:var(--ow-space-4)}.ow-p-2{padding:var(--ow-space-2)}.ow-p-3{padding:var(--ow-space-3)}.ow-p-4{padding:var(--ow-space-4)}.ow-container{max-width:1280px;margin:0 auto;padding:0 var(--ow-space-4)}.ow-flex{display:flex}.ow-flex-col{flex-direction:column}.ow-gap-2{gap:var(--ow-space-2)}.ow-gap-3{gap:var(--ow-space-3)}.ow-gap-4{gap:var(--ow-space-4)}*:focus-visible{outline:2px solid var(--ow-cyan-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}html,body{height:100%;overflow:hidden;max-width:100vw}#app{height:100%;display:flex;flex-direction:column;overflow:hidden}.screen{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.auth-screen{height:100%;display:flex;align-items:center;justify-content:center;padding:var(--ow-space-4)}.auth-container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--ow-space-4)}.auth-logo{text-align:center}.auth-title{text-align:center;font-size:var(--ow-text-3xl);color:var(--ow-cyan-primary);margin:0}.auth-subtitle{text-align:center;color:var(--ow-text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--ow-space-3)}.form-group{display:flex;flex-direction:column;gap:var(--ow-space-1)}.form-group label{font-size:var(--ow-text-sm);color:var(--ow-text-secondary);text-transform:lowercase}.auth-help{text-align:center;font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin:0}.home-screen{padding:var(--ow-space-4);display:flex;flex-direction:column;gap:var(--ow-space-4)}.home-header{display:flex;align-items:center;justify-content:space-between}.world-name{display:flex;align-items:center;gap:var(--ow-space-2);font-size:var(--ow-text-lg);font-weight:var(--ow-font-semibold);color:var(--ow-text-white);cursor:pointer;padding:var(--ow-space-1);margin:calc(var(--ow-space-1) * -1);border-radius:var(--ow-radius-md);transition:background var(--ow-transition-quick)}.world-name:active{background:#ffffff0d}.header-logo{width:28px;height:28px;object-fit:contain}.icon-btn{background:transparent;border:none;color:var(--ow-text-secondary);cursor:pointer;padding:var(--ow-space-1);min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--ow-radius-md);transition:all var(--ow-transition-quick)}.icon-btn:active{transform:scale(.95)}.icon-btn:hover{color:var(--ow-cyan-primary);background:#22d3ee1a}.home-search{margin-top:var(--ow-space-2)}.search-bar{position:relative;display:flex;align-items:center;background:var(--ow-bg-secondary);border:2px solid var(--ow-border);border-radius:var(--ow-radius-lg);padding:0 var(--ow-space-3);min-height:56px;transition:all var(--ow-transition-quick)}.search-bar:focus-within{border-color:var(--ow-cyan-primary);box-shadow:var(--ow-glow-medium)}.search-bar .material-icons{color:var(--ow-text-tertiary);margin-right:var(--ow-space-2)}.search-bar input{flex:1;background:transparent;border:none;color:var(--ow-text-primary);font-size:var(--ow-text-lg);padding:0;min-height:auto}.search-bar input:focus{outline:none;box-shadow:none}.section-title{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);text-transform:lowercase;font-weight:var(--ow-font-medium);margin:0 0 var(--ow-space-2) 0}.home-recent{margin-top:var(--ow-space-2)}.recent-list{display:flex;flex-direction:column;gap:var(--ow-space-2)}.recent-item{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-3);display:flex;align-items:center;gap:var(--ow-space-3);cursor:pointer;transition:all var(--ow-transition-quick);min-height:72px}.recent-item:active{transform:scale(.98)}.recent-item:hover{border-color:var(--ow-border);box-shadow:var(--ow-shadow-md)}.recent-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#22d3ee1a;border-radius:var(--ow-radius-md);flex-shrink:0}.recent-icon .material-icons{color:var(--ow-cyan-primary);font-size:24px}.recent-content{flex:1;min-width:0}.recent-name{font-weight:var(--ow-font-medium);color:var(--ow-text-white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-meta{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin-top:4px}.recent-arrow .material-icons{color:var(--ow-text-tertiary);font-size:20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--ow-space-6) var(--ow-space-4);gap:var(--ow-space-2);color:var(--ow-text-tertiary)}.empty-state .material-icons{font-size:48px;opacity:.5}.home-browse{margin-top:var(--ow-space-2)}.browse-button{width:100%;font-size:var(--ow-text-base)}.home-summary{margin-top:var(--ow-space-2);text-align:center}.summary-text{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin:0}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--ow-space-6)}.spinner{width:48px;height:48px;border:3px solid var(--ow-border-subtle);border-top-color:var(--ow-cyan-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.screen-header{display:flex;align-items:center;justify-content:space-between;padding:var(--ow-space-3) var(--ow-space-4);border-bottom:1px solid var(--ow-border-subtle);position:sticky;top:0;background:var(--ow-bg-primary);z-index:10}.screen-title{flex:1;text-align:center;font-size:var(--ow-text-xl);font-weight:var(--ow-font-semibold);color:var(--ow-text-white);margin:0}.type-picker-screen{background:var(--ow-bg-primary)}.type-picker-content{padding:var(--ow-space-4);display:flex;flex-direction:column;gap:var(--ow-space-6)}.type-category{display:flex;flex-direction:column;gap:var(--ow-space-3)}.category-label{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);text-transform:lowercase;font-weight:var(--ow-font-medium);margin:0}.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--ow-space-2)}.type-card{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--ow-space-1);min-height:100px;cursor:pointer;transition:all var(--ow-transition-quick)}.type-card:active{transform:scale(.95)}.type-card:hover{border-color:var(--ow-border);box-shadow:var(--ow-shadow-md)}.type-card-empty{opacity:.4;cursor:default}.type-card-empty:hover{border-color:var(--ow-border-subtle);box-shadow:none}.type-icon{color:var(--ow-cyan-primary);font-size:32px}.type-label{font-size:var(--ow-text-xs);color:var(--ow-text-secondary);text-align:center;line-height:1.2}.type-count{font-size:var(--ow-text-sm);color:var(--ow-text-primary);font-weight:var(--ow-font-semibold)}.list-screen{position:relative}.pull-to-refresh-wrapper{position:relative;height:100%}.pull-to-refresh-indicator{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;z-index:10}.pull-to-refresh-indicator .material-icons{color:var(--ow-text-tertiary);font-size:24px;transition:transform .3s ease}.pull-to-refresh-indicator.ptr-active .material-icons{color:var(--ow-cyan-primary)}.pull-to-refresh-indicator.ptr-refreshing .material-icons{color:var(--ow-cyan-primary);animation:ptr-spin .8s linear infinite}@keyframes ptr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.list-content{padding:var(--ow-space-4);padding-bottom:80px}.element-list{display:flex;flex-direction:column;gap:var(--ow-space-2)}.element-card{background:transparent;border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-2) var(--ow-space-3);display:flex;align-items:center;gap:var(--ow-space-3);cursor:pointer;transition:all var(--ow-transition-quick);min-height:56px}.element-card:active{transform:scale(.98)}.element-card:hover{border-color:var(--ow-cyan-primary);background:#22d3ee08}.element-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border-radius:var(--ow-radius-md);flex-shrink:0;overflow:hidden;position:relative}.element-card-icon.has-image{background:var(--ow-bg-secondary);padding:0}.element-card-icon .material-icons{color:var(--ow-cyan-primary);font-size:24px}.element-thumb{width:100%;height:100%;object-fit:cover;display:block}.element-card-content{flex:1;min-width:0}.element-card-name{font-weight:var(--ow-font-medium);color:var(--ow-text-white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.element-card-meta{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin-top:4px}.element-card-arrow .material-icons{color:var(--ow-text-tertiary);font-size:20px}.skeleton-card{cursor:default;pointer-events:none}.skeleton-card:hover{border-color:var(--ow-border-subtle);box-shadow:none}.skeleton-icon{background:var(--ow-bg-secondary);border-radius:var(--ow-radius-md);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-icon-small{width:20px;height:20px;background:var(--ow-bg-secondary);border-radius:var(--ow-radius-sm);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-line{height:12px;background:var(--ow-bg-secondary);border-radius:var(--ow-radius-sm);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-name{width:60%;height:16px;margin-bottom:8px}.skeleton-meta{width:40%}.skeleton-desc{width:80%;margin-top:8px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.fab{position:fixed;bottom:var(--ow-space-4);right:var(--ow-space-4);width:56px;height:56px;background:var(--ow-cyan-primary);border:none;border-radius:50%;box-shadow:0 4px 12px #22d3ee66;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ow-transition-quick);z-index:100}.fab:active{transform:scale(.9)}.fab:hover{background:var(--ow-cyan-dark);box-shadow:0 6px 16px #22d3ee80}.fab .material-icons{color:#000;font-size:28px}.search-screen{background:var(--ow-bg-primary)}.search-header{display:flex;align-items:center;gap:var(--ow-space-2);padding:var(--ow-space-3) var(--ow-space-4);border-bottom:1px solid var(--ow-border-subtle);position:sticky;top:0;background:var(--ow-bg-primary);z-index:10}.search-header .search-bar{flex:1}.search-content{padding:var(--ow-space-4)}.search-count{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin:0 0 var(--ow-space-3) 0}.search-results{display:flex;flex-direction:column;gap:var(--ow-space-2)}.search-result{background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);padding:var(--ow-space-3);display:flex;align-items:flex-start;gap:var(--ow-space-3);cursor:pointer;transition:all var(--ow-transition-quick)}.search-result:active{transform:scale(.98)}.search-result:hover{border-color:var(--ow-border);box-shadow:var(--ow-shadow-md)}.search-result-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#22d3ee1a;border-radius:var(--ow-radius-md);flex-shrink:0;overflow:hidden;position:relative}.search-result-icon.has-image{background:var(--ow-bg-secondary);padding:0}.search-result-icon .material-icons{color:var(--ow-cyan-primary);font-size:20px}.search-result-content{flex:1;min-width:0}.search-result-name{font-weight:var(--ow-font-medium);color:var(--ow-text-white);margin-bottom:4px}.search-result-meta{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin-bottom:6px}.search-result-desc{font-size:var(--ow-text-sm);color:var(--ow-text-secondary);line-height:1.4}.detail-content{padding:var(--ow-space-4)}.detail-image{margin-bottom:var(--ow-space-4);border-radius:var(--ow-radius-lg);overflow:hidden}.detail-image img{width:100%;height:auto;display:block}.detail-header{margin-bottom:var(--ow-space-6)}.detail-type-badge{display:inline-flex;align-items:center;gap:var(--ow-space-1);background:#22d3ee1a;border:1px solid var(--ow-border);border-radius:var(--ow-radius-full);padding:6px var(--ow-space-2);font-size:var(--ow-text-sm);color:var(--ow-cyan-primary);margin-bottom:var(--ow-space-2)}.detail-type-badge .material-icons{font-size:18px}.detail-name{font-size:var(--ow-text-3xl);font-weight:var(--ow-font-semibold);color:var(--ow-text-white);margin:0 0 var(--ow-space-1) 0}.detail-meta{font-size:var(--ow-text-lg);color:var(--ow-text-secondary);margin:0}.detail-section{margin-bottom:var(--ow-space-6)}.detail-section-title{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);text-transform:lowercase;font-weight:var(--ow-font-medium);margin:0 0 var(--ow-space-2) 0}.detail-description{color:var(--ow-text-primary);line-height:var(--ow-leading-relaxed);margin:0;white-space:pre-wrap}.detail-metadata{display:flex;flex-direction:column;gap:var(--ow-space-2)}.metadata-item{display:flex;gap:var(--ow-space-2)}.metadata-label{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);min-width:80px}.metadata-value{font-size:var(--ow-text-sm);color:var(--ow-text-primary)}.metadata-id{font-family:monospace;font-size:var(--ow-text-xs)}.detail-form{display:flex;flex-direction:column;gap:var(--ow-space-3)}.input-title{font-size:var(--ow-text-2xl)!important;font-weight:var(--ow-font-semibold);background:transparent!important;border:none!important;border-bottom:1px solid transparent!important;padding:var(--ow-space-1) 0!important;color:var(--ow-text-white)}.input-title:focus{border-bottom-color:var(--ow-cyan-primary)!important;outline:none}.form-row{display:flex;gap:var(--ow-space-3)}.form-group-half{flex:1}.detail-type-badge-small{display:inline-flex;align-items:center;gap:4px;font-size:var(--ow-text-sm);color:var(--ow-cyan-primary)}.detail-type-badge-small .material-icons{font-size:16px}.header-title{flex:1}.save-indicator{font-size:var(--ow-text-xs);color:var(--ow-text-tertiary);margin-right:var(--ow-space-1)}.save-indicator.error{color:var(--ow-red-primary)}.btn-full{width:100%}.header-menu{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;min-width:160px;background:var(--ow-bg-elevated);border:1px solid var(--ow-border);border-radius:var(--ow-radius-md);box-shadow:var(--ow-shadow-lg);z-index:100;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:var(--ow-space-2);width:100%;padding:var(--ow-space-3) var(--ow-space-3);background:transparent;border:none;color:var(--ow-text-primary);font-size:var(--ow-text-sm);text-align:left;cursor:pointer}.dropdown-item:active{background:var(--ow-bg-tertiary)}.dropdown-item .material-icons{font-size:18px;color:var(--ow-text-secondary)}.dropdown-danger,.dropdown-danger .material-icons{color:var(--ow-red-primary)}.type-indicator{display:inline-flex;align-items:center;gap:4px;font-size:var(--ow-text-sm);color:var(--ow-cyan-primary);margin-bottom:var(--ow-space-3)}.type-indicator .material-icons{font-size:16px}.header-center{flex:1;display:flex;justify-content:center}.link-field-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--ow-space-2) var(--ow-space-3);background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);color:var(--ow-text-primary);cursor:pointer;min-height:40px}.link-field-btn:active{background:var(--ow-bg-elevated)}.link-placeholder{color:var(--ow-text-tertiary);font-size:var(--ow-text-sm)}.link-value{display:flex;align-items:center;gap:6px;font-size:var(--ow-text-sm)}.link-value .material-icons{font-size:16px;color:var(--ow-cyan-primary)}.link-clear{color:var(--ow-text-tertiary);font-size:16px!important}.multi-link-field{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:6px var(--ow-space-2);background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);min-height:40px}.link-chips{display:contents}.link-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;background:#22d3ee26;border-radius:var(--ow-radius-full);font-size:var(--ow-text-xs);color:var(--ow-text-primary)}.link-chip .material-icons{font-size:12px;color:var(--ow-cyan-primary)}.chip-remove{cursor:pointer;color:var(--ow-text-tertiary)!important;font-size:12px!important;margin-left:2px}.link-add-btn{display:inline-flex;align-items:center;gap:2px;padding:3px 8px;background:transparent;border:1px dashed var(--ow-border);border-radius:var(--ow-radius-full);color:var(--ow-cyan-primary);font-size:var(--ow-text-xs);cursor:pointer}.link-add-btn .material-icons{font-size:14px}.link-add-btn:active{background:#22d3ee1a}.picker-content{padding:var(--ow-space-4)}.picker-list{display:flex;flex-direction:column;gap:var(--ow-space-2)}.picker-item{display:flex;align-items:center;gap:var(--ow-space-3);padding:var(--ow-space-3);background:var(--ow-bg-tertiary);border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);cursor:pointer;transition:all var(--ow-transition-quick)}.picker-item:active{transform:scale(.98)}.picker-item.selected{border-color:var(--ow-cyan-primary);background:#22d3ee1a}.picker-item-check .material-icons{font-size:24px;color:var(--ow-text-tertiary)}.picker-item.selected .picker-item-check .material-icons{color:var(--ow-cyan-primary)}.picker-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#22d3ee1a;border-radius:var(--ow-radius-md)}.picker-item-icon .material-icons{color:var(--ow-cyan-primary);font-size:20px}.picker-item-content{flex:1;min-width:0}.picker-item-name{font-weight:var(--ow-font-medium);color:var(--ow-text-white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-item-meta{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin-top:2px}.form-content{padding:var(--ow-space-4);display:flex;flex-direction:column;gap:var(--ow-space-4)}.form-danger-zone{margin-top:var(--ow-space-4);padding-top:var(--ow-space-4);border-top:1px solid var(--ow-border-subtle)}.form-group.has-error input,.form-group.has-error textarea{border-color:#ef4444;background:#ef44440d}.form-group.has-error input:focus,.form-group.has-error textarea:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-error{display:none;font-size:var(--ow-text-sm);color:#ef4444;margin-top:var(--ow-space-1);font-weight:var(--ow-font-medium)}.form-group.has-error .form-error{display:block}.settings-content{padding:var(--ow-space-4);display:flex;flex-direction:column;gap:var(--ow-space-6)}.settings-section{display:flex;flex-direction:column;gap:var(--ow-space-3)}.settings-section-title{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);text-transform:lowercase;font-weight:var(--ow-font-medium);margin:0}.settings-info{display:flex;flex-direction:column;gap:var(--ow-space-2)}.settings-info-item{display:flex;gap:var(--ow-space-2)}.settings-label{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);min-width:80px}.settings-value{font-size:var(--ow-text-sm);color:var(--ow-text-primary)}.settings-btn{width:100%}.settings-help{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);margin:0}.settings-about{font-size:var(--ow-text-sm);color:var(--ow-text-secondary);margin:0;line-height:1.6}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}.home-carousel{margin-top:var(--ow-space-2)}.carousel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--ow-space-2)}.carousel-title{font-size:var(--ow-text-sm);color:var(--ow-text-tertiary);text-transform:lowercase;font-weight:var(--ow-font-medium)}.icon-btn-sm{min-width:36px;min-height:36px;padding:var(--ow-space-1)}.icon-btn-sm .material-icons{font-size:20px}.carousel-track{display:flex;gap:var(--ow-space-2);overflow-x:auto;padding-bottom:var(--ow-space-2);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.carousel-track::-webkit-scrollbar{display:none}.carousel-tile{flex-shrink:0;width:80px;padding:var(--ow-space-3) var(--ow-space-2);background:transparent;border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);display:flex;flex-direction:column;align-items:center;gap:var(--ow-space-1);cursor:pointer;scroll-snap-align:start;transition:all var(--ow-transition-quick)}.carousel-tile:active{transform:scale(.95)}.carousel-tile:hover{border-color:var(--ow-cyan-primary);background:#22d3ee0d}.carousel-icon{font-size:24px;color:var(--ow-cyan-primary)}.carousel-label{font-size:var(--ow-text-xs);color:var(--ow-text-secondary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.carousel-count{font-size:var(--ow-text-xs);color:var(--ow-text-tertiary)}.home-footer{margin-top:auto;padding-top:var(--ow-space-4)}.disconnect-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--ow-space-2);padding:var(--ow-space-3);background:transparent;border:1px solid var(--ow-border-subtle);border-radius:var(--ow-radius-md);color:var(--ow-text-tertiary);font-size:var(--ow-text-sm);cursor:pointer;transition:all var(--ow-transition-quick)}.disconnect-btn:hover{border-color:var(--ow-text-tertiary);color:var(--ow-text-secondary)}.disconnect-btn .material-icons{font-size:18px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--ow-space-4)}.modal-content{background:var(--ow-bg-secondary);border:1px solid var(--ow-border);border-radius:var(--ow-radius-lg);width:100%;max-width:400px;max-height:80vh;overflow-y:auto}.modal-sm{max-width:320px}.modal-header{padding:var(--ow-space-4);border-bottom:1px solid var(--ow-border-subtle)}.modal-header h3{margin:0;font-size:var(--ow-text-lg);color:var(--ow-text-white)}.modal-body{padding:var(--ow-space-4);display:flex;flex-direction:column;gap:var(--ow-space-3)}.world-detail-item{display:flex;flex-direction:column;gap:var(--ow-space-1)}.detail-label{font-size:var(--ow-text-xs);color:var(--ow-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--ow-text-sm);color:var(--ow-text-primary)}.name-with-icon{display:flex;align-items:center;gap:var(--ow-space-2)}.name-icon{font-size:28px;color:var(--ow-cyan-primary);flex-shrink:0}.name-with-icon .input-title{flex:1}.slide-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:flex-end;z-index:1000}.slide-overlay-content{background:var(--ow-bg-primary);border-top-left-radius:var(--ow-radius-xl);border-top-right-radius:var(--ow-radius-xl);width:100%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.slide-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:var(--ow-space-4);border-bottom:1px solid var(--ow-border-subtle)}.slide-overlay-header h3{margin:0;font-size:var(--ow-text-lg);color:var(--ow-text-white)}.slide-overlay-search{padding:var(--ow-space-3) var(--ow-space-4)}.search-bar-sm{min-height:44px}.slide-overlay-body{flex:1;overflow-y:auto;padding:var(--ow-space-2) var(--ow-space-4)}.slide-overlay-footer{padding:var(--ow-space-4);border-top:1px solid var(--ow-border-subtle)}.link-picker-item{display:flex;align-items:center;gap:var(--ow-space-3);padding:var(--ow-space-3);border-radius:var(--ow-radius-md);cursor:pointer;transition:background var(--ow-transition-quick)}.link-picker-item:active{background:#ffffff0d}.link-picker-item.selected{background:#22d3ee1a}.link-picker-item .material-icons{color:var(--ow-cyan-primary);font-size:20px}.link-picker-name{flex:1;color:var(--ow-text-primary)}.link-picker-check{color:var(--ow-text-tertiary)!important}.link-picker-item.selected .link-picker-check{color:var(--ow-cyan-primary)!important}.category-order-screen .screen-header{position:sticky;top:0;background:var(--ow-bg-primary);z-index:10}.category-order-content{padding:var(--ow-space-4)}.order-lock-toggle{margin-bottom:var(--ow-space-4);padding:var(--ow-space-3);background:var(--ow-bg-secondary);border-radius:var(--ow-radius-md)}.toggle-label{display:flex;align-items:center;gap:var(--ow-space-3);cursor:pointer}.toggle-label input[type=checkbox]{display:none}.toggle-slider{width:44px;height:24px;background:var(--ow-bg-tertiary);border-radius:12px;position:relative;transition:background var(--ow-transition-quick);flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--ow-text-secondary);border-radius:50%;transition:all var(--ow-transition-quick)}.toggle-label input:checked+.toggle-slider{background:var(--ow-cyan-primary)}.toggle-label input:checked+.toggle-slider:after{left:22px;background:#fff}.toggle-text{color:var(--ow-text-primary);font-size:var(--ow-text-sm)}.toggle-hint{margin:var(--ow-space-2) 0 0 0;font-size:var(--ow-text-xs);color:var(--ow-text-tertiary)}.order-list{display:flex;flex-direction:column;gap:var(--ow-space-2)}.order-item{display:flex;align-items:center;gap:var(--ow-space-2);padding:var(--ow-space-2) var(--ow-space-3);background:var(--ow-bg-secondary);border-radius:var(--ow-radius-md);transition:all var(--ow-transition-quick)}.order-item.dragging{opacity:.5;transform:scale(.98)}.drag-handle{color:var(--ow-text-tertiary);cursor:grab;touch-action:none}.order-icon{color:var(--ow-cyan-primary);font-size:20px}.order-label{flex:1;color:var(--ow-text-primary);font-size:var(--ow-text-sm)}.order-buttons{display:flex;gap:var(--ow-space-1)}.order-btn{background:transparent;border:none;padding:var(--ow-space-1);color:var(--ow-text-tertiary);cursor:pointer;border-radius:var(--ow-radius-sm);transition:all var(--ow-transition-quick)}.order-btn:not(:disabled):hover{background:#ffffff1a;color:var(--ow-text-primary)}.order-btn:disabled{opacity:.3;cursor:not-allowed}.order-btn .material-icons{font-size:20px}.btn-danger-outline{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--ow-space-2);padding:var(--ow-space-3);background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:var(--ow-radius-md);color:#ef4444;font-size:var(--ow-text-sm);cursor:pointer;transition:all var(--ow-transition-quick)}.btn-danger-outline:hover{background:#ef44441a;border-color:#ef4444}.btn-danger-outline .material-icons{font-size:18px}.empty-state-sm{padding:var(--ow-space-4) var(--ow-space-3)}.empty-state-sm .material-icons{font-size:32px}.empty-state-sm p{font-size:var(--ow-text-sm)}
