body{font-family:Avenir,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;scroll-behavior:smooth}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf1 100%);padding:20px;perspective:1000px}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:float 20s ease-in-out infinite;transform-style:preserve-3d}.orb-1{width:400px;height:400px;background:linear-gradient(135deg,var(--picton-blue),var(--celestial-blue));top:-200px;left:-200px;animation-delay:0s;transform:translateZ(0)}.orb-2{width:350px;height:350px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));bottom:-150px;right:-150px;animation-delay:5s;transform:translateZ(0)}.orb-3{width:300px;height:300px;background:linear-gradient(135deg,var(--tangerine),#ff9d4d);top:50%;right:10%;animation-delay:10s;transform:translateZ(0)}@keyframes float{0%,to{transform:translate(0) scale(1) translateZ(0)}33%{transform:translate(30px,-30px) scale(1.1) translateZ(20px)}66%{transform:translate(-20px,20px) scale(.9) translateZ(-20px)}}.floating-shapes{position:absolute;width:100%;height:100%;overflow:hidden}.shape{position:absolute;border-radius:50%;background:rgba(86,172,218,.1);animation:floatShape 15s ease-in-out infinite}.shape-1{width:100px;height:100px;top:20%;left:10%;animation-delay:0s;transform:translateZ(50px)}.shape-2{width:150px;height:150px;top:60%;right:15%;animation-delay:5s;transform:translateZ(30px)}.shape-3{width:80px;height:80px;bottom:20%;left:20%;animation-delay:10s;transform:translateZ(40px)}@keyframes floatShape{0%,to{transform:translate(0) rotate(0) translateZ(0);opacity:.3}50%{transform:translate(50px,-50px) rotate(180deg) translateZ(50px);opacity:.6}}.login-content{position:relative;z-index:1;width:100%;max-width:550px;animation:slideUp .8s ease-out;transform-style:preserve-3d}@keyframes slideUp{0%{opacity:0;transform:translateY(50px) translateZ(-100px)}to{opacity:1;transform:translateY(0) translateZ(0)}}.login-card{background:var(--white)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-radius:28px;padding:64px 56px;box-shadow:0 24px 64px #0000001f,0 0 0 1px #1995d21a,inset 0 1px #fffc;border:2px solid rgba(25,149,210,.15);transform-style:preserve-3d;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;min-width:500px;max-width:550px;width:100%;animation:fadeInScale .6s ease-out}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--picton-blue),var(--celestial-blue),var(--picton-blue));background-size:200% 100%;animation:shimmer 3s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.login-card *{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;filter:none!important}.login-header{text-align:center;margin-bottom:48px}.login-logo{width:64px;height:64px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.login-logo svg{width:100%;height:100%}.platform-name{font-size:36px;font-weight:800;color:var(--davys-grey);margin-bottom:8px;letter-spacing:2px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.platform-full-name{font-size:18px;font-weight:600;color:var(--davys-grey);margin-bottom:24px;letter-spacing:.5px;text-transform:uppercase}.login-title{font-size:32px;font-weight:700;color:var(--davys-grey);margin-bottom:12px;letter-spacing:-.5px;transform:translateZ(10px)}.login-subtitle{color:var(--davys-grey);font-size:14px;font-weight:500;margin:0;letter-spacing:.5px;text-transform:uppercase;opacity:.8}.login-form{margin-bottom:24px}.error-message{display:flex;align-items:center;gap:12px;padding:16px 20px;background:rgba(240,135,33,.1);border:2px solid rgba(240,135,33,.3);border-radius:14px;color:var(--tangerine);font-size:16px;font-weight:500;margin-bottom:24px;animation:shake .5s ease-in-out;-webkit-backdrop-filter:none;backdrop-filter:none}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-message svg{flex-shrink:0}.form-group{margin-bottom:28px}.form-group label{display:block;margin-bottom:14px;color:var(--davys-grey);font-size:17px;font-weight:700;letter-spacing:.3px}.input-wrapper{position:relative;display:flex;align-items:center}.input-field{width:100%;padding:20px 22px;border:2.5px solid var(--celestial-blue);border-radius:14px;font-size:18px;color:var(--davys-grey);background:var(--white);transition:all .4s cubic-bezier(.4,0,.2,1);outline:none;font-family:inherit;transform:translateZ(0);font-weight:500;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.input-field:focus{border-color:var(--picton-blue);background:var(--white);box-shadow:0 0 0 5px #1995d226,0 6px 20px #1995d240;border-width:3px;-webkit-backdrop-filter:none;backdrop-filter:none}.input-field::placeholder{color:var(--davys-grey);opacity:.6;font-weight:400;font-size:17px}.password-wrapper{position:relative}.password-field{padding-right:56px}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:10px;display:flex;align-items:center;justify-content:center;color:var(--davys-grey);opacity:.7;transition:all .4s cubic-bezier(.4,0,.2,1);border-radius:8px;-webkit-backdrop-filter:none;backdrop-filter:none}.password-toggle:active{transform:translateY(-50%) scale(.95)}.authorize-button{width:100%;padding:20px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);border:none;border-radius:14px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #1995d259;position:relative;overflow:hidden;transform-style:preserve-3d;transform:translateZ(0);font-family:inherit;margin-top:16px;letter-spacing:.3px;-webkit-backdrop-filter:none;backdrop-filter:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.authorize-button:active{transform:translateY(0) translateZ(5px)}.authorize-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.shield-icon{transition:transform .3s ease}.spinner{animation:spin 1s linear infinite}.login-footer{text-align:center;padding-top:28px;border-top:2px solid rgba(77,77,77,.1);margin-top:8px}.login-footer p{color:var(--davys-grey);font-size:15px;font-weight:500;opacity:1;-webkit-backdrop-filter:none;backdrop-filter:none}@media (max-width: 480px){.login-card{padding:32px 24px;border-radius:20px}.login-title{font-size:28px}.login-subtitle{font-size:13px}}@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateZ(-50px)}to{opacity:1;transform:scale(1) translateZ(0)}}.home-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf1 100%)}.home-header{background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));padding:24px 40px;box-shadow:0 4px 20px #0000001a}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.home-header h1{color:var(--white);font-size:28px;font-weight:700;margin:0}.user-section{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:16px;color:var(--white)}.logout-button{padding:8px 16px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:8px;color:var(--white);cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.logout-button:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}.home-content{max-width:1200px;margin:40px auto;padding:0 40px}.error-banner{background:rgba(240,135,33,.1);border:1px solid var(--tangerine);border-radius:12px;padding:16px;color:var(--tangerine);margin-bottom:24px}.health-card{background:var(--white);border-radius:16px;padding:32px;box-shadow:0 4px 20px #0000001a}.health-card h2{color:var(--davys-grey);margin-bottom:16px}.health-card p{color:var(--davys-grey);margin-bottom:8px}.home-actions{margin-bottom:24px}.nav-button{padding:14px 24px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #1995d24d}.nav-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1995d266}.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;height:100vh;max-height:100vh;background:var(--white);box-shadow:2px 0 8px #0000001a;display:flex;flex-direction:column;z-index:1000;transition:width .3s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(0,0,0,.08);overflow:hidden;margin:0;padding:0}.sidebar.collapsed{width:64px}.sidebar-header{padding:16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,.08);min-height:64px}.sidebar-logo{display:flex;align-items:center;gap:12px}.logo-icon-sidebar{width:32px;height:32px;flex-shrink:0}.sidebar-title{font-size:18px;font-weight:700;color:var(--davys-grey);letter-spacing:.5px}.sidebar-toggle{background:transparent;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--davys-grey);transition:all .2s ease;flex-shrink:0}.sidebar-toggle:hover{background:rgba(0,0,0,.05)}.sidebar-toggle:active{background:rgba(0,0,0,.1)}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto;overflow-x:hidden;min-height:0}.nav-item{width:100%;padding:10px 16px;display:flex;align-items:center;gap:16px;background:none;border:none;color:var(--davys-grey);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;position:relative;border-radius:0 24px 24px 0;margin-right:8px}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--celestial-blue);border-radius:0 3px 3px 0;transition:height .2s ease}.nav-item:hover{background:rgba(25,149,210,.08)}.nav-item.active{background:rgba(25,149,210,.12);color:var(--celestial-blue);font-weight:600}.nav-item.active:before{height:24px}.nav-icon{width:20px;height:20px;flex-shrink:0;color:var(--davys-grey);transition:color .2s ease}.nav-item.active .nav-icon{color:var(--celestial-blue)}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:16px 16px 0;border-top:1px solid rgba(0,0,0,.08);margin-top:auto;margin-bottom:0;display:flex;align-items:center;flex-shrink:0;position:relative}.logout-button{width:100%;padding:10px 16px;margin-bottom:0;display:flex;align-items:center;gap:16px;background:rgba(240,135,33,.1);border:1px solid rgba(240,135,33,.2);border-bottom:none;border-radius:8px 8px 0 0;color:var(--tangerine);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:rgba(240,135,33,.15);border-color:#f087214d}.logout-button:active{background:rgba(240,135,33,.2)}.logout-button svg{flex-shrink:0;width:20px;height:20px}.sidebar.collapsed .sidebar-title,.sidebar.collapsed .nav-label,.sidebar.collapsed .logout-button span{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px;border-radius:50%;width:48px;height:48px;margin:4px auto}.sidebar.collapsed .logout-button{justify-content:center;padding:10px;width:48px;height:48px;border-radius:50%;margin:0 auto}.sidebar.collapsed .sidebar-header{justify-content:center;padding:16px 8px}.sidebar.collapsed .sidebar-logo{display:none}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}.logout-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.logout-modal-content{background:var(--white);border-radius:16px;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.logout-modal-header{padding:32px;text-align:center;border-bottom:1px solid rgba(0,0,0,.08)}.logout-modal-header svg{margin-bottom:16px}.logout-modal-header h3{color:var(--davys-grey);font-size:20px;font-weight:700;margin:0 0 8px}.logout-modal-header p{color:var(--davys-grey);font-size:14px;margin:0;opacity:.8}.logout-modal-actions{padding:20px 32px 32px;display:flex;gap:12px;justify-content:flex-end}.logout-cancel-btn,.logout-confirm-btn{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.logout-cancel-btn{background:rgba(0,0,0,.05);color:var(--davys-grey)}.logout-cancel-btn:hover{background:rgba(0,0,0,.1)}.logout-confirm-btn{background:var(--tangerine);color:var(--white)}.logout-confirm-btn:hover{background:#e0771e;box-shadow:0 4px 12px #f087214d}.logout-confirm-btn:active{transform:scale(.98)}@media (max-width: 1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.app-footer{position:fixed;bottom:0;left:240px;right:0;background:var(--white);border-top:2px solid rgba(25,149,210,.1);padding:12px 24px;box-shadow:0 -4px 20px #00000014;z-index:99;transform-style:preserve-3d;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:50px;display:flex;align-items:center;animation:slideUp .6s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.footer-content{display:flex;justify-content:center;align-items:center;width:100%;max-width:100%}.footer-content p{margin:0;color:var(--davys-grey);font-size:12px;font-weight:500;text-align:center}body.sidebar-collapsed .app-footer{left:64px}@media (max-width: 1024px){.app-footer{left:0}}@media (max-width: 768px){.app-footer{padding:12px 20px}.footer-content{text-align:center}}.portfolio-card{background:var(--white);border-radius:16px;box-shadow:0 4px 20px #0000001a;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer;display:flex;flex-direction:column;height:100%;transform-style:preserve-3d;border:1px solid rgba(0,0,0,.05);animation:fadeInScale .5s ease-out backwards;position:relative}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateZ(0)}to{opacity:1;transform:scale(1) translateZ(0)}}.portfolio-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--celestial-blue),var(--picton-blue));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,0,.2,1)}.portfolio-card:hover:before{transform:scaleX(1)}.portfolio-card:hover{transform:translateY(-8px) translateZ(20px) rotateX(1deg);box-shadow:0 16px 48px #0003}.portfolio-card:active{transform:translateY(-4px) translateZ(10px);transition:all .2s ease}.portfolio-card-image{width:100%;height:180px;overflow:hidden;background:linear-gradient(135deg,var(--picton-blue),var(--celestial-blue))}.portfolio-card-image img{width:100%;height:100%;object-fit:cover}.portfolio-card-content{padding:24px;flex:1;display:flex;flex-direction:column}.portfolio-card-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(77,77,77,.1)}.portfolio-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.portfolio-header-actions{display:flex;align-items:center;gap:8px}.portfolio-name{color:var(--davys-grey);font-size:20px;font-weight:700;margin:0;line-height:1.3;flex:1}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.status-badge.active{background:rgba(16,185,129,.15);color:#10b981;border:1px solid rgba(16,185,129,.3)}.status-badge.inactive{background:rgba(239,68,68,.15);color:#ef4444;border:1px solid rgba(239,68,68,.3)}.edit-portfolio-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:rgba(25,149,210,.1);border:1px solid rgba(25,149,210,.3);border-radius:8px;color:var(--celestial-blue);cursor:pointer;transition:all .3s ease;flex-shrink:0}.edit-portfolio-btn:hover{background:rgba(25,149,210,.2);border-color:var(--celestial-blue);transform:translateY(-1px)}.edit-portfolio-btn:active{transform:translateY(0)}.edit-portfolio-btn svg{width:16px;height:16px}.portfolio-location{display:flex;align-items:center;gap:8px}.location-badge{display:inline-block;padding:4px 12px;background:rgba(25,149,210,.1);color:var(--celestial-blue);border-radius:20px;font-size:12px;font-weight:600}.portfolio-card-body{flex:1;display:flex;flex-direction:column;gap:12px}.portfolio-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.portfolio-label{color:var(--davys-grey);font-size:14px;font-weight:500}.portfolio-value{color:var(--davys-grey);font-size:14px;font-weight:600;text-align:right}.portfolio-value.disbursed{color:var(--tangerine)}.portfolio-value.remaining{color:var(--celestial-blue)}.portfolio-value.roi{color:#10b981;font-size:16px}.portfolio-card-footer{margin-top:20px;padding-top:16px;border-top:1px solid rgba(77,77,77,.1)}.portfolio-meta{display:flex;flex-direction:column;gap:4px}.created-by,.created-date{color:var(--davys-grey);font-size:13px}@media (max-width: 768px){.portfolio-card{max-width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease;perspective:1000px}.modal-content{background:var(--white);border-radius:20px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;transform-style:preserve-3d;position:relative}@keyframes slideUp{0%{transform:translateY(30px) translateZ(-100px) rotateX(10deg);opacity:0}to{transform:translateY(0) translateZ(0) rotateX(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid rgba(77,77,77,.1);background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));border-radius:20px 20px 0 0}.modal-header h2{color:var(--white);font-size:24px;font-weight:700;margin:0}.modal-close{background:rgba(255,255,255,.2);border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--white);transition:all .3s ease}.modal-close:hover{background:rgba(255,255,255,.3);transform:rotate(90deg)}.portfolio-form{padding:32px}.form-error{display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(240,135,33,.1);border:1px solid rgba(240,135,33,.3);border-radius:12px;color:var(--tangerine);font-size:14px;margin-bottom:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{color:var(--davys-grey);font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:2px solid rgba(25,149,210,.2);border-radius:10px;font-size:15px;color:var(--davys-grey);background:var(--white);transition:all .3s ease;outline:none;font-family:inherit;resize:vertical}.form-group textarea{min-height:100px;line-height:1.5}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--celestial-blue);box-shadow:0 0 0 4px #1995d21a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--tangerine)}.field-error{color:var(--tangerine);font-size:12px;margin-top:4px}.image-upload-container{margin-top:8px}.image-upload-label{display:block;cursor:pointer}.image-upload-input{display:none}.image-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;border:2px dashed rgba(25,149,210,.3);border-radius:12px;background:rgba(25,149,210,.05);transition:all .3s ease;color:var(--celestial-blue)}.image-upload-placeholder:hover{border-color:var(--celestial-blue);background:rgba(25,149,210,.1)}.image-upload-placeholder svg{color:var(--celestial-blue)}.image-upload-placeholder span{font-size:14px;font-weight:500;color:var(--davys-grey)}.upload-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-preview-wrapper{position:relative;display:inline-block;width:100%;max-width:300px}.image-preview{width:100%;height:auto;max-height:200px;object-fit:cover;border-radius:12px;border:2px solid rgba(25,149,210,.2)}.remove-image-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:rgba(240,135,33,.9);border:none;color:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0003}.remove-image-btn:hover{background:var(--tangerine);transform:scale(1.1)}.remove-image-btn:disabled{opacity:.6;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(77,77,77,.1)}.btn-cancel{padding:12px 24px;background:rgba(77,77,77,.1);border:2px solid rgba(77,77,77,.2);border-radius:10px;color:var(--davys-grey);font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel:hover{background:rgba(77,77,77,.2)}.btn-submit{padding:12px 24px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));border:none;border-radius:10px;color:var(--white);font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #1995d24d}.btn-submit:hover:not(:disabled){transform:translateY(-2px) translateZ(10px);box-shadow:0 6px 20px #1995d266}.btn-submit:active:not(:disabled){transform:translateY(0) translateZ(5px)}.btn-cancel:hover{transform:translateY(-1px) translateZ(5px)}.btn-cancel:active{transform:translateY(0) translateZ(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.modal-content{max-width:100%;margin:10px}.modal-header,.portfolio-form{padding:20px}}.portfolio-management-container{display:flex;min-height:100vh;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf1 100%);transform-style:preserve-3d}.portfolio-management-main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;padding:20px 24px 80px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;scroll-behavior:smooth;overflow-y:auto;overflow-x:hidden;width:calc(100% - 240px)}body.sidebar-collapsed .portfolio-management-main{margin-left:64px;width:calc(100% - 64px)}.portfolio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:20px}.portfolio-title{font-size:32px;font-weight:700;color:var(--davys-grey);margin:0;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform-style:preserve-3d}.btn-new-portfolio{padding:12px 24px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease;box-shadow:0 4px 12px #1995d24d;transform-style:preserve-3d;font-family:inherit}.search-filter-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;gap:20px;flex-wrap:wrap}.search-input{width:100%;padding:12px 16px 12px 48px;border:2px solid rgba(25,149,210,.15);border-radius:12px;font-size:14px;background:var(--white);transition:all .3s ease;outline:none;transform-style:preserve-3d}.filter-tab{padding:8px 20px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:600;color:var(--davys-grey);cursor:pointer;transition:all .3s ease;transform-style:preserve-3d}.filter-tab:hover{background:rgba(25,149,210,.1);transform:translateZ(5px)}.filter-tab.active{background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);box-shadow:0 2px 8px #1995d24d;transform:translateZ(10px)}.portfolio-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.loading-state{display:flex;justify-content:center;align-items:center;min-height:400px}.loader-spinner{width:60px;height:60px;border:4px solid rgba(25,149,210,.1);border-top-color:var(--celestial-blue);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px;transform-style:preserve-3d}@keyframes spin{0%{transform:rotate(0) translateZ(0)}to{transform:rotate(360deg) translateZ(0)}}.animated-loader p{color:var(--davys-grey);font-size:16px;font-weight:500;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.empty-state{text-align:center;padding:80px 20px;background:var(--white);border-radius:16px;box-shadow:0 4px 20px #00000014;transform-style:preserve-3d}.empty-state svg{margin-bottom:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) translateZ(0)}50%{transform:translateY(-10px) translateZ(10px)}}.empty-state p{color:#4d4d4db3;margin-bottom:24px}.error-banner{display:flex;align-items:center;gap:10px;padding:16px;background:rgba(240,135,33,.1);border:1px solid var(--tangerine);border-radius:12px;color:var(--tangerine);margin-bottom:24px}@media (max-width: 1024px){.portfolio-management-main{margin-left:0}.portfolio-cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.portfolio-management-main{padding:20px}.portfolio-cards-grid{grid-template-columns:1fr}.search-filter-section{flex-direction:column;align-items:stretch}}.dashboard-container{display:flex;min-height:100vh;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf1 100%);transform-style:preserve-3d}.dashboard-main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;padding-bottom:80px;transition:margin-left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1);position:relative;width:calc(100% - 240px)}body.sidebar-collapsed .dashboard-main{margin-left:64px;width:calc(100% - 64px)}.dashboard-header{background:var(--white);padding:16px 24px;box-shadow:0 2px 10px #0000000d;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;position:sticky;top:0;z-index:100;transform-style:preserve-3d}.header-left{display:flex;align-items:center}.logo-title{display:flex;align-items:center;gap:16px}.logo-icon-small{width:32px;height:32px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1) translateZ(0)}50%{transform:scale(1.05) translateZ(5px)}}.dashboard-title{font-size:18px;font-weight:700;color:var(--davys-grey);margin:0;letter-spacing:.3px}.dashboard-subtitle{display:flex;align-items:center;gap:8px;margin:2px 0 0;font-size:11px}.access-badge{color:var(--davys-grey);font-weight:500;font-size:11px}.header-actions{display:flex;align-items:center;gap:12px}.btn-new-portfolio{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease;border:none;font-family:inherit;transform-style:preserve-3d;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);box-shadow:0 4px 12px #1995d24d}.btn-new-portfolio:hover{transform:translateY(-2px) translateZ(10px);box-shadow:0 6px 20px #1995d266}.btn-new-portfolio:active{transform:translateY(0) translateZ(5px)}.header-user-info{display:flex;align-items:center;gap:16px}.user-greeting{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.greeting-text{font-size:12px;font-weight:600;color:var(--davys-grey)}.current-time{font-size:10px;color:var(--davys-grey);font-weight:500}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid var(--celestial-blue);box-shadow:0 2px 8px #1995d233;transition:all .3s ease;transform-style:preserve-3d}.user-avatar:hover{transform:scale(1.05) translateZ(5px);box-shadow:0 4px 12px #1995d24d}.user-avatar img{width:100%;height:100%;object-fit:cover}.status-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(16,185,129,.1);border-radius:20px;font-size:12px;font-weight:600;color:#10b981}.status-dot{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulseDot 2s ease-in-out infinite}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:20px 24px}.metric-card{background:var(--white);border-radius:16px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 20px #00000014;transition:all .4s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;border:1px solid rgba(0,0,0,.05);animation:fadeInUp .6s ease-out backwards;position:relative;z-index:1}.metric-card:hover{z-index:10001}.metric-card:nth-child(1){animation-delay:.1s}.metric-card:nth-child(2){animation-delay:.2s}.metric-card:nth-child(3){animation-delay:.3s}.metric-card:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px) translateZ(0)}to{opacity:1;transform:translateY(0) translateZ(0)}}.metric-card:hover{transform:translateY(-6px) translateZ(15px) scale(1.02);box-shadow:0 12px 40px #00000026}.metric-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-icon.building{background:linear-gradient(135deg,rgba(86,172,218,.1),rgba(25,149,210,.1));color:var(--celestial-blue)}.metric-icon.graph{background:linear-gradient(135deg,rgba(86,172,218,.1),rgba(25,149,210,.1));color:var(--picton-blue)}.metric-icon.location{background:linear-gradient(135deg,rgba(240,135,33,.1),rgba(255,157,77,.1));color:var(--tangerine)}.metric-icon.lightning{background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(5,150,105,.1));color:#10b981}.metric-icon.roi{background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(124,58,237,.1));color:#8b5cf6}.metric-icon.wallet{background:linear-gradient(135deg,rgba(86,172,218,.1),rgba(25,149,210,.1));color:var(--celestial-blue)}.metric-content{flex:1}.metric-label{font-size:11px;font-weight:600;color:var(--davys-grey);margin:0 0 4px;letter-spacing:.3px;text-transform:uppercase}.metric-value{font-size:18px;font-weight:700;color:var(--davys-grey);margin:0}.metric-info-icon{position:absolute;top:12px;right:12px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#4d4d4d80;cursor:help;transition:all .3s ease;z-index:10}.metric-info-icon:hover{color:var(--celestial-blue);transform:scale(1.1)}.metric-info-icon svg{width:100%;height:100%}.metric-tooltip{position:absolute;bottom:100%;right:0;margin-bottom:8px;padding:14px 16px;background:var(--white);color:var(--davys-grey);border:2px solid rgba(25,149,210,.2);border-radius:12px;font-size:12px;line-height:1.6;opacity:0;visibility:hidden;transform:translateY(10px) scale(.95);transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:10000;box-shadow:0 8px 24px #00000026;max-width:320px;white-space:normal;text-align:left;min-width:200px}.metric-tooltip:before{content:"";position:absolute;top:100%;right:16px;border:8px solid transparent;border-top-color:var(--white);filter:drop-shadow(0 2px 2px rgba(0,0,0,.05))}.metric-tooltip:after{content:"";position:absolute;top:100%;right:16px;border:10px solid transparent;border-top-color:#1995d233;margin-top:-2px;z-index:-1}.metric-info-icon:hover .metric-tooltip{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.metric-tooltip strong{display:block;margin-bottom:10px;font-weight:700;color:var(--celestial-blue);font-size:13px;letter-spacing:.3px;text-transform:uppercase}.formula-text{display:block;margin-bottom:8px;color:var(--davys-grey);font-size:12px;line-height:1.5;font-weight:500}.formula-math{display:block;margin-top:8px;padding:8px 12px;background:rgba(25,149,210,.08);border-left:3px solid var(--celestial-blue);border-radius:6px;font-family:Courier New,Monaco,Consolas,monospace;font-size:12px;color:var(--celestial-blue);font-weight:700;line-height:1.6;letter-spacing:.5px;white-space:nowrap;overflow-x:auto}.search-filter-section{display:flex;justify-content:space-between;align-items:center;padding:0 24px 16px;gap:16px;flex-wrap:wrap;position:relative;z-index:100}.search-wrapper{flex:1;min-width:300px;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:16px;color:var(--davys-grey);z-index:1;opacity:.8}.search-input{width:100%;padding:8px 12px 8px 40px;border:2px solid rgba(25,149,210,.15);border-radius:8px;font-size:13px;background:var(--white);transition:all .3s ease;outline:none;transform-style:preserve-3d}.search-input:focus{border-color:var(--celestial-blue);box-shadow:0 0 0 4px #1995d21a;transform:translateY(-1px) translateZ(5px)}.filter-tabs{display:flex;gap:8px;background:var(--white);padding:4px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.filter-tab{padding:6px 16px;border:none;background:transparent;border-radius:6px;font-size:12px;font-weight:600;color:var(--davys-grey);cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;position:relative;overflow:hidden}.filter-tab:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.filter-tab:hover:before{left:100%}.filter-tab:hover{background:rgba(25,149,210,.1);transform:translateY(-2px) translateZ(5px)}.filter-tab.active{background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));color:var(--white);box-shadow:0 4px 12px #1995d266;transform:translateY(-2px) translateZ(10px)}.portfolio-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:0 24px 24px}.loading-state{display:flex;justify-content:center;align-items:center;min-height:400px;padding:0 40px 40px}.animated-loader{text-align:center;transform-style:preserve-3d}.loader-spinner{width:60px;height:60px;border:4px solid rgba(25,149,210,.1);border-top-color:var(--celestial-blue);border-radius:50%;animation:spinLoader 1s linear infinite;margin:0 auto 20px;transform-style:preserve-3d;position:relative}.loader-spinner:before{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;border:4px solid transparent;border-top-color:var(--picton-blue);border-radius:50%;animation:spinLoader .5s linear infinite reverse}@keyframes spinLoader{0%{transform:rotate(0) translateZ(0)}to{transform:rotate(360deg) translateZ(0)}}.animated-loader p{color:var(--davys-grey);font-size:16px;font-weight:500;animation:pulseText 2s ease-in-out infinite}@keyframes pulseText{0%,to{opacity:1;transform:translateZ(0)}50%{opacity:.6;transform:translateZ(5px)}}.empty-state{text-align:center;padding:80px 20px;background:var(--white);border-radius:16px;margin:0 40px 40px;box-shadow:0 4px 20px #00000014}.empty-state svg{margin-bottom:24px}.empty-state h3{color:var(--davys-grey);font-size:24px;margin-bottom:8px}.empty-state p{color:var(--davys-grey);margin-bottom:24px;font-size:15px}.error-banner{display:flex;align-items:center;gap:10px;padding:16px;background:rgba(240,135,33,.1);border:1px solid var(--tangerine);border-radius:12px;color:var(--tangerine);margin:0 40px 24px}@media (max-width: 1024px){.dashboard-main{margin-left:0}.metrics-grid{grid-template-columns:repeat(2,1fr)}.portfolio-cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-animation-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .3s ease}.success-animation-content{background:var(--white);border-radius:20px;padding:40px;text-align:center;box-shadow:0 20px 60px #0000004d;max-width:400px;width:90%}.success-animation-content svg{margin-bottom:20px}.success-animation-content h2{color:var(--davys-grey);font-size:24px;font-weight:700;margin:0}.tada-animation{animation:tada .8s ease}@keyframes tada{0%{transform:scale(.8) rotate(0);opacity:0}10%,20%{transform:scale(.9) rotate(-3deg)}30%,50%,70%,90%{transform:scale(1.1) rotate(3deg)}40%,60%,80%{transform:scale(1.1) rotate(-3deg)}to{transform:scale(1) rotate(0);opacity:1}}@media (max-width: 768px){.dashboard-header{padding:16px 20px}.metrics-grid{grid-template-columns:1fr;padding:24px 20px}.search-filter-section{padding:0 20px 24px;flex-direction:column;align-items:stretch}.portfolio-cards-grid{grid-template-columns:1fr;padding:0 20px 40px}.dashboard-title{font-size:16px}}:root{--picton-blue: #56ACDA;--celestial-blue: #1995D2;--tangerine: #F08721;--davys-grey: #4D4D4D;--white: #FFFFFF}.bank-container{display:flex;min-height:100vh;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf1 100%);transform-style:preserve-3d}.bank-main{flex:1;margin-left:240px;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px 24px 80px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;scroll-behavior:smooth;overflow-y:auto;overflow-x:hidden;width:calc(100% - 240px)}body.sidebar-collapsed .bank-main{margin-left:64px;width:calc(100% - 64px)}.coming-soon-content{text-align:center;max-width:600px;transform-style:preserve-3d;animation:fadeInUp .8s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px) translateZ(-50px) scale(.95)}to{opacity:1;transform:translateY(0) translateZ(0) scale(1)}}.coming-soon-icon{margin-bottom:40px;animation:pulse 2s ease-in-out infinite;transform-style:preserve-3d}@keyframes pulse{0%,to{transform:scale(1) translateZ(0)}50%{transform:scale(1.05) translateZ(10px)}}.coming-soon-title{font-size:48px;font-weight:700;color:var(--davys-grey);margin-bottom:16px;background:linear-gradient(135deg,var(--celestial-blue),var(--picton-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform-style:preserve-3d}.coming-soon-subtitle{font-size:20px;color:var(--davys-grey);font-weight:400;line-height:1.6}@media (max-width: 1024px){.bank-main{margin-left:0}}@media (max-width: 768px){.bank-main{padding:20px}.coming-soon-title{font-size:36px}.coming-soon-subtitle{font-size:18px}.coming-soon-icon svg{width:80px;height:80px}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:Avenir,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{scroll-behavior:smooth}a,button,input,select,textarea{transition:all .4s cubic-bezier(.4,0,.2,1)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:5px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#1995D2,#56ACDA);border-radius:5px;transition:all .4s cubic-bezier(.4,0,.2,1)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#56ACDA,#1995D2)}*{scrollbar-width:thin;scrollbar-color:#1995D2 #f1f1f1}
