@import"https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&display=swap";@import"https://fonts.cdnfonts.com/css/google-sans";:root{--font-body: "Product Sans", "Google Sans", sans-serif;--font-interface: "Product Sans", "Google Sans", sans-serif;--font-display: "EB Garamond", serif;--font-mono: "Product Sans", "Google Sans", monospace;--color-ink: #1b1914;--color-ink-muted: rgba(27, 25, 20, .64);--color-paper: #f6f2e8;--color-paper-soft: rgba(246, 242, 232, .9);--color-bg: #0c0a09;--color-bg-elevated: #1a1816;--color-bg-subtle: rgba(255, 255, 255, .03);--color-text: #e8e6e3;--color-text-muted: rgba(232, 230, 227, .6);--color-text-subtle: rgba(232, 230, 227, .4);--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .16);--color-accent: #f5f3f0;--color-focus: #b88b4a;--color-focus-blue: #60a5fa;--color-danger: #a34a37;--color-success: #10b981;--shadow-soft: 0 16px 40px rgba(27, 25, 20, .09);font-family:var(--font-body);line-height:1.5;font-weight:400;color:var(--color-ink);background:radial-gradient(circle at 20% 15%,#f7f0e4,#f1eadc 45%,#e9e0cf),linear-gradient(120deg,#b88b4a14,#1b19140d);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{margin:0;min-width:320px;min-height:100vh;background:transparent;overflow-x:hidden;overflow-y:auto;touch-action:manipulation;overscroll-behavior:auto}#root{min-height:100vh}body.map-scroll-lock{overflow:hidden;touch-action:none;overscroll-behavior:none}button,input,textarea{font-family:inherit}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}:root{--bg-primary: #f6f2e8;--text-primary: #1b1914;--accent-gold: #b88b4a;--accent-red: #a34a37;--accent-green: #547c60;--font-display: "EB Garamond", serif;--font-mono: "Google Sans Mono", monospace;--font-sans: "Product Sans", "Google Sans", sans-serif;--shadow-sm: 0 2px 8px rgba(27, 25, 20, .05);--shadow-md: 0 8px 24px rgba(27, 25, 20, .1);--border-color: rgba(27, 25, 20, .12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:400!important}a{color:inherit;text-decoration:none}button{font-family:inherit}.map-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:crosshair;touch-action:none}.map-canvas.painting{cursor:crosshair}.map-canvas.dragging{cursor:grabbing}.map-veil{position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.32),transparent 55%),radial-gradient(circle at 80% 20%,rgba(184,139,74,.14),transparent 50%),radial-gradient(circle at 30% 80%,rgba(27,25,20,.08),transparent 55%);mix-blend-mode:multiply;pointer-events:none}.hud{position:fixed;top:20px;left:20px;display:flex;flex-direction:column;gap:6px;letter-spacing:.2em;text-transform:uppercase;font-weight:600}.hud-account{position:fixed;top:20px;right:20px;z-index:5;display:flex;flex-direction:row;gap:8px;align-items:center}.landing-page{min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-interface)}.landing-header{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:#0c0a09cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.landing-mark{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--color-text);letter-spacing:.05em;transition:opacity .2s ease}.landing-mark:hover{opacity:.7}.landing-header-actions{display:flex;align-items:center;gap:24px}.landing-header-actions>a{font-size:.9rem;color:var(--color-text-muted);transition:color .2s ease}.landing-header-actions>a:hover{color:var(--color-text)}.landing-hero{text-align:center;padding:0 24px;max-width:680px;margin:0 auto}.landing-divider{width:1px;height:60px;margin:0 auto 40px;background:var(--color-border)}.landing-hero h1{margin:0 0 32px;font-family:var(--font-display);font-size:4rem;line-height:1;letter-spacing:-.03em;font-weight:400;color:var(--color-text)}.landing-hero-sub{margin:0 auto;color:var(--color-text-muted);font-size:1.25rem;line-height:1.5;font-family:var(--font-display)}.landing-preview{padding:120px 24px}.landing-preview-grid{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}.landing-preview-grid article{background:var(--color-bg-elevated);border-radius:8px;padding:24px 20px;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden;border:1px solid var(--color-border);transition:transform .3s ease;min-height:240px}.landing-preview-grid article:before{content:"";position:absolute;top:0;left:0;right:0;height:6px}.landing-preview-grid article:nth-child(1):before{background:#ea580c}.landing-preview-grid article:nth-child(2):before{background:#3b82f6}.landing-preview-grid article:nth-child(3):before{background:#22c55e}.landing-preview-grid article:hover{transform:translateY(-4px);border-color:var(--color-border-hover)}.landing-preview-grid span{display:inline-block;padding:4px 8px;background:#ffffff0d;border-radius:4px;color:var(--color-text-subtle);font-family:var(--font-mono);font-size:.75rem;align-self:flex-start;margin-top:8px}.landing-preview-grid h3{margin:0;font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--color-text);line-height:1.1;letter-spacing:-.01em}.landing-preview-grid p{margin:0;color:var(--color-text-muted);font-size:.95rem;line-height:1.5;font-family:var(--font-interface)}.landing-copy-wrap{padding:0 24px 100px}.landing-copy{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:32px;font-size:1.05rem;line-height:1.7;color:var(--color-text-muted)}.landing-copy p{margin:0}.landing-copy blockquote{margin:0;padding-left:24px;border-left:3px solid var(--color-accent);font-style:italic;color:var(--color-text)}.landing-action{padding:100px 24px}.landing-action-inner{max-width:500px;margin:0 auto;padding:0;border:none;background:transparent;display:flex;flex-direction:column;gap:24px;text-align:center;align-items:center}.landing-action-inner h2{font-size:2rem;font-family:var(--font-display);letter-spacing:-.02em}.landing-action-inner p{font-size:1.1rem;color:var(--color-text-muted)}.landing-buttons{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:12px;width:100%}.landing-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;padding:14px 28px;font-size:.95rem;font-family:var(--font-interface);font-weight:500;transition:all .2s ease;min-width:140px}.landing-btn.primary{background:var(--color-text);color:var(--color-bg);border:1px solid var(--color-text)}.landing-btn.primary:hover{background:#fff;color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #ffffff1a}.landing-btn.secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.landing-btn.secondary:hover{border-color:var(--color-text);background:#ffffff0d}.landing-faq{padding:0 24px 78px}.landing-faq h2{margin:0 0 48px;text-align:center;font-family:var(--font-display);font-size:2rem;color:var(--color-text);letter-spacing:-.02em}.landing-faq-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.landing-faq-list article{padding:24px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-elevated)}.landing-faq-list h3{margin:0 0 12px;font-size:1.125rem;font-family:var(--font-display);color:var(--color-text)}.landing-faq-list p{margin:0;color:var(--color-text-muted);line-height:1.6}.landing-footer-note{max-width:640px;margin:48px auto 0;padding:0 24px 48px;text-align:center;font-size:.85rem;color:var(--color-text-subtle);line-height:1.6}.landing-footer-links{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:24px}.landing-footer-links>a:not(.landing-btn){font-size:.9rem;color:var(--color-text-muted);text-decoration:none;border-bottom:1px solid var(--color-border);transition:border-color .2s ease,color .2s ease}.landing-footer-links>a:not(.landing-btn):hover{color:var(--color-text);border-color:var(--color-text)}@media(max-width:900px){.landing-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-hero h1{font-size:3rem}}@media(max-width:640px){.landing-preview-grid{grid-template-columns:1fr}.landing-hero h1{font-size:2.5rem}.landing-header{padding:16px 20px}.landing-buttons{flex-direction:column;width:100%}.landing-btn{width:100%}.landing-footer-links{flex-direction:column;gap:16px}}.account-button{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid rgba(27,25,20,.2);background:#f6f2e8e6;color:#1b1914e6;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;transition:all .2s ease}.account-button:hover{background:#f6f2e8;transform:translateY(-1px)}.account-button.secondary{background:#ffffffb3;border-color:#1b191426;font-size:.65rem;padding:5px 10px}.purchase-panel{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:10;background:var(--color-paper);border:1px solid rgba(27,25,20,.12);border-radius:16px;padding:20px 24px;box-shadow:var(--shadow-soft);min-width:360px;max-width:90vw}.purchase-title{margin:0 0 16px;font-size:1.125rem;color:var(--color-ink)}.purchase-controls{display:flex;flex-direction:column;gap:12px}.purchase-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.purchase-input{flex:1;padding:8px 12px;border:1px solid rgba(27,25,20,.12);border-radius:8px;font-family:inherit;font-size:.95rem;background:#fff}.purchase-button{padding:10px 20px;border:none;border-radius:8px;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.purchase-button.primary{background:var(--accent-gold);color:#fff}.purchase-button.primary:hover{background:#a07840;transform:translateY(-1px)}.purchase-button.secondary{background:#1b191414;color:var(--color-ink)}.purchase-button.secondary:hover{background:#1b19141f}.purchase-button:disabled{opacity:.5;cursor:not-allowed}.info-panel{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:10;background:var(--color-paper);border:1px solid rgba(27,25,20,.12);border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-soft);min-width:300px;text-align:center}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:var(--color-paper);border-radius:16px;padding:32px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-ink-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background:#1b191414;color:var(--color-ink)}@media(max-width:640px){.purchase-panel,.info-panel{min-width:unset;width:calc(100% - 40px);left:20px;right:20px;transform:none}.modal-content{padding:24px}}.app{position:relative;min-height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6,.hud-title,.auth-title,.profile-title,.analytics-title,.admin-title,.purchase-title,.directory-name,.admin-item-title span:first-child,.analytics-top-item span{font-family:var(--font-display);font-weight:400!important}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:var(--color-paper);border:1px solid var(--border-color);border-radius:16px;padding:40px;max-width:400px;width:100%;box-shadow:var(--shadow-md)}.auth-title{font-size:2rem;margin:0 0 24px;text-align:center;color:var(--color-ink)}.auth-status{text-align:center;color:var(--color-ink-muted);margin-bottom:24px}.auth-providers{display:flex;flex-direction:column;gap:12px}.auth-provider-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 24px;border:1px solid var(--border-color);border-radius:8px;background:#fff;color:var(--text-primary);font-family:inherit;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.auth-provider-btn:hover{background:var(--bg-primary);border-color:var(--accent-gold);transform:translateY(-1px)}.auth-provider-btn:disabled{opacity:.5;cursor:not-allowed}.profile-page{min-height:100vh;padding:80px 20px 40px}.profile-container{max-width:600px;margin:0 auto}.profile-title{font-size:2rem;margin:0 0 32px;text-align:center}.profile-card{background:var(--color-paper);border:1px solid var(--border-color);border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.profile-form{display:flex;flex-direction:column;gap:20px}.profile-field{display:flex;flex-direction:column;gap:8px}.profile-label{font-size:.9rem;font-weight:600;color:var(--color-ink);text-transform:uppercase;letter-spacing:.05em}.profile-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-family:inherit;font-size:1rem;background:#fff;transition:border-color .2s ease}.profile-input:focus{outline:none;border-color:var(--accent-gold)}.profile-actions{display:flex;gap:12px;margin-top:12px}.profile-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-btn.primary{background:var(--accent-gold);color:#fff}.profile-btn.primary:hover{background:#a07840;transform:translateY(-1px)}.profile-btn.secondary{background:#1b191414;color:var(--color-ink)}.profile-btn.secondary:hover{background:#1b19141f}.analytics-page{min-height:100vh;padding:80px 20px 40px}.analytics-container{max-width:1200px;margin:0 auto}.analytics-title{font-size:2rem;margin:0 0 32px;text-align:center}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:40px}.analytics-card{background:var(--color-paper);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm)}.analytics-card h3{font-size:1.25rem;margin:0 0 16px;color:var(--color-ink)}.analytics-stat{font-size:2.5rem;font-weight:600;color:var(--accent-gold);margin:0}.analytics-top-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.analytics-top-item:last-child{border-bottom:none}.admin-page{min-height:100vh;padding:80px 20px 40px}.admin-container{max-width:1200px;margin:0 auto}.admin-title{font-size:2rem;margin:0 0 32px;text-align:center}.admin-table{background:var(--color-paper);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}.admin-table table{width:100%;border-collapse:collapse}.admin-table th{background:#1b19140a;padding:16px;text-align:left;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-ink-muted)}.admin-table td{padding:16px;border-top:1px solid var(--border-color)}.admin-actions{display:flex;gap:8px}.admin-btn{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;background:#fff;font-size:.85rem;cursor:pointer;transition:all .2s ease}.admin-btn:hover{background:var(--bg-primary);border-color:var(--accent-gold)}@media(max-width:768px){.auth-card{padding:32px 24px}.profile-page,.analytics-page,.admin-page{padding:60px 16px 32px}.profile-card{padding:24px}.analytics-grid{grid-template-columns:1fr}.admin-table{overflow-x:auto}.admin-table table{min-width:600px}}.text-center{text-align:center}.text-muted{color:var(--color-ink-muted)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-ink-muted)}.error{padding:16px;background:#a34a371a;border:1px solid var(--accent-red);border-radius:8px;color:var(--accent-red);text-align:center}.success{padding:16px;background:#547c601a;border:1px solid var(--accent-green);border-radius:8px;color:var(--accent-green);text-align:center}
