.projects-page .page-card{animation:scaleIn .28s ease-out both}.projects-page .page-card:nth-of-type(2){animation-delay:.04s}.projects-page .page-card:nth-of-type(3){animation-delay:.08s}.projects-card{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.projects-card:hover{transform:translateY(-3px);border-color:var(--blue-300)!important;box-shadow:0 10px 24px #2563eb24}.projects-card-closed{transition:transform .2s ease,box-shadow .2s ease}.projects-card-closed:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0f172a1a}.projects-cta-btn{box-shadow:0 6px 16px #2563eb40}.projects-save-btn{box-shadow:0 8px 20px #2563eb40}.projects-alert{animation-duration:3s}.projects-thumb-btn{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.projects-thumb-btn:hover{transform:translateY(-2px) scale(1.04);border-color:var(--blue-300)!important;box-shadow:0 6px 14px #2563eb38}.projects-toast{box-shadow:0 10px 30px #10b98133}.projects-quick-toolbar{position:sticky;top:74px;z-index:5;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:.35rem;border:1px solid rgba(191,219,254,.65);border-radius:12px}.projects-meta-chips{max-width:100%}.permit-meta-chip{display:inline-flex;align-items:baseline;gap:.35rem;flex-wrap:wrap;padding:.28rem .55rem;background:#ffffffeb;border:1px solid var(--gray-200);border-radius:999px;font-size:.82rem;color:var(--gray-800);line-height:1.3}.permit-meta-chip-label{font-size:.72rem;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.03em}.permit-meta-chip-wide{border-radius:var(--radius-sm);max-width:100%}.projects-finance-row .permit-finance-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;background:var(--white);border:1px solid var(--blue-200);border-radius:999px;font-size:.8rem;color:var(--gray-700)}.projects-finance-row .permit-finance-pill strong{color:var(--blue-800);font-weight:700}.projects-finance-row .permit-finance-profit{background:var(--blue-50);border-color:var(--blue-300)}.projects-card-compact .projects-active-card-body{padding:.65rem .8rem;gap:.45rem}.projects-card-compact .projects-card-actions{padding:.55rem .8rem}.projects-card-actions{row-gap:.45rem}.projects-page input[type=file]{width:100%;padding:.45rem .55rem!important;border:1px dashed var(--blue-300)!important;border-radius:10px!important;background:linear-gradient(180deg,#fff,#f8fbff);color:var(--gray-700);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.projects-page input[type=file]:hover{border-color:var(--blue-500)!important;background:#f2f8ff}.projects-page input[type=file]:focus-visible{outline:none;border-color:var(--blue-500)!important;box-shadow:0 0 0 3px #3b82f633}.projects-page input[type=file]::file-selector-button{margin-inline-end:.6rem;padding:.45rem .8rem;border:1px solid var(--blue-300);border-radius:8px;background:linear-gradient(135deg,var(--blue-50),var(--blue-100));color:var(--blue-800);font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}.projects-page input[type=file]::file-selector-button:hover{border-color:var(--blue-500);box-shadow:0 4px 10px #2563eb29}.projects-page input[type=file]::file-selector-button:active{transform:scale(.97)}@media(max-width:640px){.projects-card-actions{justify-content:stretch}.projects-card-actions .btn-interactive{flex:1 1 auto;min-width:0;text-align:center}}.pricing-page{--primary-blue: #003366;--secondary-blue: #007bff;--hover-blue: #e6f0ff;--dark-hover: #d1e3ff;--eco-green: #27ae60;--light-bg: #f8f9fa;--border-color: #cbd5e0;--white: #ffffff;--shadow: 0 10px 25px rgba(0, 0, 0, .08);font-family:Assistant,sans-serif;color:#2c3e50}.calculator-container{max-width:1000px;margin:20px auto 40px;background:var(--white);border-radius:30px;box-shadow:var(--shadow);padding:40px;border:1px solid var(--border-color);animation:slideUp .8s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.calculator-header h2{color:var(--primary-blue);font-weight:800;text-align:center;font-size:2.2rem;margin-bottom:5px}.calculator-header p{text-align:center;color:var(--secondary-blue);margin-bottom:40px;font-weight:600}.calculators-row{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}.calculator-panel{width:100%}.two-column{display:grid;grid-template-columns:1fr 1fr;gap:25px}.calculator-card{background:var(--white);border:2px solid #edf2f7;border-radius:20px;padding:22px;margin-bottom:20px;transition:all .3s ease}.calculator-card:hover{border-color:var(--secondary-blue);transform:translateY(-3px)}.section-label{display:block;font-weight:800;color:var(--primary-blue);margin-bottom:15px;border-right:5px solid var(--secondary-blue);padding-right:10px}.button-group{display:flex;gap:10px;flex-wrap:wrap}.calc-btn{flex:1;padding:12px 15px;border:2px solid var(--border-color);background:#fff;border-radius:12px;cursor:pointer;font-weight:700;color:var(--primary-blue);transition:all .2s ease}.calc-btn:hover{border-color:var(--primary-blue);background-color:var(--dark-hover)}.calc-btn.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.calc-btn.multi.active{background:var(--eco-green);color:#fff;border-color:var(--eco-green)}.area-shortcut-group{display:flex;gap:8px;justify-content:center;margin-top:15px}.area-btn{padding:8px 18px;border:2px solid var(--secondary-blue);background:#fff;color:var(--secondary-blue);border-radius:50px;cursor:pointer;font-weight:800;transition:.2s}.area-btn:hover{background:var(--hover-blue)}.area-btn.active{background:var(--secondary-blue);color:#fff}.calculator-range{width:100%;margin:20px 0;accent-color:var(--secondary-blue)}.area-display{text-align:center;font-size:2.2rem;font-weight:800;color:var(--secondary-blue)}.calculator-result{margin-top:40px;background:linear-gradient(135deg,#001f3f,#036);border-radius:25px;padding:40px;color:#fff;text-align:center;box-shadow:0 15px 35px #0033664d}.result-value{font-size:3.5rem;font-weight:800;color:#58d68d;margin:15px 0}.vat-info{font-size:.9rem;opacity:.85;line-height:1.6}.blog-wrapper{line-height:1.8;max-width:900px;margin:0 auto 40px}.blog-wrapper h1{color:#036;font-size:2.8rem;font-weight:800;text-align:center;margin-bottom:30px;border-bottom:4px solid #007bff;padding-bottom:15px}.blog-wrapper h2{color:#036;font-size:1.8rem;margin-top:40px;background:#f0f7ff;padding:10px 20px;border-right:6px solid #007bff;border-radius:4px}.blog-wrapper h3{color:#007bff;font-size:1.4rem;margin-top:25px}.info-box{background:#fff;border:1px solid #e1e8ed;border-radius:15px;padding:25px;margin:25px 0;box-shadow:0 4px 15px #0000000d}.highlight-card{background:linear-gradient(135deg,#036,#0056b3);color:#fff;padding:30px;border-radius:20px;text-align:center;margin:30px 0}.all-in-pill{background:#27ae60;padding:5px 15px;border-radius:20px}.custom-list{list-style:none;padding-right:0}.custom-list li{position:relative;padding-right:30px;margin-bottom:15px}.custom-list li:before{content:"✓";position:absolute;right:0;color:#27ae60;font-weight:700;font-size:1.2rem}.warning-box{background:#fff9e6;border-right:6px solid #f1c40f;padding:20px;border-radius:8px;margin:20px 0}.ops-calculator{background:#fff;border:1px solid #e1e8ed;border-radius:15px;padding:20px;margin:20px 0;box-shadow:0 4px 15px #0000000d}.ops-title{color:#036;margin:0 0 12px}.ops-note{margin:0 0 12px}.ops-grid{border-top:1px dashed #cbd5e0;margin-top:12px;padding-top:12px}.ops-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #edf2f7}.ops-label{display:inline-flex;align-items:center;gap:6px}.info-tooltip{position:relative;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#036;border:1px solid #9bb4d1;background:#eef5ff;cursor:help}.info-tooltip:after{content:attr(data-tooltip);position:absolute;right:50%;bottom:calc(100% + 10px);transform:translate(50%);width:260px;max-width:70vw;background:#0f2742;color:#fff;border-radius:10px;padding:8px 10px;font-size:.78rem;line-height:1.4;text-align:right;box-shadow:0 8px 20px #0003;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:20}.info-tooltip:before{content:"";position:absolute;right:50%;bottom:calc(100% + 4px);transform:translate(50%);border-width:6px;border-style:solid;border-color:#0f2742 transparent transparent transparent;opacity:0;visibility:hidden;transition:opacity .18s ease;z-index:20}.info-tooltip:hover:after,.info-tooltip:hover:before{opacity:1;visibility:visible}.info-tooltip:hover:after{transform:translate(50%) translateY(-2px)}.ops-row.total{color:#036;font-size:1.1rem}.cta-box{text-align:center;margin-top:50px;padding:40px;background:#f4f7fa;border-radius:20px}.cta-link{display:inline-block;padding:15px 40px;background:#007bff;color:#fff;text-decoration:none;border-radius:30px;font-weight:800;font-size:1.2rem}@media(max-width:768px){.calculators-row,.two-column{grid-template-columns:1fr}.calculator-container{padding:22px;border-radius:18px}.result-value{font-size:2.4rem}.blog-wrapper h1{font-size:2rem}}: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}}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(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;touch-action:manipulation}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{background:#ffffffa6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(147,197,253,.35);transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform .16s ease;will-change:transform}.nav-link-transition:hover{transform:translate(-3px) scale(1.01);box-shadow:0 6px 16px #2563eb1f}.nav-link-transition:active{transform:translate(0) scale(.98)}.nav-group-trigger{transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform .16s ease,box-shadow .2s ease}.nav-group-trigger:active{transform:scale(.985)}.nav-close-btn{transition:transform .16s ease,box-shadow .2s ease,background-color .2s ease}.nav-close-btn:hover{background:var(--blue-50);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb26}.nav-close-btn:active{transform:translateY(0) scale(.98);box-shadow:0 2px 6px #2563eb1a}.nav-group-trigger:hover{background:var(--blue-50)!important;border-color:var(--blue-300)!important}.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;touch-action:manipulation}.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)}}.login-remember-label:hover .login-checkbox-off{border-color:var(--blue-300);background:var(--blue-50)}.login-remember-label:active{opacity:.9}@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;gap:.5rem;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)}.app-nav.nav-drawer .nav-group-trigger{width:100%}.app-nav.nav-drawer .nav-group{position:static!important}.app-nav.nav-drawer .nav-group-menu{position:static!important;left:auto!important;right:auto!important;top:auto!important;transform:none!important;visibility:visible!important;pointer-events:auto!important;opacity:1!important;z-index:auto!important;padding:.2rem 0 .1rem!important}.app-nav.nav-drawer .nav-close-btn{width:100%;margin-bottom:.2rem}.app-nav.nav-drawer .nav-group-menu{display:none!important}.app-nav.nav-drawer .nav-group-trigger[aria-expanded=true]+.nav-group-menu{display:flex!important}}@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}}
