:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-300: #93c5fd;--blue-400: #60a5fa;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-800: #1e40af;--blue-900: #1e3a8a;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-600: #4b5563;--gray-800: #1f2937;--amber-50: #fffbeb;--amber-100: #fef3c7;--amber-500: #f59e0b;--emerald-500: #10b981;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(37, 99, 235, .12);--shadow-xl: 0 10px 40px rgba(37, 99, 235, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition-fast: .2s ease;--transition-normal: .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes glow{0%,to{box-shadow:0 0 20px #2563eb4d}50%{box-shadow:0 0 40px #2563eb80}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes float3d{0%,to{transform:translateY(0) rotateX(0)}50%{transform:translateY(-6px) rotateX(2deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease-out forwards}.animate-slide-up{animation:slideUp .4s ease-out forwards}.animate-slide-in-right{animation:slideInRight .35s ease-out forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-shake{animation:shake .4s ease-in-out}.animate-float:hover{animation:float 2s ease-in-out infinite}.animate-glow{animation:glow 3s ease-in-out infinite}.animate-scale-in{animation:scaleIn .4s ease-out forwards}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}*{box-sizing:border-box}html{font-family:Heebo,Segoe UI,Tahoma,sans-serif;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{margin:0;min-height:100vh;background:linear-gradient(160deg,var(--white) 0%,var(--blue-50) 20%,var(--blue-100) 60%,var(--blue-50) 100%);background-attachment:fixed;background-size:400% 400%;animation:gradientShift 30s ease infinite;color:var(--gray-800);line-height:1.5}#root{min-height:100vh}input,select,textarea{font-family:inherit;font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:44px;touch-action:manipulation}input[type=date],input[type=time],input[type=number],input[type=text],input[type=password],select{padding:.6rem .85rem}button{font-family:inherit;font-size:1rem;min-height:44px}label{font-size:.95rem;font-weight:500;margin-bottom:.25rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 3px #3b82f633}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible,a:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f666}button{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}button:hover{transform:translateY(-1px)}button:active{transform:translateY(0)}a{color:var(--blue-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--blue-700)}.card-3d{transform-style:preserve-3d;transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s ease}.card-3d:hover{transform:perspective(1000px) translateY(-8px) rotateX(3deg) rotateY(-3deg);box-shadow:0 20px 40px #2563eb33,0 0 0 1px #ffffff80 inset}.card-hover{transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s ease}.card-hover:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 12px 24px #2563eb33,0 0 0 1px #fffc}.nav-link-transition{transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.permits-alert:hover{background:linear-gradient(90deg,#fde68a,#fcd34d)!important;transform:scale(1.01)}.logout-btn:hover{background:var(--blue-700)!important;box-shadow:0 4px 12px #2563eb66}.btn-interactive{position:relative;overflow:hidden;transition:transform .15s ease,box-shadow .2s ease}.btn-interactive:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.btn-interactive:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #2563eb33}.mockup-frame{position:relative;padding:24px;background:linear-gradient(145deg,#1e293b,#0f172a);border-radius:24px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a,inset 0 1px #ffffff1a}.mockup-frame:before{content:"";position:absolute;top:12px;left:50%;transform:translate(-50%);width:60px;height:6px;background:#334155;border-radius:3px}.mockup-content{background:#fff;border-radius:12px;overflow:hidden;box-shadow:inset 0 0 0 1px #0000000d}.interactive-border{position:relative}.interactive-border:after{content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;background:linear-gradient(135deg,var(--blue-400),var(--blue-600));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease}.interactive-border:hover:after{opacity:1;animation:glow 2s ease-in-out infinite}.stat-interactive{transition:transform .2s ease,box-shadow .2s ease}.stat-interactive:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 16px #2563eb26}.page-hero{margin:0 0 1.5rem;font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--blue-800) 0%,var(--blue-600) 50%,var(--blue-800) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding-bottom:.5rem;border-bottom:3px solid var(--blue-200)}.card-accent-warning{border-color:var(--amber-500)!important;background:linear-gradient(135deg,rgba(255,255,255,.98) 0%,var(--amber-50) 100%)!important;box-shadow:0 4px 16px #f59e0b26!important}.card-accent-warning h2{color:#b45309!important;border-bottom-color:var(--amber-100)!important}.nav-link-active-accent{position:relative}.nav-link-active-accent:after{content:"";position:absolute;top:50%;right:0;transform:translateY(-50%);width:4px;height:70%;background:linear-gradient(180deg,var(--blue-500),var(--blue-700));border-radius:2px;animation:fadeIn .25s ease}.tile-arrow{position:absolute;right:1rem;top:50%;opacity:0;transform:translateY(-50%) translate(8px);transition:opacity .25s ease,transform .25s ease}a:hover .tile-arrow,a:focus-visible .tile-arrow{opacity:1;transform:translateY(-50%) translate(0)}.missing-link-card:hover{background:var(--blue-50)!important;border-color:var(--blue-200)!important;transform:translate(-2px)}.missing-link-card:focus-visible{box-shadow:0 0 0 3px #3b82f666}.login-page{position:relative;overflow:hidden;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill='%23d1d5db' fill-opacity='0.4'%3E%3Cpath d='M10 70 L25 45 L40 70 Z'/%3E%3Cpath d='M50 70 L65 45 L80 70 Z'/%3E%3Cpath d='M30 45 L45 20 L60 45 Z'/%3E%3Cpath d='M60 25 L75 0 L90 25 Z'/%3E%3Cpath d='M0 45 L15 20 L30 45 Z'/%3E%3C/g%3E%3C/svg%3E");background-size:100px 100px}.login-card{position:relative;z-index:2}.login-stagger{opacity:0;animation:loginStaggerIn .5s ease-out forwards}.login-stagger-1{animation-delay:.1s}.login-stagger-2{animation-delay:.2s}.login-stagger-3{animation-delay:.3s}.login-stagger-4{animation-delay:.4s}.login-stagger-5{animation-delay:.5s}.login-stagger-6{animation-delay:.6s}@keyframes loginStaggerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:992px){.nav-hamburger{display:flex!important}.app-nav.nav-drawer{position:absolute;top:100%;inset-inline:1.25rem;margin-top:.4rem;display:flex;flex-direction:column;align-items:stretch;background:#fffffffa;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 12px 30px #0f172a2e;border-radius:var(--radius-md);padding:.6rem .5rem .75rem;gap:.25rem;transform-origin:top;transform:scaleY(.9);opacity:0;pointer-events:none;transition:transform .2s ease-out,opacity .2s ease-out;z-index:1000}.app-nav.nav-drawer-open{transform:scaleY(1);opacity:1;pointer-events:auto}.app-nav.nav-drawer .nav-link{padding:.85rem 1rem!important;border-radius:var(--radius-sm);font-size:1rem}.app-nav.nav-drawer .nav-link:hover{background:var(--blue-50)}}@media(max-width:768px){.app-header{padding:.5rem 1rem!important}.app-logo-img{height:36px!important}.app-main{padding:.9rem 1rem!important}.mockup-frame{padding:12px!important}.mockup-content{padding:1rem!important}}@media(max-width:480px){.app-header{padding:.5rem .75rem!important}.app-logo-img{height:32px!important}.app-main{padding:.75rem!important}body{font-size:15px}.page-hero{font-size:1.4rem}}@media(max-width:600px){.mockup-frame{border-radius:16px!important;padding:16px!important}}@media(max-width:420px){.app-header .user-name-span{display:none}}html,body{overflow-x:hidden}@media(max-width:768px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}}
