:root{--color-danger: #B91C1C;--color-danger-dark: #991B1B;--color-danger-light: #DC2626;--color-warning: #D97706;--color-warning-light: #F59E0B;--color-success: #059669;--color-success-light: #10B981;--color-charcoal: #1F2937;--color-charcoal-light: #374151;--color-gray: #6B7280;--color-gray-light: #9CA3AF;--color-border: #E5E7EB;--color-bg: #F9FAFB;--color-bg-alt: #FFFFFF;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-size-6xl: 3.75rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--container-max: 1200px;--container-sm: 640px;--container-md: 768px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-charcoal);background-color:var(--color-bg);min-height:100vh}img,svg{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--color-charcoal)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p{margin-bottom:var(--space-4)}.text-muted{color:var(--color-gray)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-success{color:var(--color-success)}.text-center{text-align:center}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6)}.container-sm{max-width:var(--container-sm)}.container-md{max-width:var(--container-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.my-8{margin-top:var(--space-8);margin-bottom:var(--space-8)}.my-12{margin-top:var(--space-12);margin-bottom:var(--space-12)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.py-12{padding-top:var(--space-12);padding-bottom:var(--space-12)}.py-16{padding-top:var(--space-16);padding-bottom:var(--space-16)}.py-20{padding-top:var(--space-20);padding-bottom:var(--space-20)}.disclaimer{position:fixed;bottom:0;left:0;right:0;background:var(--color-charcoal);color:var(--color-bg);padding:var(--space-2) var(--space-6);font-size:var(--font-size-xs);z-index:1000;display:flex;align-items:center;justify-content:center;border-top:1px solid rgba(255,255,255,.1)}.disclaimer-content{flex:1;text-align:center}.disclaimer p{margin-bottom:0;opacity:.9}.disclaimer strong{color:var(--color-warning-light);text-transform:uppercase;letter-spacing:.05em;margin-right:var(--space-2)}.disclaimer-close{font-size:1.5rem;line-height:1;color:#fff;opacity:.6;padding:0 var(--space-2);transition:opacity var(--transition-fast)}.disclaimer-close:hover{opacity:1}@media(max-width:768px){h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}.container{padding:0 var(--space-4)}}@media(max-width:480px){h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}}.header{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);padding:var(--space-3) 0;position:sticky;top:44px;z-index:1000}.header-inner{display:flex!important;align-items:center!important;justify-content:space-between!important}.logo{display:flex!important;flex-direction:row!important;align-items:center!important;gap:var(--space-3);font-size:var(--font-size-xl);font-weight:800;color:var(--color-danger);line-height:1}.logo-icon{width:36px;height:36px;flex-shrink:0}.nav{display:flex;align-items:center;gap:var(--space-6)}.nav-link{font-weight:500;color:var(--color-charcoal-light);transition:color var(--transition-fast);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:transparent!important}.nav-link:hover{color:var(--color-danger)}.nav-link.active{color:var(--color-danger);font-weight:700}.nav-cta{background:var(--color-danger);color:#fff!important;border-radius:var(--radius-lg);font-weight:700;padding:var(--space-2) var(--space-5);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap;min-width:fit-content}.nav-cta:hover{background:#991b1b;box-shadow:var(--shadow-md);transform:translateY(-1px);color:#fff!important}.nav-toggle{display:none;flex-direction:column;gap:4px;padding:var(--space-2)}.nav-toggle span{width:24px;height:2px;background:var(--color-charcoal);transition:var(--transition-fast)}@media(max-width:768px){.nav-toggle{display:flex}.nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-bg-alt);flex-direction:column;padding:var(--space-4);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.nav.open{display:flex}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;border:2px solid transparent}.btn-primary{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-primary:hover{background:var(--color-danger-dark);border-color:var(--color-danger-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--color-charcoal);border-color:var(--color-border)}.btn-secondary:hover{border-color:var(--color-charcoal);background:var(--color-bg)}.btn-danger{background:var(--color-danger-light);color:#fff}.btn-danger:hover{background:var(--color-danger)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:var(--color-success-light)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn-block{width:100%}.card{background:var(--color-bg-alt);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.card-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-2)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-gray)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-weight:600;font-size:var(--font-size-sm);color:var(--color-charcoal)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-alt);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-danger);box-shadow:0 0 0 3px #b91c1c26}.form-input::placeholder{color:var(--color-gray-light)}.form-textarea{min-height:120px;resize:vertical}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:20px;padding-right:var(--space-10)}.form-radio-group{display:flex;gap:var(--space-4);flex-wrap:wrap}.form-radio-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-radio-label:hover{border-color:var(--color-gray-light)}.form-radio-label input{display:none}.form-radio-label.selected{border-color:var(--color-danger);background:#b91c1c0d}.form-hint{font-size:var(--font-size-sm);color:var(--color-gray);margin-top:var(--space-1)}.score-display{text-align:center;padding:var(--space-8)}.score-circle{width:180px;height:180px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto var(--space-6);position:relative;background:var(--color-bg)}.score-circle:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:8px solid var(--color-border)}.score-circle.high-risk:before{border-color:var(--color-danger)}.score-circle.medium-risk:before{border-color:var(--color-warning)}.score-circle.low-risk:before{border-color:var(--color-success)}.score-value{font-size:var(--font-size-5xl);font-weight:800;line-height:1}.score-label{font-size:var(--font-size-sm);color:var(--color-gray);margin-top:var(--space-1)}.risk-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-weight:700;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.risk-badge.high{background:#b91c1c26;color:var(--color-danger)}.risk-badge.medium{background:#d9770626;color:var(--color-warning)}.risk-badge.low{background:#05966926;color:var(--color-success)}.risk-factors{margin-top:var(--space-6)}.risk-factor{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg);border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.risk-factor-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-sm)}.risk-factor-icon.danger{background:#b91c1c26;color:var(--color-danger)}.risk-factor-icon.warning{background:#d9770626;color:var(--color-warning)}.risk-factor-icon.success{background:#05966926;color:var(--color-success)}.risk-factor-text{flex:1}.risk-factor-title{font-weight:600;margin-bottom:var(--space-1)}.risk-factor-desc{font-size:var(--font-size-sm);color:var(--color-gray)}.report-card{padding:var(--space-4);border-left:4px solid var(--color-danger);margin-bottom:var(--space-4)}.report-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.report-card-location{font-weight:700;font-size:var(--font-size-lg)}.report-card-time{font-size:var(--font-size-xs);color:var(--color-gray)}.report-card-issue{display:inline-block;padding:var(--space-1) var(--space-3);background:#b91c1c1a;color:var(--color-danger);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-2)}.report-card-desc{font-size:var(--font-size-sm);color:var(--color-charcoal-light)}.footer{background:var(--color-charcoal);color:var(--color-gray-light);padding:var(--space-12) 0;margin-bottom:48px}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-8)}.footer-brand{display:flex;align-items:center;gap:var(--space-3);color:#fff;font-size:var(--font-size-xl);font-weight:800;margin-bottom:var(--space-4)}.footer-desc{font-size:var(--font-size-sm);line-height:1.7;margin-bottom:0}.footer-title{color:#fff;font-size:var(--font-size-sm);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4)}.footer-links{display:flex;flex-direction:column;gap:var(--space-2)}.footer-link{font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer-link:hover{color:#fff}.footer-bottom{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:var(--font-size-sm)}@media(max-width:768px){.footer-content{grid-template-columns:1fr 1fr}.footer-about{grid-column:span 2}}@media(max-width:480px){.footer-content{grid-template-columns:1fr}.footer-about{grid-column:auto}}.empty-state{text-align:center;padding:var(--space-12);color:var(--color-gray)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-charcoal);margin-bottom:var(--space-2)}.alert{padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex;align-items:flex-start;gap:var(--space-3)}.alert-success{background:#0596691a;border:1px solid var(--color-success);color:var(--color-success)}.alert-warning{background:#d977061a;border:1px solid var(--color-warning);color:var(--color-warning)}.alert-danger{background:#b91c1c1a;border:1px solid var(--color-danger);color:var(--color-danger)}.qr-container{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);display:inline-block;box-shadow:var(--shadow-lg)}.qr-container canvas{display:block}.qr-instructions{text-align:center;margin-top:var(--space-4);font-size:var(--font-size-sm);color:var(--color-gray)}.demo-mode-badge{position:fixed;top:80px;right:16px;background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-light) 100%);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:700;display:flex;align-items:center;gap:var(--space-2);z-index:1000;box-shadow:var(--shadow-lg);animation:demo-pulse 2s infinite}.demo-mode-badge .demo-mode-toggle{background:#fff3;border:none;color:#fff;padding:4px 8px;border-radius:var(--radius-md);font-size:var(--font-size-xs);cursor:pointer;transition:background var(--transition-fast)}.demo-mode-badge .demo-mode-toggle:hover{background:#ffffff4d}@keyframes demo-pulse{0%,to{opacity:1}50%{opacity:.85}}.data-source-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--color-bg);border-radius:var(--radius-full);font-size:10px;color:var(--color-gray);font-weight:500}.data-source-badge.curated{background:#3b82f61a;color:#3b82f6}.data-source-badge.osm{background:#22c55e1a;color:#22c55e}.data-source-badge.community{background:#a855f71a;color:#a855f7}.score-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-4)}.score-breakdown-item{background:var(--color-bg);padding:var(--space-3);border-radius:var(--radius-lg);text-align:center}.score-breakdown-value{font-size:var(--font-size-xl);font-weight:700;line-height:1}.score-breakdown-label{font-size:var(--font-size-xs);color:var(--color-gray);margin-top:var(--space-1)}.last-updated{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-gray)}.last-updated:before{content:"🕐"}.city-landmark-card{transition:transform var(--transition-base),box-shadow var(--transition-base)}.city-landmark-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.city-landmark-card:hover>div:first-child{transform:scale(1.05)}.hero{padding:var(--space-24) 0;background:radial-gradient(circle at top,rgba(185,28,28,.03) 0%,transparent 50%),linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-alt) 100%);position:relative;overflow:hidden}.hero-content{position:relative;z-index:2;text-align:center}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#b91c1c14;color:var(--color-danger);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-8)}.hero-title{font-size:var(--font-size-6xl);font-weight:800;line-height:1.1;margin-bottom:var(--space-8);background:linear-gradient(135deg,var(--color-charcoal) 0%,var(--color-charcoal-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title span{background:linear-gradient(135deg,var(--color-danger) 0%,var(--color-danger-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:var(--font-size-xl);color:var(--color-gray);line-height:1.7;margin-bottom:var(--space-8)}.hero-actions{display:flex;gap:var(--space-4);flex-wrap:wrap}@media(max-width:992px){.hero-layout{grid-template-columns:1fr;text-align:center;gap:var(--space-12)}.hero-content{max-width:100%}.hero-mockup{transform:none;max-width:450px;margin:0 auto}.hero-actions{justify-content:center}}@media(max-width:768px){.hero{padding:var(--space-12) 0}.hero-title{font-size:var(--font-size-4xl)}.hero-subtitle{font-size:var(--font-size-lg)}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}}.features{padding:var(--space-20) 0}.section-header{text-align:center;max-width:600px;margin:0 auto var(--space-12)}.section-title{margin-bottom:var(--space-4)}.section-subtitle{color:var(--color-gray);font-size:var(--font-size-lg);margin-bottom:0}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.feature-card{text-align:center;padding:var(--space-8)}.feature-icon{width:64px;height:64px;margin:0 auto var(--space-6);background:linear-gradient(135deg,#b91c1c1a,#b91c1c0d);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem}.feature-title{font-size:var(--font-size-xl);margin-bottom:var(--space-3)}.feature-desc{color:var(--color-gray);margin-bottom:0}@media(max-width:768px){.features-grid{grid-template-columns:1fr;gap:var(--space-6)}}.problem-section{padding:var(--space-24) 0;background:#0f172a;color:#fff;position:relative}.problem-section .section-title{color:#fff}.problem-section .section-subtitle{color:var(--color-gray-light);opacity:.8}.problem-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-10);margin-top:var(--space-16)}.stat-card{text-align:center;padding:var(--space-10) var(--space-6);background:#ffffff08;border-radius:var(--radius-2xl);border:1px solid rgba(255,255,255,.06);transition:transform var(--transition-base),background var(--transition-base)}.stat-card:hover{transform:translateY(-5px);background:#ffffff0d}.stat-value{font-size:var(--font-size-6xl);font-weight:800;color:#fff;line-height:1;margin-bottom:var(--space-4);letter-spacing:-.02em}.stat-label{font-size:var(--font-size-base);color:var(--color-gray-light);line-height:1.5;opacity:.9}@media(max-width:768px){.problem-stats{grid-template-columns:1fr}}.page-header{padding:var(--space-12) 0;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-alt) 100%);text-align:center}.page-title{margin-bottom:var(--space-4)}.page-subtitle{color:var(--color-gray);font-size:var(--font-size-lg);max-width:600px;margin:0 auto}.check-building-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);padding:var(--space-12) 0 var(--space-20)}.form-section{position:sticky;top:100px;align-self:start}.results-section{min-height:400px}.results-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;text-align:center;color:var(--color-gray);background:var(--color-bg);border-radius:var(--radius-xl);border:2px dashed var(--color-border)}.results-placeholder-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.3}@media(max-width:900px){.check-building-layout{grid-template-columns:1fr}.form-section{position:static}}.report-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-8);padding:var(--space-12) 0 var(--space-20)}.reports-feed{max-height:600px;overflow-y:auto;padding-right:var(--space-4)}.reports-feed::-webkit-scrollbar{width:6px}.reports-feed::-webkit-scrollbar-track{background:var(--color-bg);border-radius:var(--radius-full)}.reports-feed::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}@media(max-width:900px){.report-layout{grid-template-columns:1fr}}.evacuation-page{min-height:100vh;background:var(--color-bg);color:var(--color-charcoal);padding-bottom:80px}.evacuation-header{padding:var(--space-6) 0;border-bottom:1px solid var(--color-border);background:#fff;box-shadow:var(--shadow-sm)}.evacuation-header-inner{display:flex;justify-content:space-between;align-items:center}.evacuation-title{display:flex;align-items:center;gap:var(--space-3);color:var(--color-charcoal)}.evacuation-badge{padding:var(--space-2) var(--space-4);background:var(--color-danger);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.evacuation-content{padding:var(--space-8) 0}.evacuation-building-info{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-8);box-shadow:var(--shadow-sm)}.evacuation-building-name{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-2);color:var(--color-charcoal)}.evacuation-building-address{color:var(--color-gray)}.evacuation-instructions{margin-bottom:var(--space-8)}.evacuation-instructions h3{color:var(--color-charcoal)!important}.evacuation-step{display:flex;gap:var(--space-4);padding:var(--space-4);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-3);border-left:4px solid var(--color-danger);box-shadow:var(--shadow-sm)}.evacuation-step-number{width:32px;height:32px;background:var(--color-danger);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.evacuation-step-text{font-size:var(--font-size-lg);color:var(--color-charcoal)}.evacuation-exits{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.exit-card{background:#fff;border:2px solid var(--color-success);border-radius:var(--radius-xl);padding:var(--space-5);text-align:center;box-shadow:var(--shadow-sm)}.exit-icon{font-size:2.5rem;margin-bottom:var(--space-2)}.exit-name{font-weight:700;font-size:var(--font-size-lg);margin-bottom:var(--space-1);color:var(--color-charcoal)}.exit-direction{font-size:var(--font-size-sm);color:var(--color-gray)}.building-selector{padding:var(--space-12) 0;background:var(--color-bg)}.building-selector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}.building-select-card{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.building-select-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.demo-buildings{padding:var(--space-16) 0}.demo-building-card{margin-bottom:var(--space-6)}.demo-building-header{display:flex;justify-content:space-between;align-items:flex-start}.demo-building-score{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--font-size-xl);color:#fff}.demo-building-score.high-risk{background:var(--color-danger)}.demo-building-score.medium-risk{background:var(--color-warning)}.demo-building-score.low-risk{background:var(--color-success)}.poster-page-wrapper{min-height:100vh;background:#e2e8f0;padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.poster-container{background:#fff;width:210mm;min-height:297mm;padding:10mm;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;color:#000;font-family:Inter,sans-serif;position:relative;overflow:hidden}.poster-border{border:4px solid #000;height:100%;padding:20px;display:flex;flex-direction:column;justify-content:space-between}.poster-header{text-align:center;border-bottom:4px solid #000;padding-bottom:20px;margin-bottom:20px}.poster-header h1{font-size:3.5rem;font-weight:900;margin:0;line-height:1;text-transform:uppercase}.poster-header p{font-size:1.5rem;font-weight:700;margin:10px 0 0;color:#dc2626;text-transform:uppercase;letter-spacing:2px}.poster-content{flex-grow:1;text-align:center;display:flex;flex-direction:column;align-items:center}.poster-building-name{font-size:2rem;font-weight:800;margin-bottom:10px}.poster-location{font-size:1.2rem;color:#4b5563;margin-bottom:30px}.poster-qr-frame{border:4px solid #000;padding:20px;display:inline-block;margin-bottom:20px;position:relative}.poster-scan-me{position:absolute;bottom:-15px;left:50%;transform:translate(-50%);background:#000;color:#fff;padding:5px 20px;font-weight:700;text-transform:uppercase;font-size:1.2rem}.poster-arrow{font-size:3rem;margin-bottom:10px;animation:bounce 2s infinite}.poster-cta{font-size:1.5rem;font-weight:700;margin-bottom:40px}.poster-steps-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;width:100%}.poster-step-card{border:2px solid #000;padding:15px;text-align:center}.step-icon{display:block;font-size:2.5rem;font-weight:900;margin-bottom:10px;color:#dc2626}.poster-footer{border-top:4px solid #000;padding-top:20px;margin-top:20px;display:flex;justify-content:space-between;align-items:center}.poster-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.2rem}.poster-logo-img{width:32px;height:32px;filter:grayscale(100%)}.poster-meta{font-size:.9rem;color:#6b7280}@media print{@page{size:A4;margin:0}body{background:#fff}.poster-page-wrapper{background:#fff;padding:0;display:block}.poster-container{width:100%;min-height:100vh;box-shadow:none;padding:5mm}.no-print,.poster-controls,header.header,footer.footer{display:none!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.add-building-page{min-height:100vh;background:var(--color-bg)}.add-building-page .page-header{background:linear-gradient(135deg,var(--color-charcoal) 0%,var(--color-charcoal-light) 100%);color:#fff;padding:var(--space-12) 0;margin-bottom:var(--space-8)}.add-building-page .page-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--space-2)}.add-building-page .page-header .subtitle{opacity:.8;margin:0}.add-building-page .back-link{color:#fffc;text-decoration:none;font-size:var(--font-size-sm);display:inline-block;margin-bottom:var(--space-4);transition:color .2s}.add-building-page .back-link:hover{color:#fff}.add-building-form-container{max-width:700px;margin:0 auto;padding-bottom:var(--space-16)}.add-building-form{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.form-section h2{font-size:var(--font-size-lg);margin-bottom:var(--space-4);color:var(--color-charcoal)}.form-section .section-hint{font-size:var(--font-size-sm);color:var(--color-gray);margin-top:calc(-1 * var(--space-2));margin-bottom:var(--space-4)}.form-section{padding:var(--space-6);border-bottom:1px solid var(--color-border)}.form-section:last-of-type{border-bottom:none}.form-section h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-charcoal);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.section-hint{font-size:var(--font-size-sm);color:var(--color-gray);margin-top:calc(var(--space-2) * -1);margin-bottom:var(--space-4)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;font-weight:600;margin-bottom:var(--space-2);color:var(--color-charcoal);font-size:var(--font-size-sm)}.form-group label .required{color:var(--color-danger)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-base);transition:border-color .2s,box-shadow .2s;background:var(--color-bg)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #b91c1c1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-gray-light)}.form-group:last-child{margin-bottom:0}.form-hint{display:block;font-size:12px;color:var(--color-gray);margin-top:var(--space-2)}.form-hint a{color:var(--color-primary);text-decoration:underline}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.location-help{margin-top:var(--space-4)}.location-help details{background:var(--color-bg-alt);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4)}.location-help summary{cursor:pointer;font-weight:600;color:var(--color-primary);font-size:var(--font-size-sm)}.location-help ol{margin:var(--space-3) 0 0 var(--space-4);font-size:var(--font-size-sm);color:var(--color-gray)}.location-help ol li{margin-bottom:var(--space-1)}.location-help a{color:var(--color-primary)}.form-actions{padding:var(--space-6);background:var(--color-bg-alt);text-align:center}.form-actions .btn{min-width:200px}.submit-note{font-size:var(--font-size-sm);color:var(--color-gray);margin-top:var(--space-3);margin-bottom:0}.success-message{text-align:center;padding:var(--space-12) var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.success-icon{font-size:4rem;margin-bottom:var(--space-4)}.success-message h2{color:var(--color-success);margin-bottom:var(--space-2)}.success-message p{color:var(--color-gray);margin-bottom:var(--space-2)}.success-actions{display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-6);flex-wrap:wrap}.error-message{display:flex;align-items:center;gap:var(--space-3);background:#b91c1c1a;color:var(--color-danger);padding:var(--space-4);border-radius:var(--radius-lg);margin-top:var(--space-4)}.error-icon{font-size:1.5rem}.error-text{font-weight:500}.panic-emergency-banner{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 20px 10px #dc262633}}.panic-emergency-inner{display:flex;align-items:center;gap:var(--space-4)}.panic-emergency-icon{font-size:3rem}.panic-emergency-label{font-size:var(--font-size-lg);font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.9}.panic-emergency-number{font-size:2.5rem;font-weight:900;color:#fff;text-decoration:none;display:block;line-height:1}.panic-emergency-number:hover{text-decoration:underline}.panic-emergency-sub{font-size:var(--font-size-sm);opacity:.8;margin-top:4px}.panic-building-header{text-align:center;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid var(--color-border)}.panic-building-name{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-charcoal);margin-bottom:var(--space-2)}.panic-building-address{font-size:var(--font-size-base);color:var(--color-gray);margin:0}.panic-section{margin-bottom:var(--space-8)}.panic-section-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-xl);font-weight:800;color:var(--color-charcoal);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.03em}.panic-icon{font-size:1.5rem}.panic-subsection-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-charcoal);margin-bottom:var(--space-3)}.panic-exits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:600px){.panic-exits-grid{grid-template-columns:1fr}}.panic-exit-card{display:flex;align-items:center;gap:var(--space-4);background:#fff;border:3px solid var(--color-charcoal);border-radius:var(--radius-xl);padding:var(--space-5);transition:transform .2s,box-shadow .2s}.panic-exit-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.panic-exit-number{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-charcoal);color:#fff;font-size:1.5rem;font-weight:900;border-radius:50%;flex-shrink:0}.panic-exit-info{flex:1}.panic-exit-name{font-size:var(--font-size-lg);font-weight:700;color:var(--color-charcoal);margin-bottom:4px}.panic-exit-direction{font-size:var(--font-size-base);color:var(--color-gray);font-weight:500}.panic-assembly-section{background:#0596691a;border:3px solid var(--color-success);border-radius:var(--radius-xl);padding:var(--space-6)}.panic-assembly-section .panic-section-title{color:var(--color-success-dark)}.panic-assembly-box{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4)}.panic-assembly-text{font-size:var(--font-size-lg);font-weight:600;color:var(--color-charcoal);margin:0}.panic-tips{background:#00000008;border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-6)}.panic-tips summary{font-weight:700;color:var(--color-charcoal);cursor:pointer;font-size:var(--font-size-base)}.panic-tips ul{margin:var(--space-4) 0 0 0;padding-left:var(--space-4)}.panic-tips li{font-size:var(--font-size-base);color:var(--color-gray);margin-bottom:var(--space-2)}.panic-loading{background:#0000000d;padding:var(--space-4);border-radius:var(--radius-lg);text-align:center;color:var(--color-gray)}.panic-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--color-border);margin-top:var(--space-8)}.panic-score-mini{font-size:var(--font-size-sm);color:var(--color-gray)}.panic-score-mini strong{color:var(--color-charcoal);font-size:var(--font-size-lg)}.update-safety-page{min-height:100vh;background:var(--color-bg)}.update-safety-page .page-header{background:linear-gradient(135deg,#059669,#047857);color:#fff;padding:var(--space-12) 0;margin-bottom:var(--space-8)}.update-safety-page .page-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--space-2)}.update-safety-page .page-header .subtitle{opacity:.9;margin:0}.update-safety-page .back-link{color:#fffc;text-decoration:none;font-size:var(--font-size-sm);display:inline-block;margin-bottom:var(--space-4);transition:color .2s}.update-safety-page .back-link:hover{color:#fff}.safety-form-container{max-width:800px;margin:0 auto;padding-bottom:var(--space-16)}.safety-info-banner{display:flex;align-items:flex-start;gap:var(--space-4);background:#0596691a;border:2px solid var(--color-success);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-6)}.safety-info-banner .info-icon{font-size:1.5rem}.safety-info-banner strong{color:var(--color-success-dark);display:block;margin-bottom:var(--space-1)}.safety-info-banner p{margin:0;font-size:var(--font-size-sm);color:var(--color-gray)}.safety-form{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.safety-form .form-section{padding:24px;border-bottom:1px solid var(--color-border)}.safety-form .form-section:last-of-type{border-bottom:none}.safety-form .form-section h2{font-size:1.125rem;font-weight:700;color:var(--color-charcoal);margin:0 0 16px}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}.checkbox-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .2s,background-color .2s}.checkbox-card:hover{border-color:var(--color-primary)}.checkbox-card input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-success)}.checkbox-card input[type=checkbox]:checked+.checkbox-label{color:var(--color-success-dark)}.checkbox-card:has(input:checked){background:#0596691a;border-color:var(--color-success)}.checkbox-label{display:flex;align-items:center;gap:var(--space-2);font-weight:500;color:var(--color-charcoal);font-size:var(--font-size-sm)}.checkbox-icon{font-size:1.25rem}.checkbox-inline{display:flex;align-items:center;gap:var(--space-2);font-weight:500;cursor:pointer}.checkbox-inline input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-success)}
