*{scrollbar-width:thin;scrollbar-color:var(--primary-700) var(--surface)}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-thumb{background:#888;border-radius:4px}*::-webkit-scrollbar-track{background:#222}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:Roboto,Helvetica Neue,sans-serif;background-color:var(--background);color:#000000de}*{box-sizing:border-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in-out}:root{--primary-50: #b18afa;--primary-100: #f9bbfb;--primary-200: #f990e7;--primary-300: #cd64f6;--primary-400: #d142f5;--primary-500: #a621f3;--primary-600: #9c1ee5;--primary-700: #8e19d2;--primary-800: #7c15c0;--primary-900: #770da1;--accent-50: #fce4ec;--accent-100: #f8bbd9;--accent-200: #f48fb1;--accent-300: #f06292;--accent-400: #ec407a;--accent-500: #e91e63;--accent-600: #d81b60;--accent-700: #c2185b;--accent-800: #ad1457;--accent-900: #880e4f;--warn-50: #ffebee;--warn-100: #ffcdd2;--warn-200: #ef9a9a;--warn-300: #e57373;--warn-400: #ef5350;--warn-500: #f44336;--warn-600: #e53935;--warn-700: #d32f2f;--warn-800: #c62828;--warn-900: #b71c1c;--surface: #2e2e2e;--background: #363535;--on-surface: rgb(255, 255, 255);--on-background: rgba(0, 0, 0, .87);--border-color: #646464;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 8px rgba(0, 0, 0, .15);--mat-dialog-container-color: var(--surface)}.mat-mdc-form-field{color:var(--on-surface);background-color:var(--surface)}.cdk-overlay-pane{background-color:var(--surface);color:var(--on-surface)}button{font-family:inherit;cursor:pointer;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;text-transform:uppercase;transition:all .3s ease;outline:none}.create-folder-dialog{background-color:var(--surface);border-radius:8px;box-shadow:0 2px 10px #0000001a}button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-700);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-800);box-shadow:var(--shadow-hover)}.btn-secondary{background-color:transparent;color:var(--primary-900);border:2px solid var(--primary-900)}.btn-secondary:hover:not(:disabled){background-color:var(--primary-50)}.btn-warn{background-color:var(--warn-700);color:#fff}.btn-warn:hover:not(:disabled){background-color:var(--warn-800)}.card{background:var(--surface);border-radius:8px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .3s ease;flex:15}.card-explorer{background:var(--surface);border-radius:8px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .3s ease;border:#666 solid;display:flex;overflow-x:scroll;flex:3;padding-top:15px}.card:hover{box-shadow:var(--shadow-hover)}.card-header{padding:16px 20px;border-bottom:4px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;min-height:72px;box-sizing:border-box}.card-title{font-size:20px;font-weight:500;margin:0;color:var(--on-surface)}.card-subtitle{font-size:14px;color:#807d7dbb;margin:4px 0 0}.card-content{padding:10px;overflow-x:scroll;max-height:90%}.form-field{margin-bottom:16px}.form-label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:var(--on-surface)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:4px;font-size:16px;font-family:inherit;background-color:var(--surface);color:var(--on-surface);transition:border-color .3s ease}.form-input:focus{outline:none;border-color:var(--primary-700);box-shadow:0 0 0 2px #1976d233}.form-input:invalid{border-color:var(--warn-700)}.form-error{color:var(--warn-700);font-size:12px;margin-top:4px}.icon{width:24px;height:24px;fill:currentColor;vertical-align:middle}.icon-button{background:none;border:none;padding:8px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background-color .3s ease}.icon-button:hover{background-color:#0000000a}.list{list-style:none;padding:0;margin:0}.list-item{padding:12px 16px;border-bottom:1px solid var(--border-color);transition:background-color .3s ease}.list-item:hover{background-color:#0000000a}.list-item:last-child{border-bottom:none}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.full-width{width:100%}.text-center{text-align:center}.flex{display:flex}.flex-column{flex-direction:column}.align-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.p-16{padding:16px}.p-20{padding:20px}.app-container{min-height:99vh;display:flex;flex-direction:column;background-color:var(--background);overflow:visible}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-800) 100%)}.login-card{background:var(--surface);padding:40px;border-radius:12px;box-shadow:0 8px 32px #0000001a;width:100%;max-width:400px}.sidebar{width:250px;background-color:var(--primary-700);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 5px #0000001a}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{margin:0 0 10px;font-weight:300;font-size:24px}.sidebar-header p{margin:0;opacity:.8;font-size:14px}.nav-menu{flex:1;padding:20px 0}.nav-item{display:flex;align-items:center;padding:12px 20px;margin:4px 0;color:#fff;text-decoration:none;transition:background-color .3s ease;cursor:pointer}.nav-item:hover{background-color:#ffffff1a}.nav-item.active{background-color:#fff3}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.logout-btn{color:#fff;width:100%;justify-content:flex-start;background:none;text-transform:none}.main-content{flex:1;background-color:var(--background)}.upload-zone{border:2px dashed #ccc;border-radius:8px;padding:40px;text-align:center;margin:20px 0;transition:all .3s ease;cursor:pointer;background-color:#fafafa}.upload-zone:hover{border-color:var(--primary-700);background-color:var(--primary-50)}.upload-zone.dragover{border-color:var(--primary-700);background-color:var(--primary-50);transform:scale(1.02)}.upload-icon{font-size:48px;color:#666;margin-bottom:16px}.image-container{position:relative;display:inline-block;border-radius:4px;overflow:hidden;background:#f9f9f9}.layout-image{display:block;max-width:100%;height:auto;cursor:crosshair;-webkit-user-select:none;user-select:none}.coordinate-tracker{position:absolute;top:10px;right:10px;background:#000c;color:#fff;padding:6px 12px;border-radius:4px;font-family:Courier New,monospace;font-size:12px;pointer-events:none;z-index:10}.selection-rectangle{position:absolute;border:2px dashed var(--primary-700);background:#1976d21a;pointer-events:none;z-index:5}.marked-area{position:absolute;border:2px solid #ff4444;background:#ff44441a;pointer-events:none;z-index:3}.area-label{position:absolute;top:-20px;left:0;background:#f44;color:#fff;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700;min-width:20px;text-align:center}.delete-area-btn{position:absolute;top:-20px;right:0;background:var(--warn-700);color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;z-index:10;font-size:12px}.delete-area-btn:hover{background:var(--warn-800)}.coordinate-item{margin-bottom:16px;padding:16px;background:#f8f9fa;border-radius:6px;border-left:4px solid #ff4444}.coordinate-details{font-family:Courier New,monospace;font-size:12px}.coordinate-row{display:flex;justify-content:space-between;margin-bottom:4px}.coordinate-row .label{color:#666;font-weight:700}.coordinate-row .value{color:#333}@media (max-width: 480px){.sidebar{width:100%!important;min-width:0;height:auto;flex-direction:column;padding:8px 0}.main-content{padding:1vw}.sidebar-footer{padding:10px}}@media (max-width: 768px){.dashboard-container{flex-direction:column}.sidebar{width:100%;height:auto}.editor-workspace{grid-template-columns:1fr!important}.login-card{margin:20px;padding:30px}}@font-face{font-family:Mistral;src:url(/assets/fonts/Mistral.ttf) format("truetype")}@font-face{font-family:Modernline;src:url(/assets/fonts/Modernline.ttf) format("truetype")}@font-face{font-family:Modernline Tail;src:url(/assets/fonts/Modernline\ tail.ttf) format("truetype")}@font-face{font-family:ShelleyAllegro;src:url(/assets/fonts/ShelleyAllegro.ttf) format("truetype")}@font-face{font-family:Bestand;src:url(/assets/fonts/Bestand.ttf) format("truetype")}@font-face{font-family:Melinda;src:url(/assets/fonts/Melinda.ttf) format("truetype")}@font-face{font-family:Clarissa;src:url(/assets/fonts/Clarissa.ttf) format("truetype")}@font-face{font-family:"Melinda 1";src:url(/assets/fonts/Melinda\ 1.ttf) format("truetype")}@font-face{font-family:Cartoonish;src:url(/assets/fonts/Cartoonish.ttf) format("truetype")}@font-face{font-family:Dandele\a2n;src:url(/assets/fonts/Dandele\a2n.ttf) format("truetype")}@font-face{font-family:Sign Rathi;src:url(/assets/fonts/Sign\ Rathi.ttf) format("truetype")}@font-face{font-family:Broken Heart;src:url(/assets/fonts/Broken\ Heart.ttf) format("truetype")}@font-face{font-family:Hello Selly;src:url("/assets/fonts/19 Hello Selly.ttf") format("truetype")}@font-face{font-family:I Love Glitter;src:url("/assets/fonts/I Love Glitter.ttf") format("truetype")}@font-face{font-family:Melinda Script;src:url(/assets/fonts/Melinda\ script.ttf) format("truetype")}@font-face{font-family:Broadcast Xtras;src:url(/assets/fonts/Broadcast_Xtras.ttf) format("truetype")}@font-face{font-family:Broadcast Matter;src:url(/assets/fonts/Broadcast_Matter.ttf) format("truetype")}@font-face{font-family:Dandele\a2n Swash;src:url(/assets/fonts/Dandele\a2n\ Swash.ttf) format("truetype")}@font-face{font-family:Cartoonish Italic;src:url(/assets/fonts/Cartoonish-Italic.ttf) format("truetype")}@font-face{font-family:Dandele\a2n Italic;src:url(/assets/fonts/Dandele\a2n\ Italic.ttf) format("truetype")}@font-face{font-family:Watermelon Script;src:url(/assets/fonts/Watermelon-Script.ttf) format("truetype")}@font-face{font-family:Blossom Lovely;src:url("/assets/fonts/Blossom lovely ttf.ttf") format("truetype")}@font-face{font-family:Dandele\a2n Vintage;src:url(/assets/fonts/Dandele\a2n\ Vintage.ttf) format("truetype")}@font-face{font-family:Stylish Calligraphy;src:url(/assets/fonts/Stylish-Calligraphy.ttf) format("truetype")}@font-face{font-family:Hello Selly Kopie;src:url("/assets/fonts/19 Hello Selly Kopie.ttf") format("truetype")}@font-face{font-family:Hello Selly Italic;src:url("/assets/fonts/19 Hello Selly Italic.ttf") format("truetype")}@font-face{font-family:Christmas Wish Monoline;src:url(/assets/fonts/ChristmasWish-monoline.ttf) format("truetype")}@font-face{font-family:Christmas Wish Calligraphy;src:url(/assets/fonts/ChristmasWish-Calligraphy.ttf) format("truetype")}@font-face{font-family:Dandele\a2n Vintage Italic;src:url("/assets/fonts/Dandele\a2n Vintage Italic.ttf") format("truetype")}@font-face{font-family:Diamond Dust;src:url("/assets/fonts/Diamond-Dust COMMERCIAL VERSION.ttf") format("truetype")}
