@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.m-395{margin:calc(var(--spacing)*395)}.m-406{margin:calc(var(--spacing)*406)}.m-409{margin:calc(var(--spacing)*409)}.m-437{margin:calc(var(--spacing)*437)}.m-487{margin:calc(var(--spacing)*487)}.m-558{margin:calc(var(--spacing)*558)}.m-586{margin:calc(var(--spacing)*586)}.m-588{margin:calc(var(--spacing)*588)}.m-616{margin:calc(var(--spacing)*616)}.m-799{margin:calc(var(--spacing)*799)}.m-995{margin:calc(var(--spacing)*995)}.m-997{margin:calc(var(--spacing)*997)}.m-1180{margin:calc(var(--spacing)*1180)}.m-1204{margin:calc(var(--spacing)*1204)}.m-1345{margin:calc(var(--spacing)*1345)}.m-1710{margin:calc(var(--spacing)*1710)}.m-2702{margin:calc(var(--spacing)*2702)}.m-3214{margin:calc(var(--spacing)*3214)}.m-4562{margin:calc(var(--spacing)*4562)}.m-6677{margin:calc(var(--spacing)*6677)}.m-7527{margin:calc(var(--spacing)*7527)}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}html{height:100%;height:-webkit-fill-available}body{min-height:100vh;min-height:-webkit-fill-available}*{touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.main-page{width:100%;height:100vh;max-height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;position:fixed;inset:0}.main-container{width:100%;max-width:400px;background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.main-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;position:relative}.main-title{font-size:3rem;font-weight:700;text-align:center;margin:0 auto;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex:1}.settings-button{position:absolute;top:0;right:0;background:none;border:none;cursor:pointer;padding:8px;color:#3b82f6;transition:all .3s;display:flex;align-items:center;justify-content:center;border-radius:50%;width:40px;height:40px}.settings-button:hover{background:#3b82f61a;transform:rotate(90deg)}.settings-button:active{transform:rotate(90deg) scale(.95)}@media(max-width:768px){.main-page{padding:10px;overflow:hidden}.main-title{font-size:1.6rem;margin-bottom:8px}.main-container{padding:20px 15px;height:auto;max-height:none;min-height:auto;gap:15px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:400px;margin:10px auto}.main-subtitle{font-size:.85rem;margin-bottom:15px}.code-input{padding:12px 16px;font-size:1rem}.submit-button{padding:12px;font-size:1rem}.error-message{padding:10px;font-size:.85rem}}.main-subtitle{text-align:center;color:#666;margin-bottom:30px;font-size:1rem}@media(max-width:768px){.main-subtitle{font-size:.9rem;margin-bottom:20px}}.code-input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .3s;box-sizing:border-box}.code-input:focus{border-color:#3b82f6}.code-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.group-admin-info{text-align:center;padding:20px;background:#f8f9fa;border-radius:8px;margin-bottom:20px;display:flex;flex-direction:column;align-items:center;gap:15px}.group-admin-label{font-size:.85rem;color:#666;margin:0}.group-admin-link{font-size:1rem;color:#333;font-weight:600;background:none;border:none;cursor:pointer;padding:0;margin:0;transition:color .3s;display:block;width:100%;text-align:center}.group-admin-link:hover{color:#3b82f6}.group-admin-buttons{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.settings-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.settings-modal-content{background:#fff;border-radius:20px;padding:30px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative}.settings-modal-content h2{font-size:1.8rem;font-weight:700;margin-bottom:25px;text-align:center;color:#333}.settings-options{display:flex;flex-direction:column;gap:15px;margin-bottom:25px}.settings-option-button{display:flex;align-items:center;gap:15px;padding:20px;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s;text-align:left;width:100%}.settings-option-button:hover{background:#e9ecef;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.settings-option-icon{font-size:2.5rem;flex-shrink:0}.settings-option-text{flex:1}.settings-option-title{font-size:1.2rem;font-weight:600;color:#333;margin-bottom:5px}.settings-option-desc{font-size:.9rem;color:#666}.settings-modal-close{width:100%;padding:12px;background:#6b7280;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.settings-modal-close:hover{background:#4b5563;transform:translateY(-2px)}@media(max-width:768px){.settings-modal-content{padding:20px}.settings-modal-content h2{font-size:1.5rem}.settings-option-button{padding:15px}.settings-option-icon{font-size:2rem}.settings-option-title{font-size:1.1rem}}.consent-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;overflow:hidden;position:fixed;inset:0}.consent-container{background:#fff;border-radius:20px;padding:40px;max-width:600px;width:100%;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;gap:20px;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.consent-container h1{margin:0;color:#1e293b;font-size:2rem;text-align:center;font-weight:700}.consent-content{display:flex;flex-direction:column;gap:15px;flex:1;overflow-y:auto;min-height:0}.consent-text{color:#475569;line-height:1.8}.consent-text h2{margin:0 0 15px;color:#1e293b;font-size:1.5rem;font-weight:600}.consent-text p{margin:0 0 15px;font-size:1rem}.consent-text ul{margin:15px 0;padding-left:25px}.consent-text li{margin:10px 0;font-size:1rem}.consent-text strong{color:#dc2626;font-weight:600}.consent-warning{margin-top:20px!important;padding:15px;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;color:#92400e;font-weight:500}.consent-checkbox{padding:20px;background:#f8f9fa;border-radius:12px;border:2px solid #e5e7eb}.consent-checkbox label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:1.1rem;font-weight:600;color:#1e293b}.consent-checkbox input[type=checkbox]{width:24px;height:24px;cursor:pointer;accent-color:#3b82f6}.consent-actions{display:flex;gap:15px;justify-content:center}.consent-actions button{flex:1;padding:18px 30px;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s;height:50px;display:flex;align-items:center;justify-content:center}.back-button{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.back-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #ff98004d}.next-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f666}.next-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.consent-page{padding:10px;overflow:hidden}.consent-container{padding:20px 15px;height:auto;max-height:none;min-height:auto;gap:15px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:600px;margin:10px auto}.consent-container h1{font-size:1.3rem;margin-bottom:0}.consent-text h2{font-size:1.1rem;margin-bottom:10px}.consent-text p{font-size:.9rem;margin-bottom:10px}.consent-text ul{margin:10px 0;padding-left:20px}.consent-text li{margin:8px 0;font-size:.85rem}.consent-warning{margin-top:10px!important;padding:10px;font-size:.85rem}.consent-checkbox{padding:15px}.consent-checkbox label{font-size:.95rem}.consent-checkbox input[type=checkbox]{width:20px;height:20px}.consent-actions{flex-direction:row;gap:10px;flex-shrink:0}.consent-actions button{flex:1;padding:14px;font-size:1rem}}.frame-select-page{width:100%;height:100vh;max-height:100vh;overflow:hidden;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;position:fixed;inset:0}.frame-select-container{width:100%;max-width:1200px;margin:20px auto;background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto}.page-subtitle{text-align:center;color:#666;margin-bottom:15px;font-size:1rem}.remaining-shots-info{text-align:center;padding:10px 20px;background:#dbeafe;border-radius:10px;margin-bottom:30px;font-size:1rem;color:#1e40af}.remaining-shots-info strong{font-size:1.2rem;color:#3b82f6}.frames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;margin-bottom:20px;justify-items:center;align-items:start;flex:1;overflow-y:auto;min-height:0;padding-right:5px}.frame-item{cursor:pointer;transition:all .3s;border-radius:12px;overflow:hidden;border:3px solid transparent;display:flex;flex-direction:column;max-width:100%;width:100%}.frame-item:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003}.frame-item.selected{border-color:#3b82f6;box-shadow:0 0 20px #3b82f680}.frame-preview{position:relative;width:100%;min-height:120px;max-height:250px;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center}.frame-preview img{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;margin:0 auto;display:block}.frame-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#3b82f61a;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.frame-item.selected .frame-overlay{opacity:1}.check-icon{width:60px;height:60px;background:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.frame-info{text-align:center;padding:10px;color:#666;font-size:.9rem;margin:0}.camera-permission-section{background:#fff3cd;border:2px solid #ffc107;border-radius:12px;padding:15px;margin-bottom:15px;text-align:center;flex-shrink:0}.camera-permission-text{color:#856404;font-size:.95rem;margin:0 0 12px;font-weight:500}.camera-permission-button{width:100%;padding:12px 20px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;cursor:pointer;transition:all .3s}.camera-permission-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.action-buttons{display:flex;justify-content:center;margin-top:10px;flex-shrink:0}.next-button{padding:15px 40px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;cursor:pointer;transition:all .3s}.loading{text-align:center;padding:50px;font-size:1.2rem;color:#fff;display:flex;align-items:center;justify-content:center;height:100%}.error-container{text-align:center;padding:50px;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}.error-container h2{margin-bottom:10px}@media(max-width:768px){.frame-select-page{padding:10px;overflow:hidden}.frame-select-container{padding:15px 10px;height:auto;max-height:none;min-height:auto;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:1200px;margin:10px auto}.page-title{font-size:1.4rem;margin-bottom:5px}.page-subtitle{font-size:.85rem;margin-bottom:10px}.remaining-shots-info{padding:8px 15px;margin-bottom:10px;font-size:.85rem}.remaining-shots-info strong{font-size:1rem}.frames-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:10px}.frame-preview{min-height:100px;max-height:200px}.frame-info{font-size:.8rem;padding:5px}.camera-permission-section{padding:12px;margin-bottom:10px}.camera-permission-text{font-size:.85rem;margin-bottom:10px}.camera-permission-button{padding:10px;font-size:.9rem}.next-button{padding:12px 20px;font-size:.95rem;width:100%}}.camera-connecting-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;overflow:hidden;position:fixed;inset:0}.connecting-container{width:100%;max-width:400px;background:#fff;border-radius:20px;padding:60px 40px;box-shadow:0 20px 60px #0000004d;text-align:center;box-sizing:border-box}.spinner-large{width:80px;height:80px;border:6px solid rgba(59,130,246,.3);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 30px}.connecting-title{font-size:1.8rem;font-weight:700;color:#333;margin-bottom:10px}.connecting-subtitle{font-size:1rem;color:#666}@media(max-width:768px){.connecting-container{padding:50px 30px}.connecting-title{font-size:1.5rem}.connecting-subtitle{font-size:.9rem}.spinner-large{width:60px;height:60px;border-width:5px}}.camera-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;position:fixed;inset:0;overflow:hidden;box-sizing:border-box}.camera-container{width:100%;height:100vh;max-height:100vh;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;box-sizing:border-box;overflow:hidden;min-height:0;padding-bottom:200px;padding-top:0}.camera-view-wrapper{position:relative;width:100%;max-width:100%;flex:0 0 auto;min-height:0;max-height:calc(100vh - 200px);display:flex;align-items:flex-start;justify-content:center;overflow:hidden;aspect-ratio:var(--camera-aspect-ratio, 16 / 9);margin-top:0}.webcam{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;position:relative;z-index:5}.area-guide{display:flex;align-items:flex-start;justify-content:flex-start;animation:areaPulse 2s ease-in-out infinite}.area-label{position:absolute;top:8px;left:8px;background:#10b981e6;color:#fff;padding:6px 12px;border-radius:6px;font-size:.9rem;font-weight:600;box-shadow:0 2px 8px #0000004d}@keyframes areaPulse{0%,to{box-shadow:0 0 20px #10b98199,inset 0 0 20px #10b9814d}50%{box-shadow:0 0 30px #10b981cc,inset 0 0 30px #10b98180}}.realtime-preview-canvas{pointer-events:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.frame-overlay{pointer-events:none;display:flex;align-items:center;justify-content:center}.frame-overlay-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.camera-mask{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#3b82f6,#2563eb);z-index:6;pointer-events:none;display:none}.flash-effect{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;opacity:0;animation:flash .15s ease-out;pointer-events:none;z-index:10}@keyframes flash{0%{opacity:0}50%{opacity:1}to{opacity:0}}.area-message-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:#000c;z-index:100;animation:fadeInOut 2s ease-in-out}.area-message{font-size:3rem;font-weight:700;color:#fff;text-shadow:0 0 20px rgba(255,255,255,.5);text-align:center;padding:30px 50px;background:#3b82f6cc;border-radius:20px;box-shadow:0 10px 40px #0000004d}@keyframes fadeInOut{0%{opacity:0;transform:scale(.9)}20%{opacity:1;transform:scale(1)}80%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@media(max-width:768px){.area-message{font-size:1.8rem;padding:20px 30px}}.countdown-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:#000c;z-index:100}.countdown-number{font-size:15rem;font-weight:700;color:#fff;text-shadow:0 0 30px rgba(255,255,255,.5);animation:pulse 1s ease-in-out infinite}@media(max-width:768px){.countdown-number{font-size:8rem}.camera-page{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start}.camera-container{width:100%;height:100vh;max-height:100vh;display:flex;flex-direction:column;position:relative}.camera-view-wrapper{width:100%;max-width:100%;flex:0 0 auto;min-height:0;max-height:calc(100vh - 200px);position:relative;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;aspect-ratio:var(--camera-aspect-ratio, 16 / 9);margin-top:0}.webcam{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.camera-controls{position:fixed;bottom:0;left:0;right:0;width:100%;padding:20px 15px;padding-bottom:max(20px,env(safe-area-inset-bottom));background:linear-gradient(to top,#000000f2,#000c);z-index:15;flex-shrink:0;box-shadow:0 -4px 20px #0000004d;display:flex;flex-direction:column;align-items:center}.shot-info{font-size:1rem;margin-bottom:15px}.capture-button{padding:15px;font-size:1rem}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.camera-controls{position:fixed;bottom:0;left:0;right:0;width:100%;padding:30px 20px;padding-bottom:max(30px,env(safe-area-inset-bottom));background:linear-gradient(to top,#000000f2,#000c);z-index:15;flex-shrink:0;display:flex;flex-direction:column;align-items:center;min-height:150px;box-shadow:0 -4px 20px #0000004d}.progress-bar{width:100%;height:4px;background:#ffffff4d;border-radius:2px;margin-bottom:20px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.shot-info{text-align:center;color:#fff;font-size:1.2rem;font-weight:600;margin-bottom:20px}.capture-button{width:100%;padding:18px;font-size:1.2rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s}.capture-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.capture-button:disabled{opacity:.6;cursor:not-allowed}.select-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;overflow:hidden;position:fixed;inset:0}.select-container{max-width:1200px;margin:20px auto;background:#fff;border-radius:20px;padding:20px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto}.page-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:8px;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{text-align:center;color:#666;margin-bottom:20px;font-size:.9rem}.select-layout{display:flex;gap:20px;align-items:stretch;flex:1;overflow:hidden;min-height:0}.photo-grid-section{flex:2;min-width:0;overflow-y:auto;min-height:0;display:flex;flex-direction:column}.photo-list{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0}.photo-item{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;border:3px solid transparent;width:100%;max-width:300px;flex-shrink:0;margin:0 auto}.photo-item:hover{transform:scale(1.05)}.photo-item.selected{border-color:#3b82f6;box-shadow:0 0 20px #3b82f666}.photo-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:filter .3s}.photo-number{position:absolute;top:10px;left:10px;width:30px;height:30px;background:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.filter-section{background:#fff;padding:25px;border-radius:15px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.filter-section h3{margin-bottom:15px;color:#333;font-size:1.3rem}.filter-button{padding:10px 20px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s;font-size:.95rem}.preview-section{flex:2;min-width:0;background:#f8f9fa;padding:15px;border-radius:15px;box-shadow:0 2px 10px #0000001a;text-align:center;display:flex;flex-direction:column;min-height:0}.preview-section h3{margin-bottom:10px;color:#333;font-size:1rem;font-weight:600}.preview-image-wrapper{width:100%;flex:1;display:flex;justify-content:center;align-items:center;min-height:0}.preview-loading{flex-shrink:0;width:400px;background:#f8f9fa;padding:40px;border-radius:15px;box-shadow:0 2px 10px #0000001a;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}.preview-loading .spinner-small{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.preview-loading p{color:#666;font-size:.95rem}.preview-placeholder{flex-shrink:0;width:400px;background:#f8f9fa;padding:40px;border-radius:15px;box-shadow:0 2px 10px #0000001a;text-align:center;display:flex;align-items:center;justify-content:center;min-height:200px}.preview-placeholder p{color:#999;font-size:.95rem}.action-buttons{display:flex;justify-content:center;gap:10px;margin-top:15px;align-items:center;flex-shrink:0}.prev-area-button{padding:12px 30px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:12px;cursor:pointer;transition:all .3s;height:48px;min-width:120px;box-sizing:border-box}.prev-area-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #ff98004d}.prev-area-button-placeholder{display:none}.next-button{padding:12px 30px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;cursor:pointer;transition:all .3s;height:48px;min-width:120px;box-sizing:border-box}.next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.next-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.select-page{padding:10px;overflow:hidden}.select-container{padding:15px 10px;height:auto;max-height:none;min-height:auto;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:1400px;margin:10px auto}.page-title{font-size:1.3rem;margin-bottom:5px}.page-subtitle{font-size:.85rem;margin-bottom:10px}.select-layout{flex-direction:column;gap:10px}.photo-list{gap:10px}.photo-item{width:100%}.filter-section{padding:15px;margin-bottom:20px}.filter-section h3{font-size:1.1rem;margin-bottom:10px}.filter-buttons{gap:8px}.filter-button{padding:8px 15px;font-size:.85rem}.photo-grid-section{flex:1;order:2;max-height:30vh}.preview-section,.preview-loading,.preview-placeholder{flex:3;width:100%;position:relative;top:0;order:-1;margin-bottom:20px;min-height:0;display:flex;flex-direction:column}.preview-image-wrapper{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.preview-image{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain}.back-button{padding:12px 30px!important;font-size:1rem!important;font-weight:600!important;color:#fff!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important;border:none!important;border-radius:12px!important;cursor:pointer!important;transition:all .3s!important}.back-button:hover{transform:translateY(-2px)!important;box-shadow:0 10px 20px #6b72804d!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important}.action-buttons{margin-top:20px}.complete-button{padding:12px 30px;font-size:1rem;width:100%}}.effect-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;overflow:hidden;position:fixed;inset:0}.effect-container{width:100%;max-width:1200px;background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;margin:20px auto;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto}.page-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:10px;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{text-align:center;color:#666;margin-bottom:30px;font-size:1rem}.effect-layout{display:flex;flex-direction:column;gap:20px;margin-bottom:20px;flex:1;overflow:hidden;min-height:0;align-items:center;justify-content:center}.effect-layout.wide-frame{flex-direction:column;align-items:center;justify-content:center}.effect-layout.tall-frame{flex-direction:row;align-items:center;justify-content:center}.filter-section{background:#f8f9fa;padding:15px;border-radius:15px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.filter-section-horizontal{width:100%;max-width:100%;max-height:200px}.filter-section-vertical{width:250px;max-height:100%;overflow-y:auto;overflow-x:hidden}.filter-section-header{display:flex;align-items:baseline;gap:10px;margin-bottom:15px;flex-wrap:wrap}.filter-section h3{margin:0;color:#333;font-size:1.3rem;font-weight:600}.filter-hint{color:#999;font-size:.85rem;font-weight:400}.filter-buttons{display:flex;gap:8px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#3b82f6 #f0f0f0}.filter-buttons-horizontal{flex-direction:row;flex-wrap:nowrap!important;overflow-x:auto!important;overflow-y:hidden!important;width:100%;justify-content:flex-start;padding:10px 0 15px;gap:8px;white-space:nowrap}.filter-buttons-vertical{flex-direction:column;flex-wrap:nowrap;overflow-x:hidden;overflow-y:auto;width:100%;align-items:center;padding:10px 0;max-height:400px;gap:8px}.filter-buttons-horizontal::-webkit-scrollbar{height:6px}.filter-buttons-horizontal::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.filter-buttons-horizontal::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:3px}.filter-buttons-horizontal::-webkit-scrollbar-thumb:hover{background:#2563eb}.filter-buttons-vertical::-webkit-scrollbar{width:6px}.filter-buttons-vertical::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.filter-buttons-vertical::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:3px}.filter-buttons-vertical::-webkit-scrollbar-thumb:hover{background:#2563eb}.filter-button{padding:8px 16px;font-size:.85rem;font-weight:600;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s;flex-shrink:0!important;white-space:nowrap!important;min-width:-moz-fit-content;min-width:fit-content}.filter-buttons-horizontal .filter-button{min-width:-moz-fit-content;min-width:fit-content;flex:0 0 auto!important}.filter-buttons-vertical .filter-button{width:100%;max-width:200px}.filter-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.preview-section{text-align:center;width:100%;height:auto;min-height:400px;max-height:calc(100vh - 350px);display:flex;flex-direction:column;overflow:hidden;align-items:center;justify-content:center;flex-shrink:0}.effect-layout.wide-frame .preview-section{width:100%;height:auto;max-height:calc(100vh - 350px);flex-shrink:0}.effect-layout.tall-frame .preview-section{width:60%;height:auto;max-width:60%;max-height:calc(100vh - 200px);flex-shrink:0}.preview-section h3{margin-bottom:15px;color:#333;font-size:1.3rem;font-weight:600}.preview-image-wrapper{width:100%;flex:1;min-height:0;display:flex;justify-content:center;align-items:center;overflow:hidden;max-height:calc(100vh - 400px)}.preview-image{max-width:100%;max-height:100%;width:auto;height:auto;border-radius:12px;box-shadow:0 4px 20px #0003;-o-object-fit:contain;object-fit:contain}.preview-loading,.preview-placeholder{text-align:center;padding:50px;color:#666}.spinner-small{width:40px;height:40px;border:4px solid rgba(59,130,246,.3);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 15px}.loading-spinner .spinner{width:60px;height:60px;border:5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.action-buttons{display:flex;gap:15px;justify-content:center;flex-shrink:0}.complete-button,.back-button{padding:15px 40px;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s}.complete-button{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb)}.complete-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.complete-button:disabled{opacity:.6;cursor:not-allowed}.back-button{color:#fff!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important;border:none!important}@media(max-width:768px){.effect-page{padding:10px;overflow:hidden}.effect-container{padding:15px 10px;height:auto;max-height:none;min-height:auto;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:1200px;margin:10px auto}.page-title{font-size:1.4rem;margin-bottom:5px}.page-subtitle{font-size:.85rem;margin-bottom:10px}.effect-layout{flex-direction:column;gap:10px;margin-bottom:10px;flex:1;min-height:0;overflow:hidden;align-items:center;justify-content:center}.effect-layout.wide-frame,.effect-layout.tall-frame{flex-direction:column}.filter-section{padding:15px 10px;flex-shrink:0;width:100%}.filter-section-horizontal,.filter-section-vertical{width:100%;max-width:100%;max-height:none}.filter-section-header{margin-bottom:10px}.filter-section h3{font-size:1.1rem}.filter-hint{font-size:.75rem}.filter-buttons{gap:8px;-webkit-overflow-scrolling:touch}.filter-buttons-horizontal,.filter-buttons-vertical{flex-direction:row!important;flex-wrap:nowrap!important;overflow-x:auto!important;overflow-y:hidden!important;width:100%;justify-content:flex-start;padding:10px 0 15px;min-height:50px}.filter-button{padding:8px 12px;font-size:.8rem;flex-shrink:0;white-space:nowrap;min-width:-moz-fit-content;min-width:fit-content}.preview-section{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;width:100%;max-width:100%;align-items:center;justify-content:center}.effect-layout.wide-frame .preview-section,.effect-layout.tall-frame .preview-section{width:100%;max-width:100%}.preview-section h3{font-size:1rem;margin-bottom:10px;flex-shrink:0}.preview-image-wrapper{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.preview-image{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain}.preview-loading,.preview-placeholder{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:20px}.action-buttons{flex-direction:column;gap:10px;flex-shrink:0}.complete-button,.back-button{width:100%;padding:12px 20px;font-size:.95rem}}@media(max-width:480px){.effect-container{padding:10px 8px;max-height:calc(100vh - 20px)}.page-title{font-size:1.2rem;margin-bottom:5px}.page-subtitle{font-size:.75rem;margin-bottom:8px}.filter-section{padding:12px 8px}.filter-button{padding:6px 10px;font-size:.75rem}.preview-section h3{font-size:.9rem;margin-bottom:8px}}.result-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;position:relative;overflow-y:auto;overflow-x:hidden}.result-container{width:100%;max-width:600px;background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;box-sizing:border-box;margin:20px auto;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto}.result-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:30px;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.result-image-wrapper{width:100%;margin-bottom:15px;border-radius:15px;overflow:hidden;box-shadow:0 10px 30px #0003;flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.result-image-wrapper img{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.result-image{width:100%;height:auto;display:block}.security-notice{background:#fff3cd;border:2px solid #ffc107;border-radius:10px;padding:10px;margin-bottom:15px;text-align:center;flex-shrink:0}.security-notice p{color:#856404;font-size:.95rem;margin:0;font-weight:500}.qr-section{text-align:center;margin-bottom:15px;padding:15px;background:#f8f9fa;border-radius:15px;flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center}.qr-section h3{margin-bottom:15px;color:#333;font-size:1.3rem}.qr-code{width:200px;height:200px;margin:0 auto 10px;border-radius:10px;padding:10px;background:#fff;box-shadow:0 4px 10px #0000001a;flex-shrink:0}.qr-description{color:#666;font-size:.9rem;margin:0}.action-buttons{display:flex;gap:15px;margin-top:auto;padding-top:10px;justify-content:center;align-items:center;flex-shrink:0}.download-button,.home-button{flex:1;padding:15px;font-size:1.1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;height:50px;display:flex;align-items:center;justify-content:center}.download-button,.next-button{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb)}.download-button:hover,.next-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.home-button{color:#3b82f6;background:#fff;border:2px solid #3b82f6}.home-button:hover{background:#f0f0f0;transform:translateY(-2px)}.next-button{max-width:300px;width:100%}@media(max-width:768px){.result-page{padding:10px;overflow:hidden}.result-container{padding:15px 10px;height:auto;max-height:none;min-height:auto;margin:10px auto;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0;width:100%;max-width:600px;flex-shrink:0}.result-title{font-size:1.4rem;margin-bottom:10px}.result-image-wrapper{margin-bottom:10px}.security-notice{padding:8px;margin-bottom:10px}.security-notice p{font-size:.8rem;margin:0}.qr-section{padding:10px;margin-bottom:10px}.qr-section h3{font-size:1rem;margin-bottom:8px}.qr-code{width:150px;height:150px;padding:8px}.qr-description{font-size:.8rem;margin:0}.action-buttons{flex-direction:column;gap:10px;align-items:center}.download-button,.next-button,.home-button{width:100%;max-width:300px;padding:12px;font-size:.95rem}}.paused-ip-page{width:100%;height:100vh;background:linear-gradient(135deg,#dc3545,#c82333);display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;overflow:hidden;position:fixed;inset:0}.paused-container{width:100%;max-width:500px;background:#fff;border-radius:20px;padding:60px 40px;box-shadow:0 20px 60px #0000004d;text-align:center;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.paused-title{font-size:2rem;font-weight:700;color:#dc3545;margin-bottom:20px}.paused-message{font-size:1.1rem;color:#666;line-height:1.6;margin-bottom:40px}.paused-buttons{display:flex;flex-direction:column;gap:15px;width:100%}.paused-button{padding:15px 40px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:12px;cursor:pointer;transition:all .3s;width:100%}.paused-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #dc35454d}.paused-button:disabled{opacity:.6;cursor:not-allowed}.request-button{background:linear-gradient(135deg,#14b8a6,#0d9488)}.request-button:hover:not(:disabled){box-shadow:0 10px 20px #14b8a64d}@media(max-width:768px){.paused-ip-page{overflow:hidden}.paused-container{padding:40px 30px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:500px;margin:10px auto}.paused-title{font-size:1.5rem}.paused-message{font-size:1rem}}.photo-view-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:flex-start;padding:20px;box-sizing:border-box;position:relative;overflow-y:auto;overflow-x:hidden}.photo-view-container{background:#fff;border-radius:20px;padding:40px;max-width:800px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;height:auto;max-height:none;min-height:auto;margin:20px auto}.photo-title{font-size:2rem;color:#333;margin-bottom:15px;font-weight:700;flex-shrink:0}.photo-wrapper{margin:15px 0;border-radius:10px;overflow:hidden;box-shadow:0 10px 30px #0003;flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.photo-wrapper img{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.photo-image{width:100%;height:auto;display:block}.loading-section{padding:60px 20px}.loading-section .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-section p{color:#666;font-size:1.1rem}.expired-title,.error-title{font-size:2rem;color:#d32f2f;margin-bottom:20px;font-weight:700}.expired-message,.error-message{font-size:1.2rem;color:#666;margin-bottom:30px;line-height:1.6}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:15px;flex-wrap:wrap;flex-shrink:0}.download-button,.back-button{padding:15px 30px;font-size:1.1rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease;min-width:150px}.download-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.download-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.back-button{background:linear-gradient(135deg,#6b7280,#4b5563)!important;color:#fff!important}@media(max-width:768px){.photo-view-page{padding:10px;overflow:hidden}.photo-view-container{padding:15px 10px;height:auto;max-height:none;min-height:auto;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:800px;margin:10px auto;flex-shrink:0}.photo-title{font-size:1.3rem;margin-bottom:10px}.photo-wrapper{margin:10px 0}.expired-title,.error-title{font-size:1.3rem;margin-bottom:10px}.expired-message,.error-message{font-size:.9rem;margin-bottom:15px}.loading-section{padding:30px 15px}.loading-section .spinner{width:40px;height:40px;margin-bottom:15px}.loading-section p{font-size:.95rem}.action-buttons{flex-direction:row;gap:10px;margin-top:10px}.download-button,.back-button{flex:1;padding:12px;font-size:.95rem;min-width:auto}}.photo-expired-page{width:100%;height:100vh;max-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box;overflow:hidden;position:fixed;inset:0}.photo-expired-container{background:#fff;border-radius:20px;padding:40px;max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box;height:auto;max-height:none;min-height:auto;margin:20px auto}.expired-title{font-size:2rem;color:#d32f2f;margin-bottom:15px;font-weight:700;flex-shrink:0}.expired-message{font-size:1.2rem;color:#666;margin-bottom:20px;line-height:1.6;flex-shrink:0}.back-button{padding:15px 30px;font-size:1.1rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-width:150px;flex-shrink:0}.back-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}@media(max-width:768px){.photo-expired-page{padding:10px;overflow:hidden}.photo-expired-container{padding:20px 15px;height:auto;max-height:none;min-height:auto;gap:15px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:600px;margin:10px auto}.expired-title{font-size:1.3rem;margin-bottom:10px}.expired-message{font-size:.9rem;margin-bottom:15px}.back-button{width:100%;padding:12px;font-size:.95rem}}.group-select-page{min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;padding:20px;position:fixed;width:100%;height:100vh;overflow:hidden}.group-select-container{background:#fff;border-radius:20px;padding:40px;max-width:800px;width:100%;box-shadow:0 20px 60px #0000004d;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.page-title{text-align:center;color:#333;margin-bottom:10px;font-size:2rem;font-weight:700}.page-description{text-align:center;color:#666;margin-bottom:30px;font-size:1rem}.no-groups{text-align:center;padding:40px;color:#666}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px;margin-bottom:30px;margin-top:20px;max-height:400px;overflow-y:auto;padding-right:10px;padding-top:15px}.group-card{background:#f8f9fa;border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s;border:2px solid transparent}.group-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000001a;border-color:#3b82f6}.group-logo{width:100px;height:100px;-o-object-fit:contain;object-fit:contain;border-radius:8px;margin:0 auto 15px;display:block}.group-logo-placeholder{width:100px;height:100px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;margin:0 auto 15px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;font-weight:700}.group-name{font-size:1.1rem;font-weight:600;color:#333;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;word-break:break-word;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:normal}.back-button{width:100%!important;padding:14px!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important;color:#fff!important;border:none!important;border-radius:10px!important;font-size:1rem!important;font-weight:600!important;cursor:pointer!important;transition:all .3s!important;margin-top:20px!important}@media(max-width:768px){.group-select-page{overflow:hidden}.group-select-container{padding:20px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;margin:10px auto;max-width:800px;flex-shrink:0}.groups-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px}.group-logo,.group-logo-placeholder{width:80px;height:80px}}.group-code-input-page{min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;padding:20px;position:fixed;width:100%;height:100vh;overflow:hidden}.code-input-container{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.group-logo-section{text-align:center;margin-bottom:20px}.group-logo{max-width:150px;max-height:150px;-o-object-fit:contain;object-fit:contain;border-radius:8px}.group-name{text-align:center;color:#333;margin-bottom:30px;font-size:2rem;font-weight:700}.code-form{margin-bottom:30px}.form-group label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:.95rem}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{border-color:#3b82f6}.error-message{padding:12px;background-color:#fee;color:#c33;border-radius:8px;text-align:center;font-size:.9rem;margin-bottom:20px}.submit-button{width:100%;padding:14px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:10px}.manager-info{text-align:center;padding:20px;background:#f8f9fa;border-radius:8px;margin-bottom:20px}.manager-label{font-size:.85rem;color:#666;margin:0 0 5px}.manager-email{font-size:1rem;color:#333;font-weight:600;margin:0}.back-button{width:100%!important;padding:12px!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important;color:#fff!important;border:none!important;border-radius:10px!important;font-size:1rem!important;font-weight:600!important;cursor:pointer!important;transition:all .3s!important}.back-button:hover{transform:translateY(-2px)!important;box-shadow:0 10px 20px #6b72804d!important;background:linear-gradient(135deg,#6b7280,#4b5563)!important}.loading{text-align:center;padding:50px;font-size:1.2rem;color:#fff}@media(max-width:768px){.group-code-input-page{overflow:hidden}.code-input-container{padding:20px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:500px;margin:10px auto}.group-logo{max-width:120px;max-height:120px}.group-name{font-size:1.5rem}}.mobile-test-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;align-items:flex-start;justify-content:center}.test-container{max-width:1200px;width:100%;margin:20px auto;background:#fff;border-radius:20px;padding:30px;box-shadow:0 20px 60px #0000004d;overflow-y:auto;overflow-x:hidden}.mobile-test-page h1{font-size:2rem;font-weight:700;margin-bottom:20px;text-align:center;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.main-nav-button-container{display:flex;justify-content:center;margin-bottom:30px}.main-nav-button{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;cursor:pointer;transition:all .3s}.test-section{margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid #e5e7eb}.test-section:last-child{border-bottom:none}.test-section h2{font-size:1.5rem;font-weight:600;margin-bottom:20px;color:#1f2937}.control-group{margin-bottom:20px}.control-group label{display:block;font-weight:600;margin-bottom:8px;color:#374151}.control-group select,.control-group input[type=number]{width:100%;padding:10px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;box-sizing:border-box}.control-group select:focus,.control-group input[type=number]:focus{outline:none;border-color:#3b82f6}.resolution-controls{display:grid;grid-template-columns:1fr 1fr;gap:10px}.resolution-controls>div{display:flex;flex-direction:column;gap:5px}.resolution-controls label{font-size:.9rem;font-weight:500}.aspect-ratio-buttons{display:flex;gap:10px;flex-wrap:wrap}.aspect-ratio-buttons button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.aspect-ratio-buttons button:hover{background:#2563eb;transform:translateY(-2px)}.camera-preview-wrapper{width:100%;max-width:100%;background:#000;border-radius:12px;overflow:hidden;margin-bottom:20px;position:relative}.test-webcam{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.info-display{background:#f9fafb;padding:20px;border-radius:12px;border:2px solid #e5e7eb}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e5e7eb}.info-item:last-child{border-bottom:none}.info-label{font-weight:600;color:#6b7280}.info-value{font-weight:700;color:#1f2937;text-align:right;word-break:break-all}.capture-button{width:100%;padding:18px;font-size:1.2rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s;display:block;margin:0 auto;min-height:60px}.capture-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.capture-button:active{transform:translateY(0);box-shadow:0 5px 10px #667eea4d}.captured-image-wrapper{width:100%;max-width:100%;background:#f9fafb;border-radius:12px;padding:20px;border:2px solid #e5e7eb;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.captured-image{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a}.console-log{background:#1f2937;color:#f9fafb;padding:20px;border-radius:12px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.6}.console-log p{margin:0 0 10px}.console-log p:last-child{margin-bottom:0}@media(max-width:768px){.mobile-test-page{padding:10px;align-items:flex-start}.test-container{padding:20px;margin:10px auto;width:100%;max-width:1200px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.mobile-test-page h1{font-size:1.5rem}.test-section h2{font-size:1.2rem}.resolution-controls{grid-template-columns:1fr}.aspect-ratio-buttons{grid-template-columns:repeat(2,1fr)}.aspect-ratio-buttons button{width:100%}.info-item{flex-direction:column;align-items:flex-start;gap:5px}.info-value{text-align:left}}.manual-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;align-items:flex-start;justify-content:center}.manual-container{max-width:900px;width:100%;margin:20px auto;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.manual-header{display:flex;flex-direction:column;gap:15px;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}.manual-header .back-button{align-self:flex-start}.manual-header .back-button{background:none;border:none;color:#3b82f6;font-size:1rem;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .3s;font-weight:600}.manual-header .back-button:hover{background:#f0f0f0}.manual-title{font-size:2.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex:1;min-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.error-message{background:#fee;color:#dc3545;padding:15px;border-radius:8px;margin-bottom:20px;font-weight:600}.manual-content{line-height:1.8;color:#333;overflow-y:auto;overflow-x:hidden;max-height:calc(100vh - 200px);padding-right:10px;width:100%;box-sizing:border-box;word-wrap:break-word}.manual-content::-webkit-scrollbar{width:8px}.manual-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.manual-content::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.manual-content::-webkit-scrollbar-thumb:hover{background:#555}.manual-content h1{font-size:2.5rem;font-weight:700;margin:30px 0 20px;color:#1f2937;border-bottom:3px solid #3b82f6;padding-bottom:10px}.manual-content h2{font-size:2rem;font-weight:600;margin:25px 0 15px;color:#374151}.manual-content h3{font-size:1.5rem;font-weight:600;margin:20px 0 12px;color:#4b5563}.manual-content h4{font-size:1.25rem;font-weight:600;margin:15px 0 10px;color:#6b7280}.manual-content p{margin:15px 0;font-size:1.1rem}.manual-content ul,.manual-content ol{margin:15px 0;padding-left:30px}.manual-content li{margin:8px 0;font-size:1.1rem}.manual-content strong{font-weight:700;color:#1f2937}.manual-content em{font-style:italic;color:#4b5563}.markdown-inline-code{background:#f3f4f6;color:#dc2626;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.9em}.code-block-wrapper{margin:20px 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.code-block-header{display:flex;justify-content:space-between;align-items:center;background:#374151;padding:8px 15px;border-bottom:1px solid #4b5563}.code-block-label{color:#9ca3af;font-size:.85rem;font-weight:600}.code-copy-button{background:#3b82f6;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s}.code-copy-button:hover{background:#2563eb;transform:translateY(-1px)}.markdown-code-block{background:#1f2937;color:#f9fafb;padding:20px;overflow-x:auto;margin:0;border-radius:0}.markdown-code-block code{font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;color:inherit;background:transparent;padding:0}.markdown-blockquote{border-left:4px solid #3b82f6;margin:20px 0;color:#6b7280;font-style:italic;background:#f9fafb;padding:15px 20px;border-radius:4px}.markdown-divider{border:none;border-top:2px solid #e5e7eb;margin:30px 0}.markdown-image-wrapper{margin:25px 0;text-align:center;width:100%;box-sizing:border-box;overflow-x:hidden}.markdown-image-wrapper img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a;display:block;margin:0 auto}.mui-icon-inline{display:inline-flex;align-items:center;vertical-align:middle;color:#374151;margin:0 4px}.markdown-table-wrapper{overflow-x:auto;margin:20px 0;width:100%;box-sizing:border-box}.markdown-table-wrapper table{width:100%;max-width:100%;border-collapse:collapse;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-sizing:border-box}.markdown-table-wrapper th{background:#3b82f6;color:#fff;padding:12px;text-align:left;font-weight:600}.markdown-table-wrapper td{padding:12px;border-top:1px solid #e5e7eb}.markdown-table-wrapper tr:nth-child(2n){background:#f9fafb}.markdown-table-wrapper tr:hover{background:#f3f4f6}.link-embed{margin:25px 0;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.youtube-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden}.youtube-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%}.twitter-embed{max-width:100%}.link-preview{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .3s}.link-preview:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-2px)}.link-preview-content{display:flex;text-decoration:none;color:inherit}.link-preview-image{width:200px;height:150px;flex-shrink:0;overflow:hidden;background:#f3f4f6}.link-preview-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.link-preview-text{flex:1;padding:20px;display:flex;flex-direction:column;justify-content:space-between}.link-preview-title{font-size:1.2rem;font-weight:600;color:#1f2937;margin-bottom:8px}.link-preview-description{font-size:.95rem;color:#6b7280;margin-bottom:8px;line-height:1.5}.link-preview-url{font-size:.85rem;color:#9ca3af}.external-link{color:#3b82f6;text-decoration:none;font-weight:500;border-bottom:1px solid #3b82f6;transition:all .3s}.external-link:hover{color:#2563eb;border-bottom-color:#2563eb}.link-embed-loading{padding:20px;text-align:center;color:#6b7280}.link-embed-loading a{color:#3b82f6;text-decoration:none}@media(max-width:768px){.manual-page{padding:10px;overflow:hidden}.manual-container{padding:20px;height:auto;max-height:none;min-height:auto;border-radius:15px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:900px;margin:10px auto}.manual-header{flex-direction:row;align-items:center;gap:15px;padding-bottom:15px;margin-bottom:20px}.manual-title{font-size:1.5rem;flex:1;white-space:normal;word-break:keep-all;line-height:1.3}.manual-content{font-size:1rem;padding-right:5px}.manual-content h1{font-size:1.8rem;margin:20px 0 15px}.manual-content h2{font-size:1.5rem;margin:20px 0 12px}.manual-content h3{font-size:1.25rem;margin:15px 0 10px}.manual-content p{font-size:1rem;margin:12px 0}.manual-content ul,.manual-content ol{padding-left:25px}.manual-content li{font-size:1rem;margin:6px 0}.markdown-table-wrapper{overflow-x:scroll;-webkit-overflow-scrolling:touch}.markdown-table-wrapper table{min-width:500px}.link-preview-content{flex-direction:column}.link-preview-image{width:100%;height:200px}.youtube-embed iframe{min-height:250px}}.manual-editor-page{width:100%;height:calc(100vh - 80px);background:#f5f5f5;padding:20px;box-sizing:border-box;overflow-x:hidden;overflow-y:hidden;display:flex;flex-direction:column}.manual-editor-container{max-width:1200px;width:100%;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-height:100%}.manual-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e5e7eb;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;width:100%;box-sizing:border-box;flex-wrap:wrap;gap:15px;position:sticky;top:0;z-index:100}.mode-buttons-row{display:flex;gap:10px;align-items:center}.manual-editor-title{font-size:1.8rem;font-weight:700;margin:0}.manual-editor-actions{display:flex;gap:10px;align-items:center}.mode-button{padding:8px 16px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.mode-button:hover{background:#ffffff4d}.mode-button.active{background:#fff;color:#3b82f6;border-color:#fff}.save-button{padding:8px 20px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s;box-shadow:0 2px 4px #14b8a64d}.save-button:hover:not(:disabled){background:linear-gradient(135deg,#0d9488,#0f766e);transform:translateY(-2px);box-shadow:0 4px 8px #14b8a666}.back-button{padding:8px 16px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.back-button:hover{background:#ffffff4d}.editor-toolbar{display:flex;gap:15px;padding:15px 30px;background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;align-items:center;width:100%;box-sizing:border-box;overflow-x:auto;overflow-y:visible;position:relative;z-index:50;height:auto;min-height:-moz-fit-content;min-height:fit-content}.toolbar-group{display:flex;gap:5px;padding-right:15px;border-right:1px solid #e5e7eb}.toolbar-group:last-child{border-right:none}.toolbar-tooltip-wrapper{position:relative;display:inline-block;overflow:visible;z-index:10001}.toolbar-button{padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s;font-weight:600;position:relative}.toolbar-button:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.toolbar-tooltip{visibility:hidden;opacity:0;background-color:#1f2937;color:#fff;text-align:center;padding:8px 12px;border-radius:6px;position:fixed;z-index:100000;white-space:nowrap;font-size:.85rem;font-weight:500;box-shadow:0 4px 12px #0003;transition:opacity .3s,visibility .3s;pointer-events:none;margin-top:-5px}.toolbar-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1f2937}.toolbar-tooltip-wrapper:hover .toolbar-tooltip{visibility:visible!important;opacity:1!important}.image-upload-button{cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.template-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed)!important;color:#fff!important;border-color:#8b5cf6!important}.template-button:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9)!important;transform:translateY(-2px)!important;box-shadow:0 4px 12px #8b5cf666!important}.template-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.template-modal-content{background:#fff;border-radius:16px;padding:30px;max-width:800px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.template-header h3{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.template-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.template-close:hover{background:#f3f4f6;color:#dc3545}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px}.template-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s;text-align:center}.template-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026;border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.template-icon{font-size:3rem;margin-bottom:12px}.template-title{font-size:1.1rem;font-weight:700;color:#1f2937;margin-bottom:8px}.template-desc{font-size:.85rem;color:#6b7280;line-height:1.4}.editor-content{min-height:600px;position:relative;width:100%;box-sizing:border-box;overflow-x:hidden;display:flex;flex-direction:column}.editor-content.split-view{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:calc(100vh - 300px);max-height:calc(100vh - 250px);border-top:1px solid #e5e7eb;overflow:hidden}.editor-content.single-view{display:flex;flex-direction:column}.editor-panel,.preview-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;border-right:1px solid #e5e7eb}.preview-panel{border-right:none;border-left:1px solid #e5e7eb}.panel-header{padding:12px 20px;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;flex-shrink:0}.panel-title{font-size:.95rem;font-weight:600;color:#374151}.editor-panel .editor-wrapper{flex:1;overflow:hidden;display:flex;flex-direction:column}.editor-panel .editor-textarea{flex:1;min-height:auto;height:100%;padding:20px;border:none;resize:none;overflow-y:auto;-webkit-overflow-scrolling:touch}.preview-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;min-height:0;-webkit-overflow-scrolling:touch}.editor-textarea{overflow-y:auto;-webkit-overflow-scrolling:touch}.editor-wrapper{position:relative;width:100%;height:100%}.editor-textarea{width:100%;min-height:600px;padding:30px;border:none;outline:none;font-family:Courier New,monospace;font-size:1rem;line-height:1.8;resize:vertical;box-sizing:border-box;max-width:100%;overflow-x:auto;word-wrap:break-word;background:#fafafa;border-top:1px solid #e5e7eb;transition:background .3s}.editor-textarea:focus{background:#fff;box-shadow:inset 0 0 0 2px #3b82f6}.editor-hint{position:absolute;bottom:15px;left:30px;right:30px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:12px 16px;font-size:.9rem;color:#1e40af;display:flex;align-items:center;gap:8px;box-shadow:0 2px 8px #3b82f61a}.editor-hint strong{font-weight:600}.preview-content{line-height:1.8;color:#333;word-wrap:break-word}.preview-content h1{font-size:2rem;font-weight:700;margin:20px 0 15px;color:#1f2937;border-bottom:3px solid #3b82f6;padding-bottom:8px}.preview-content h2{font-size:1.6rem;font-weight:600;margin:18px 0 12px;color:#374151}.preview-content h3{font-size:1.3rem;font-weight:600;margin:15px 0 10px;color:#4b5563}.preview-content p{margin:12px 0;font-size:1rem}.preview-content ul,.preview-content ol{margin:12px 0;padding-left:25px}.preview-content li{margin:6px 0;font-size:1rem}.preview-content code{background:#f3f4f6;color:#dc2626;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.9em}.preview-content pre{background:#1f2937;color:#f9fafb;padding:15px;border-radius:8px;overflow-x:auto;margin:15px 0}.preview-content pre code{background:transparent;color:inherit;padding:0}.preview-content blockquote{border-left:4px solid #3b82f6;padding:12px 16px;margin:15px 0;color:#6b7280;font-style:italic;background:#f9fafb;border-radius:4px}.preview-content hr{border:none;border-top:2px solid #e5e7eb;margin:20px 0}.preview-content img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a;margin:15px 0}.preview-content table{width:100%;border-collapse:collapse;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;margin:15px 0}.preview-content th{background:#3b82f6;color:#fff;padding:10px;text-align:left;font-weight:600;font-size:.9rem}.preview-content td{padding:10px;border-top:1px solid #e5e7eb;font-size:.9rem}.preview-content tr:nth-child(2n){background:#f9fafb}.preview-content a{color:#3b82f6;text-decoration:none;font-weight:500;border-bottom:1px solid #3b82f6}.preview-content a:hover{color:#2563eb;border-bottom-color:#2563eb}.editor-help{padding:20px 30px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-top:2px solid #0ea5e9}.editor-help h3{font-size:1.2rem;font-weight:700;margin-bottom:15px;color:#0c4a6e;display:flex;align-items:center;gap:8px}.editor-help h3:before{content:"📚";font-size:1.3rem}.editor-help ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.editor-help li{font-size:.9rem;color:#075985;padding:12px;background:#fff;border-radius:8px;border:1px solid #bae6fd;box-shadow:0 2px 4px #0ea5e91a;transition:all .3s}.editor-help li:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0ea5e933;border-color:#0ea5e9}.editor-help code{background:#fef3c7;color:#92400e;padding:3px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;font-weight:600;border:1px solid #fde68a}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@media(max-width:768px){.manual-editor-page{padding:10px}.manual-editor-container{padding:0;border-radius:0}.manual-editor-header{flex-direction:column;gap:15px;align-items:flex-start;padding:15px 20px}.manual-editor-title{font-size:1.5rem}.manual-editor-actions{width:100%;flex-wrap:wrap;gap:8px}.mode-button,.save-button,.back-button{font-size:.9rem;padding:6px 12px}.editor-toolbar{padding:10px 15px;gap:10px}.toolbar-group{padding-right:10px;margin-bottom:10px}.toolbar-button{padding:6px 10px;font-size:.85rem}.template-button{font-size:.8rem;padding:6px 10px}.editor-content.split-view{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.editor-panel,.preview-panel{border-right:none;border-left:none;border-bottom:1px solid #e5e7eb}.preview-panel{border-bottom:none}.editor-textarea{padding:15px;font-size:.9rem;min-height:300px}.preview-content{padding:15px;font-size:.9rem}.editor-hint{position:relative;bottom:auto;left:auto;right:auto;margin-top:10px;margin-left:15px;margin-right:15px}.editor-help{padding:15px 20px}.editor-help ul{grid-template-columns:1fr}.template-modal{padding:10px}.template-modal-content{padding:20px;max-height:90vh}.template-grid{grid-template-columns:1fr;gap:15px}.template-card{padding:15px}.template-icon{font-size:2.5rem}}.emoji-picker-popup,.icon-picker-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;z-index:10001;max-width:500px;width:90%;max-height:70vh;display:flex;flex-direction:column}.emoji-picker-header,.icon-picker-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:1.1rem}.close-picker{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-picker:hover{background:#f3f4f6;color:#1f2937}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;padding:15px;overflow-y:auto;max-height:calc(70vh - 60px)}.emoji-item{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:10px;cursor:pointer;font-size:1.5rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-item:hover{background:#f3f4f6;border-color:#3b82f6;transform:scale(1.1)}.icon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:15px;overflow-y:auto;max-height:calc(70vh - 60px)}.icon-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;cursor:pointer;font-size:.9rem;transition:all .2s;text-align:center;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:8px}.icon-item .icon-name{font-size:.75rem;color:#6b7280}.icon-item:hover{background:#f3f4f6;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f633}.mui-icon-inline{display:inline-flex;align-items:center;vertical-align:middle;color:#374151}@media(max-width:768px){.toolbar-tooltip{display:none}}.dashboard-page{width:100%}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:16px;transition:all .3s;border:1px solid #e5e7eb}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border-radius:12px;flex-shrink:0;color:#fff!important}.stat-icon svg{font-size:2rem;color:#fff!important;fill:#fff!important}.stat-value{font-size:2rem;font-weight:700;color:#14b8a6!important;line-height:1}.quick-actions{margin-top:40px}.section-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 20px}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.action-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .3s;border:1px solid #e5e7eb;text-align:center}.action-card:hover{box-shadow:0 4px 12px #3b82f633;transform:translateY(-4px);border-color:#14b8a6}.action-icon{margin-bottom:12px;display:flex;align-items:center;justify-content:center;color:#14b8a6}.action-icon svg{font-size:3rem}.action-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:8px}.action-desc{font-size:.85rem;color:#6b7280}@media(max-width:768px){.stats-grid,.action-cards{grid-template-columns:1fr}.request-item{flex-direction:column;align-items:flex-start;gap:15px}.request-actions{width:100%;justify-content:flex-end}}.code-management,.code-container{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.code-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:20px}.create-button{background:linear-gradient(135deg,#10b981,#059669)}.create-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #10b9814d}.bulk-create-button{background:linear-gradient(135deg,#14b8a6,#0d9488)}.bulk-create-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.sort-button:hover{color:#14b8a6}.form-group input:focus{outline:none;border-color:#14b8a6}.check-duplicate-button{padding:12px 20px;font-size:.95rem;font-weight:600;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}.detail-item input:focus{outline:none;border-color:#14b8a6}.photos-list{display:flex;flex-wrap:wrap;gap:15px;max-height:500px;min-height:150px;overflow-y:auto;align-items:flex-start}.photo-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#f8f9fa;display:flex;flex-direction:column}.photo-thumbnail{display:block;-o-object-fit:contain;object-fit:contain;background:#f0f0f0}.photo-link{color:#14b8a6;text-decoration:none;font-size:.85rem}.log-action-code_input,.log-action-code_reaccess,.log-action-frame_selected,.log-action-photo_captured{background:#14b8a6}.frame-select-dropdown:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #3b82f61a}.frame-preview-item{position:relative;border:2px solid #14b8a6;border-radius:12px;overflow:hidden;background:#f8f9fa;padding:15px;display:flex;flex-direction:column;align-items:center;gap:10px}.close-button{padding:10px 20px;font-size:1rem;font-weight:600;background:#14b8a6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.close-button:hover{background:#0d9488}.frame-editor-new{width:100%;min-height:100vh;padding:20px;overflow-x:hidden;background:transparent;display:flex;flex-direction:column}.help-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#14b8a6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s}.help-button:hover{background:#0d9488;transform:translateY(-2px)}.help-step{padding:20px;background:#f8f9fa;border-radius:10px;border-left:4px solid #14b8a6}.step.active .step-number{background:#14b8a6;color:#fff;transform:scale(1.1)}.step.active .step-label{color:#14b8a6}.grid-icon,.draw-icon{font-size:40px!important;color:#14b8a6;margin-bottom:15px}.grid-input:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #3b82f61a}.selected-area-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:15px;background:#fff;border-radius:10px;font-weight:700;color:#14b8a6;font-size:1.1rem}.action-button{padding:12px 20px;font-size:.95rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;background:#14b8a6;color:#fff}.area-card.selected{border-color:#14b8a6;box-shadow:0 0 0 3px #3b82f633}.frame-name-input:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.frame-card:hover{border-color:#14b8a6;box-shadow:0 4px 12px #3b82f633}.frame-card.selected{border-color:#14b8a6;background:#dbeafe}.tool-button:hover{border-color:#14b8a6;background:#eff6ff;transform:translateY(-2px)}.tool-button.same-size{background:#eff6ff;border-color:#14b8a6;color:#14b8a6}.area-item-compact.selected{border-color:#14b8a6;box-shadow:0 0 0 3px #3b82f633}.modal-save-button{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}.big-edit-button{padding:20px 50px;font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:15px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px #3b82f64d}.areas-summary{padding:15px 30px;background:#eff6ff;border-radius:10px;border:2px solid #14b8a6}.create-frame-button{padding:12px 24px;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px}.create-frame-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #14b8a64d}.nav-button.next{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;margin-left:auto}.nav-button.next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #14b8a64d}.filter-button:hover{border-color:#14b8a6;color:#14b8a6}.filter-button.active{background:#14b8a6;color:#fff;border-color:#14b8a6}.logs-table table th,.logs-table table td{white-space:nowrap;min-width:-moz-fit-content;min-width:fit-content}.logs-table th{padding:15px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;position:sticky;top:0;background:#f8f9fa;z-index:10}.logs-table th .sort-button:hover{color:#14b8a6}.logs-table td{padding:15px;border-bottom:1px solid #f0f0f0;text-align:center}.setup-admin-page{width:100%}.setup-container{max-width:600px;margin:0 auto;background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.page-title{font-size:2rem;font-weight:700;margin:0;color:#1f2937}.admin-info{background:#f8f9fa;padding:20px;border-radius:10px;margin-bottom:30px}.admin-info p{margin:10px 0;font-size:1.1rem;color:#333}.setup-button{width:100%;padding:15px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:10px;cursor:pointer;transition:all .3s}.setup-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.setup-button:disabled{opacity:.6;cursor:not-allowed}.result-message{margin-top:20px;padding:20px;border-radius:10px;font-size:1rem}.result-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.result-message.info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.result-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.result-details{margin-top:15px;padding:15px;background:#ffffff80;border-radius:8px}.result-details pre{margin:10px 0 0;font-size:.9rem;overflow-x:auto}.doc-id{margin-top:10px;font-size:.9rem;font-family:monospace;color:#666}.create-system-admin-page{width:100%}.create-container{max-width:600px;margin:0 auto;background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.page-title{font-size:2rem;font-weight:700;margin:0 0 8px;color:#1f2937}.page-description{color:#6b7280;font-size:.95rem;margin:0 0 15px;line-height:1.6}.info-box{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px 15px;font-size:.85rem;color:#856404;line-height:1.5;margin-top:15px}.create-form{display:flex;flex-direction:column;gap:20px}.result-message{padding:15px;border-radius:8px;font-size:.95rem}.result-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.result-message.warning{background-color:#fff3cd;color:#856404;border:1px solid #ffc107}.result-details{margin-top:10px;font-size:.9rem;opacity:.8}.create-button{width:100%;padding:15px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;cursor:pointer;transition:all .3s;margin-top:10px}.create-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #10b9814d}.create-button:disabled{opacity:.6;cursor:not-allowed}.super-admin-list-page,.super-admin-container{width:100%}.super-admin-table{background:#fff;border-radius:12px;overflow-x:auto;overflow-y:visible;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;-webkit-overflow-scrolling:touch}.super-admin-table table{width:100%;min-width:100%;border-collapse:collapse;table-layout:auto}.super-admin-table thead{background:#f8f9fa}.super-admin-table th{padding:15px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.super-admin-table td{padding:15px;border-bottom:1px solid #f0f0f0;text-align:center;white-space:nowrap}.super-admin-table tbody tr:hover{background:#f8f9fa}.edit-input{padding:8px 12px;border:2px solid #14b8a6;border-radius:6px;font-size:.95rem;width:100%;max-width:300px}.edit-input:focus{outline:none;border-color:#0d9488;box-shadow:0 0 0 3px #14b8a61a}.uid-code{font-family:Courier New,monospace;font-size:.85rem;background:#f3f4f6;padding:4px 8px;border-radius:4px;color:#6b7280}.action-buttons{display:flex;flex-direction:column;gap:10px;align-items:stretch;min-width:200px}.action-buttons-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.edit-button,.save-button,.cancel-button,.reset-password-button,.delete-button{padding:10px 16px;font-size:.9rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s;font-weight:600;display:flex;align-items:center;justify-content:center;min-height:40px;white-space:nowrap}.cancel-button{background:#6b7280;color:#fff}.cancel-button:hover{background:#4b5563}.reset-password-button{background:#f59e0b;color:#fff}.reset-password-button:hover:not(:disabled){background:#d97706}.reset-password-button:disabled{opacity:.5;cursor:not-allowed}.delete-button{background:#dc3545;color:#fff;width:100%;grid-column:1 / -1}.delete-button:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.delete-button:disabled{opacity:.5;cursor:not-allowed}.create-admin-button{padding:10px 20px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;cursor:pointer;transition:all .3s;margin-top:15px}.create-admin-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.modal-input{padding:10px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .3s}.modal-input:focus{border-color:#14b8a6}.modal-buttons{display:flex;gap:10px;justify-content:flex-end}.modal-buttons .create-button{background:#10b981;color:#fff}.modal-buttons .create-button:hover{background:#059669}.spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#14b8a6;border-radius:50%;animation:spin 1s linear infinite}.photo-code{font-size:.85rem;color:#14b8a6;font-weight:500}.download-button{background:#14b8a6;color:#fff}.download-button:hover:not(:disabled){background:#0d9488;transform:translateY(-1px)}.my-info-page{width:100%}.my-info-container{width:100%;max-width:600px;margin:0 auto}.info-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #f0f0f0}.info-label{font-size:.85rem;color:#6b7280;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.1rem;color:#1f2937;font-weight:500}.role-badge{display:inline-block;padding:6px 16px;border-radius:20px;font-size:.9rem;font-weight:600}.role-badge.super_admin{background:#ffd70033;color:#d97706;border:1px solid rgba(255,215,0,.3)}.role-badge.system_admin{background:#3b82f633;color:#2563eb;border:1px solid rgba(59,130,246,.3)}.uid-code{font-family:Courier New,monospace;font-size:.9rem;background:#f3f4f6;padding:8px 12px;border-radius:6px;color:#6b7280;word-break:break-all}@media(max-width:768px){.my-info-container{padding:0 10px}.info-card{padding:20px}}.group-management-page,.group-container{width:100%}.page-description{color:#6b7280;font-size:.95rem;margin:0 0 20px}.create-group-button{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;cursor:pointer;transition:all .3s}.create-group-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.error-container{max-width:600px;margin:50px auto;background:#fff;border-radius:15px;padding:40px;text-align:center;box-shadow:0 2px 10px #0000001a}.error-container h2{color:#dc3545;margin-bottom:15px}.error-container p{color:#666}.no-groups{text-align:center;padding:80px 20px;color:#6b7280;font-size:1.1rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.groups-table-container{background:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.groups-table{width:100%;min-width:100%;border-collapse:collapse;table-layout:auto}.groups-table thead{background:#f8f9fa}.groups-table th{padding:15px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.groups-table td{padding:15px;border-bottom:1px solid #f0f0f0;text-align:center;white-space:nowrap}.groups-table tbody tr:hover{background:#f8f9fa}.remaining-codes{font-weight:600;color:#14b8a6}.remaining-codes.zero{color:#dc3545}.group-actions{display:flex;gap:8px;justify-content:center}.edit-button,.delete-button,.password-reset-button{padding:8px 16px;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s;white-space:nowrap}.password-reset-button{background:#f59e0b;color:#fff}.password-reset-button:hover{background:#d97706}.edit-button{background:#14b8a6;color:#fff}.edit-button:hover{background:#0d9488}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:#fff;border-radius:15px;padding:30px;max-width:500px;max-height:90vh;width:90%;box-shadow:0 20px 60px #00000080;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal-content h3{margin:0 0 20px;color:#333;font-size:1.5rem}.modal-form{display:flex;flex-direction:column;gap:20px}.modal-form label{display:flex;flex-direction:column;gap:8px;font-weight:600;color:#333}.modal-form input{padding:10px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .3s}.modal-form input:focus{border-color:#14b8a6}.modal-buttons{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.modal-buttons .cancel-button,.modal-buttons .create-button{padding:10px 20px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.modal-buttons .cancel-button{background:#6b7280;color:#fff}.modal-buttons .cancel-button:hover{background:#4b5563}.modal-buttons .create-button{background:#14b8a6;color:#fff}.modal-buttons .create-button:hover{background:#0d9488}.modal-buttons .create-button:disabled{background:#9ca3af;cursor:not-allowed}.modal-content{position:relative}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.group-admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ec4899,#db2777);padding:20px}.login-container{background:#fff;border-radius:20px;padding:40px;max-width:450px;width:100%;box-shadow:0 20px 60px #0000004d}.login-title{text-align:center;color:#333;margin-bottom:30px;font-size:2rem;font-weight:700}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .3s}.form-group input:focus{border-color:#ec4899}.error-message{padding:12px;background-color:#fee;color:#c33;border-radius:8px;text-align:center;font-size:.9rem}.info-box{padding:12px;background-color:#e7f3ff;color:#0d47a1;border-radius:8px;font-size:.9rem;line-height:1.5}.login-button{padding:14px;background:linear-gradient(135deg,#ec4899,#db2777);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #ec489966}.reset-password-link{background:none;border:none;color:#ec4899;cursor:pointer;font-size:.9rem;text-decoration:underline;padding:8px;transition:color .3s}.reset-password-link:hover{color:#db2777}.group-admin-dashboard-page{width:100%;min-height:100vh;background:transparent;padding:20px;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;align-items:flex-start;justify-content:center}.group-admin-dashboard-container{max-width:1200px;width:100%;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.dashboard-header{margin-bottom:30px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:16px;transition:all .3s;border:1px solid #e9d5ff}.stat-card:hover{box-shadow:0 4px 12px #8b5cf633;transform:translateY(-2px);border-color:#8b5cf6}.stat-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:12px;flex-shrink:0;color:#fff;font-size:2rem}.stat-content{flex:1}.stat-label{font-size:.85rem;color:#6b7280;margin-bottom:6px;font-weight:500}.stat-value{font-size:2rem;font-weight:700;color:#1f2937;line-height:1}.stat-value.zero{color:#dc3545}@media(max-width:768px){.group-admin-dashboard-page{padding:10px;overflow-y:auto}.group-admin-dashboard-container{padding:20px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:1200px;margin:10px auto}.stats-grid{grid-template-columns:1fr}}.code-management{width:100%;height:100%;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.code-container{width:100%;height:auto;min-height:100%;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.code-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:20px}.header-info{display:flex;flex-direction:column;gap:10px}.page-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0}.remaining-codes-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.remaining-codes-label{font-size:.95rem;color:#6b7280;font-weight:500}.remaining-codes-value{font-size:1.2rem;font-weight:700;color:#8b5cf6;padding:4px 12px;background:transparent;border-radius:8px}.remaining-codes-value.zero{color:#dc3545;background:#fee}.request-message{font-size:.85rem;color:#dc3545;font-weight:500}.header-buttons{display:flex;gap:10px;align-items:center}.create-button,.bulk-create-button{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;height:44px;white-space:nowrap;min-width:-moz-max-content;min-width:max-content;width:-moz-max-content;width:max-content;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-sizing:border-box}.create-button{background:linear-gradient(135deg,#ec4899,#db2777)}.create-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.create-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #ec48994d}.bulk-create-button{background:linear-gradient(135deg,#ec4899,#db2777)}.bulk-create-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.bulk-create-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #ec48994d}.codes-table{background:#fff;border-radius:12px;overflow-x:auto;overflow-y:auto;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;-webkit-overflow-scrolling:touch;flex:1;min-height:0;max-height:calc(100vh - 250px)}.codes-table table{width:100%;min-width:100%;border-collapse:collapse;table-layout:auto}.codes-table thead{background:#f8f9fa}.codes-table th{padding:15px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.codes-table td{padding:15px;border-bottom:1px solid #f0f0f0;text-align:center;white-space:nowrap}.codes-table tbody tr:hover{background:#f8f9fa}.status-badge{display:inline-block;padding:5px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.status-badge.active{background:#d4edda;color:#155724}.status-badge.capturing{background:#fff3cd;color:#856404}.sort-button{background:none;border:none;padding:0;font-size:inherit;font-weight:600;color:#333;cursor:pointer;text-align:left;width:100%;transition:color .3s}.sort-button:hover{color:#8b5cf6}.status-badge.used{background:#f8d7da;color:#721c24}.status-badge.paused{background:#dc3545;color:#fff}.action-buttons{display:flex;gap:10px}.reset-button,.delete-button,.pause-button,.activate-button{padding:6px 12px;font-size:.85rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s;height:32px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reset-button{background:#ffc107;color:#000}.reset-button:hover:not(:disabled){background:#ffb300}.reset-button:disabled{opacity:.5;cursor:not-allowed}.pause-button{background:#dc3545;color:#fff}.pause-button:hover:not(:disabled){background:#c82333}.pause-button:disabled{opacity:.5;cursor:not-allowed}.activate-button{background:#10b981;color:#fff}.activate-button:hover{background:#059669}.reset-ip-button{padding:6px 12px;font-size:.85rem;font-weight:600;background:#f59e0b;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .3s}.reset-ip-button:hover{background:#d97706}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:15px;width:90%;max-width:500px;max-height:90vh;box-shadow:0 20px 60px #0000004d;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal-content h2{margin-bottom:20px;color:#333}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea}.form-group input.input-disabled{background-color:#f5f5f5;cursor:not-allowed;border-color:#dc3545}.error-message{color:#dc3545;font-size:.85rem;margin-top:5px;display:block}.check-duplicate-button{padding:12px 20px;font-size:.95rem;font-weight:600;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}.check-duplicate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f666}.check-duplicate-button:disabled{opacity:.6;cursor:not-allowed;background:#9ca3af}.form-hint{display:block;color:#666;font-size:.85rem;margin-top:5px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:30px}.cancel-button,.save-button{padding:10px 20px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.cancel-button{background:#e0e0e0;color:#333}.cancel-button:hover{background:#d0d0d0}.save-button{background:#10b981;color:#fff}.save-button:hover{background:#059669}.detail-modal{max-width:800px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.detail-section{margin-bottom:30px}.detail-section h3{margin-bottom:15px;color:#333;font-size:1.2rem;font-weight:600;border-bottom:2px solid #e0e0e0;padding-bottom:8px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{font-weight:600;color:#666;font-size:.9rem}.detail-item span{color:#333;font-size:1rem}.detail-item input{padding:8px;border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem}.detail-item input:focus{outline:none;border-color:#8b5cf6}.photos-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;max-height:300px;overflow-y:auto}.photo-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#f8f9fa}.photo-thumbnail{width:100%;height:150px;-o-object-fit:cover;object-fit:cover}.photo-info{padding:10px}.photo-date{font-size:.8rem;color:#666;margin-bottom:5px}.photo-link{color:#8b5cf6;text-decoration:none;font-size:.85rem}.photo-link:hover{text-decoration:underline}.logs-list{max-height:300px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px;padding:10px}.log-item{padding:12px;border-bottom:1px solid #f0f0f0;font-size:.9rem;background:#f8f9fa;border-radius:6px;margin-bottom:8px}.log-item:last-child{border-bottom:none;margin-bottom:0}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}.log-time{color:#666;font-size:.85rem;flex-shrink:0}.log-action-badge{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;color:#fff}.log-action-create{background:#28a745}.log-action-update{background:#ffc107;color:#333}.log-action-delete{background:#dc3545}.log-action-read{background:#17a2b8}.log-action-button_click{background:#6c757d}.log-action-page_view{background:#6f42c1}.log-action-code_input,.log-action-code_reaccess,.log-action-frame_selected,.log-action-photo_captured{background:#8b5cf6}.log-action-unknown{background:#6b7280}.log-details{color:#333;font-size:.85rem;margin-bottom:5px;word-break:break-word}.log-admin,.log-ip{color:#666;font-size:.75rem;margin-top:4px}.no-data{color:#666;text-align:center;padding:20px;font-style:italic}.section-description{color:#666;font-size:.9rem;margin-bottom:15px;line-height:1.5}.frame-selection-section{position:relative}.frame-selection{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.frame-select-controls{display:flex;gap:10px;align-items:center}.frame-select-dropdown{flex:1;padding:10px 15px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s}.frame-select-dropdown:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #3b82f61a}.selected-frames-preview{margin-top:10px;display:flex;gap:15px;flex-wrap:wrap}.frame-preview-item{position:relative;border:2px solid #3b82f6;border-radius:12px;overflow:hidden;background:#f8f9fa;padding:15px;display:flex;flex-direction:column;align-items:center;gap:10px}.frame-preview-item img{max-width:100%;max-height:200px;-o-object-fit:contain;object-fit:contain;border-radius:8px;background:#fff;padding:10px}.frame-preview-info{text-align:center;font-size:.9rem;color:#666;font-weight:600;display:flex;flex-direction:column;gap:5px}.frame-preview-info .frame-name{font-weight:700;color:#333;font-size:1rem}.frame-remove-button{position:absolute;top:5px;right:5px;width:28px;height:28px;border-radius:50%;background:#dc3545;color:#fff;border:none;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:all .3s}.frame-remove-button:hover{background:#c82333;transform:scale(1.1)}.frame-actions{position:sticky;top:0;background:#fff;padding:15px 0;border-top:2px solid #e5e7eb;margin-top:20px;z-index:10}.close-button{padding:10px 20px;font-size:1rem;font-weight:600;background:#8b5cf6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.close-button:hover{background:#7c3aed}.frame-editor-new{width:100%;min-height:100vh;padding:20px;overflow-y:auto;overflow-x:hidden;background:transparent;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:15px;box-shadow:0 2px 10px #0000001a}.editor-header h2{margin:0;color:#1e293b;font-size:1.8rem}.help-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#8b5cf6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s}.help-button:hover{background:#7c3aed;transform:translateY(-2px)}.help-panel{background:#fff;border-radius:15px;padding:30px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.help-panel h3{margin:0 0 20px;color:#1e293b;font-size:1.5rem}.help-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.help-step{padding:20px;background:#f8f9fa;border-radius:10px;border-left:4px solid #3b82f6}.help-step strong{display:block;margin-bottom:10px;color:#1e293b;font-size:1.1rem}.help-step p{margin:0;color:#64748b;line-height:1.6}.close-help-button{padding:10px 20px;background:#6b7280;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.close-help-button:hover{background:#4b5563}.step-indicator{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:15px;box-shadow:0 2px 10px #0000001a;position:relative}.step-indicator:before{content:"";position:absolute;top:50%;left:10%;right:10%;height:3px;background:#e5e7eb;z-index:0}.step{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:1;flex:1}.step-number{width:50px;height:50px;border-radius:50%;background:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;transition:all .3s}.step.active .step-number{background:#8b5cf6;color:#fff;transform:scale(1.1)}.step.completed .step-number{background:#10b981;color:#fff}.step-label{font-size:.9rem;color:#64748b;font-weight:600;text-align:center}.step.active .step-label{color:#8b5cf6}.step.completed .step-label{color:#10b981}.editor-content{display:grid;grid-template-columns:1fr 350px;gap:30px;flex:1;min-height:0}.editor-main-panel{background:#fff;border-radius:15px;padding:30px;box-shadow:0 2px 10px #0000001a;overflow-x:hidden}.upload-step{display:flex;justify-content:center;align-items:center;padding:40px 0}.upload-card{text-align:center;padding:60px 40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;max-width:500px;width:100%}.upload-icon{font-size:80px!important;margin-bottom:20px;opacity:.9}.upload-card h3{margin:0 0 10px;font-size:1.8rem}.upload-card p{margin:0 0 30px;font-size:1.1rem;opacity:.9}.big-upload-button{padding:18px 40px;font-size:1.2rem;font-weight:700;background:#fff;color:#667eea;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #0003}.big-upload-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000004d}.step-header{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}.step-header h3{margin:0 0 10px;color:#1e293b;font-size:1.5rem}.step-header p{margin:0;color:#64748b;font-size:1rem}.area-creation-step{margin-bottom:30px}.grid-controls{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.grid-input-card,.draw-controls-card{padding:25px;background:#f8f9fa;border-radius:15px;border:2px solid #e5e7eb;text-align:center}.grid-icon,.draw-icon{font-size:40px!important;color:#8b5cf6;margin-bottom:15px}.grid-input-card h4,.draw-controls-card h4{margin:0 0 20px;color:#1e293b;font-size:1.2rem}.grid-inputs{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:15px}.grid-input-group{display:flex;flex-direction:column;gap:8px;align-items:center}.grid-input-group label{font-size:.9rem;font-weight:600;color:#64748b}.grid-input{width:80px;padding:12px;font-size:1.2rem;text-align:center;border:2px solid #e5e7eb;border-radius:10px;outline:none;transition:all .3s}.grid-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #3b82f61a}.grid-separator{font-size:1.5rem;font-weight:700;color:#64748b}.grid-info{margin:15px 0;font-size:.9rem;color:#64748b}.big-generate-button{width:100%;padding:15px;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:10px}.big-generate-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b9814d}.draw-controls-card p{margin:0 0 15px;color:#64748b;line-height:1.6}.draw-info{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#fef3c7;border-radius:8px;color:#92400e;font-size:.9rem;font-weight:600}.canvas-wrapper{display:flex;justify-content:center;align-items:center;width:100%;height:100%;overflow:hidden}.canvas-container{border:3px solid #e5e7eb;border-radius:15px;padding:20px;background:#f0f0f0;display:inline-block;box-shadow:0 4px 15px #0000001a;max-width:100%;max-height:100%}.area-adjustment-step{margin-bottom:30px;display:flex;flex-direction:column}.area-adjustment-layout{display:flex;gap:20px;padding:20px 0}.frame-canvas-section{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-width:0}.area-controls-panel{width:350px;background:#f8f9fa;border-radius:15px;padding:25px;overflow-x:hidden;flex-shrink:0}.selected-area-controls{margin-bottom:25px}.selected-area-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:15px;background:#fff;border-radius:10px;font-weight:700;color:#8b5cf6;font-size:1.1rem}.selected-icon{color:#10b981}.area-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.action-button{padding:12px 20px;font-size:.95rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;background:#8b5cf6;color:#fff}.action-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.action-button.locked{background:#dc3545}.action-button.same-size{background:#10b981}.action-button.delete{background:#dc3545}.no-selection-message{display:flex;align-items:center;justify-content:center;gap:10px;padding:30px;background:#fff;border-radius:10px;color:#64748b;font-size:1.1rem;font-weight:600}.areas-list{margin-top:25px}.areas-list h4{margin:0 0 15px;color:#1e293b;font-size:1.2rem}.areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px}.area-card{padding:15px;background:#fff;border-radius:12px;border:3px solid #e5e7eb;cursor:pointer;transition:all .3s}.area-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a}.area-card.selected{border-color:#8b5cf6;box-shadow:0 0 0 3px #3b82f633}.area-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px;border-radius:8px}.area-number{display:inline-flex;align-items:center;justify-content:center;width:35px;height:35px;border-radius:50%;color:#fff;font-weight:700;font-size:1rem}.area-size{font-size:.85rem;color:#64748b;font-weight:600}.lock-icon{color:#dc3545;font-size:18px!important}.save-step{text-align:center;padding:30px;background:#f8f9fa;border-radius:15px;display:flex;flex-direction:column;align-items:center;gap:20px}.frame-name-input-container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:8px;text-align:left}.frame-name-input-container label{font-size:1rem;font-weight:600;color:#1e293b}.frame-name-input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e5e7eb;border-radius:8px;transition:all .3s}.frame-name-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #14b8a61a}.big-save-button{width:100%;max-width:400px;padding:20px 40px;font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:15px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:12px;margin:0 auto 15px;box-shadow:0 4px 15px #10b9814d}.big-save-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 20px #10b98166}.big-save-button:disabled{opacity:.6;cursor:not-allowed}.new-frame-button-small{padding:12px 30px;font-size:1rem;font-weight:600;background:#6b7280;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s}.new-frame-button-small:hover{background:#4b5563;transform:translateY(-2px)}.frames-sidebar{background:#fff;border-radius:15px;padding:25px;box-shadow:0 2px 10px #0000001a;overflow-x:hidden;display:flex;flex-direction:column}.frames-sidebar h3{margin:0 0 20px;color:#1e293b;font-size:1.3rem;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.no-frames{text-align:center;padding:60px 20px;color:#9ca3af}.no-frames p{margin:0;font-size:1rem}.frames-list{display:flex;flex-direction:column;gap:15px;flex:1;min-height:0;padding-bottom:20px}.frame-card{border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .3s}.frame-card:hover{border-color:#8b5cf6;box-shadow:0 4px 12px #3b82f633}.frame-card.selected{border-color:#8b5cf6;background:#dbeafe}.frame-preview{cursor:pointer;position:relative;overflow:hidden}.frame-preview-image-container{width:100%;height:200px;overflow:auto;background:#f0f0f0;display:flex;align-items:center;justify-content:center}.frame-preview-image-container img{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;display:block}.frame-info{background:#000c;color:#fff;padding:12px;text-align:center}.frame-name-display{font-weight:700;font-size:1rem;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frame-areas-count{font-size:.85rem;opacity:.9}.frame-actions{display:flex;gap:8px;padding:12px;background:#f8f9fa}.edit-button,.delete-button{flex:1;padding:10px;font-size:.9rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:6px}.edit-button{background:#8b5cf6;color:#fff}.edit-button:hover{background:#7c3aed}.delete-button:hover{background:#c82333}.area-edit-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.area-edit-modal{background:#fff;border-radius:20px;width:95vw;height:90vh;max-width:1600px;max-height:1000px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e5e7eb;background:#f8f9fa}.modal-header h2{margin:0;color:#1e293b;font-size:1.5rem;font-weight:700}.modal-close-button{width:40px;height:40px;border-radius:50%;border:none;background:#e5e7eb;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.modal-close-button:hover{background:#dc3545;color:#fff;transform:rotate(90deg)}.modal-body{flex:1;display:flex;overflow:hidden;min-height:0}.modal-canvas-section{flex:1;display:flex;align-items:center;justify-content:center;background:#f0f0f0;padding:30px;overflow:hidden;min-width:0}.modal-canvas-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.modal-canvas-container{border:3px solid #e5e7eb;border-radius:15px;padding:20px;background:gray;box-shadow:0 4px 15px #0000001a;max-width:100%;max-height:100%;display:inline-block}.modal-tools-section{width:400px;background:#f8f9fa;border-left:2px solid #e5e7eb;overflow-y:auto;overflow-x:hidden;flex-shrink:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.tools-panel{padding:20px;display:flex;flex-direction:column;gap:20px}.tool-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000d}.tool-section-title{margin:0 0 15px;color:#1e293b;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.tool-button{width:100%;padding:12px 16px;font-size:.95rem;font-weight:600;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#1e293b;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}.tool-button:hover{border-color:#8b5cf6;background:#eff6ff;transform:translateY(-2px)}.tool-button.generate{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:transparent}.tool-button.generate:hover{background:linear-gradient(135deg,#059669,#047857)}.tool-button.locked{background:#fee2e2;border-color:#dc3545;color:#dc3545}.tool-button.same-size{background:#eff6ff;border-color:#8b5cf6;color:#8b5cf6}.tool-button.delete{background:#fee2e2;border-color:#dc3545;color:#dc3545}.tool-button.delete:hover{background:#dc3545;color:#fff}.tool-buttons-grid{display:flex;flex-direction:column;gap:10px}.areas-list-compact{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.area-item-compact{border:2px solid #e5e7eb;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .3s}.area-item-compact:hover{transform:translate(5px);box-shadow:0 4px 8px #0000001a}.area-item-compact.selected{border-color:#8b5cf6;box-shadow:0 0 0 3px #3b82f633}.area-item-header{padding:12px;display:flex;align-items:center;gap:10px}.area-number-small{width:28px;height:28px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.area-size-small{flex:1;font-size:.85rem;color:#475569;font-weight:600}.lock-icon-small{width:18px;height:18px;color:#dc3545;flex-shrink:0}.modal-footer{display:flex;justify-content:flex-end;gap:15px;padding:20px 30px;border-top:2px solid #e5e7eb;background:#f8f9fa}.modal-cancel-button,.modal-save-button{padding:12px 30px;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s}.modal-cancel-button{background:#e5e7eb;color:#475569}.modal-cancel-button:hover{background:#d1d5db}.modal-save-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.modal-save-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f666}.area-edit-button-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px}.big-edit-button{padding:20px 50px;font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:15px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px #3b82f64d}.big-edit-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #3b82f666}.areas-summary{padding:15px 30px;background:#eff6ff;border-radius:10px;border:2px solid #3b82f6}.areas-summary p{margin:0;color:#1e40af;font-weight:600;font-size:1rem}.loading-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner{text-align:center;color:#fff}.loading-spinner p{margin-top:20px;font-size:1.2rem;font-weight:600}.spinner{width:60px;height:60px;border:5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@media(max-width:1200px){.editor-content{grid-template-columns:1fr}}.frames-list-view{width:100%}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:15px;box-shadow:0 2px 10px #0000001a}.list-header h3{margin:0;color:#1e293b;font-size:1.5rem}.create-frame-button{padding:12px 24px;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px}.create-frame-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf64d}.frames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.step-content{padding:40px 0}.step-content h3{margin:0 0 10px;color:#1e293b;font-size:1.8rem}.step-content>p{margin:0 0 30px;color:#64748b;font-size:1.1rem}.uploaded-preview{text-align:center;padding:20px}.uploaded-preview img{max-width:100%;max-height:400px;border-radius:10px;box-shadow:0 4px 15px #0000001a;margin-bottom:15px}.step-navigation{display:flex;justify-content:space-between;gap:15px;margin-top:40px;padding-top:30px;border-top:2px solid #e5e7eb}.nav-button{padding:12px 30px;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px}.nav-button.prev{background:#e5e7eb;color:#475569}.nav-button.prev:hover{background:#d1d5db}.nav-button.next{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;margin-left:auto}.nav-button.next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf64d}.nav-button.next:disabled{opacity:.5;cursor:not-allowed}.nav-button.cancel{background:#dc3545;color:#fff}.nav-button.cancel:hover{background:#c82333}.frame-summary{background:#f8f9fa;border-radius:15px;padding:30px;margin:30px 0}.summary-item{margin-bottom:20px}.summary-item:last-child{margin-bottom:0}.summary-item strong{display:block;margin-bottom:10px;color:#1e293b;font-size:1.1rem}.summary-item span{color:#64748b;font-size:1rem}.summary-preview{max-width:100%;max-height:300px;border-radius:10px;box-shadow:0 4px 15px #0000001a;margin-top:10px}.complete-step .big-save-button{width:100%;max-width:500px;margin:30px auto 0}@media(max-width:768px){.grid-controls{grid-template-columns:1fr}.step-indicator{flex-wrap:wrap;gap:15px}.step{flex:0 0 calc(50% - 7.5px)}.area-actions-grid,.frames-grid{grid-template-columns:1fr}.list-header{flex-direction:column;gap:15px;align-items:flex-start}.step-navigation{flex-direction:column}.nav-button.next{margin-left:0}}.photos-list-page,.photos-container{width:100%}.error-message{padding:12px;background-color:#fee;color:#c33;border-radius:8px;margin-bottom:20px;text-align:center;font-size:.9rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 20px;gap:20px}.spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1.1rem;color:#6b7280;margin:0}.no-photos{text-align:center;padding:80px 20px;color:#6b7280;font-size:1.1rem}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.photo-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;transition:all .3s}.photo-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.photo-image-wrapper{width:100%;aspect-ratio:2 / 3;background:#f3f4f6;display:flex;align-items:center;justify-content:center;overflow:hidden}.photo-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.photo-placeholder{color:#9ca3af;font-size:.9rem}.photo-info{padding:16px}.photo-meta{margin-bottom:12px}.photo-date{font-size:.85rem;color:#6b7280;margin-bottom:4px}.photo-code{font-size:.85rem;color:#8b5cf6;font-weight:500}.photo-actions{display:flex;gap:8px}.download-button,.delete-button{flex:1;padding:10px;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s}.download-button{background:#8b5cf6;color:#fff}.download-button:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.download-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333;transform:translateY(-1px)}@media(max-width:768px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}}.group-my-info-page{width:100%;min-height:100vh;background:transparent;padding:20px;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;align-items:flex-start;justify-content:center}.group-my-info-container{max-width:800px;width:100%;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto;max-height:none;min-height:auto;margin:20px auto}.page-description{color:#6b7280;font-size:.95rem;margin:0}.info-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.info-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.info-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.info-label{font-size:.85rem;color:#6b7280;margin-bottom:8px;font-weight:500}.info-value{font-size:1.1rem;color:#1f2937;font-weight:600}.role-badge{display:inline-block;padding:6px 16px;border-radius:12px;font-size:.9rem;font-weight:600}.role-badge.group-admin{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.uid-code{background:#f3f4f6;padding:8px 12px;border-radius:6px;font-family:Courier New,monospace;font-size:.9rem;color:#1f2937;word-break:break-all}@media(max-width:768px){.group-my-info-page{padding:10px;overflow-y:auto}.group-my-info-container{padding:20px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:800px;margin:10px auto}.page-title{font-size:1.5rem}.info-card{padding:20px}}.audit-log,.audit-container{width:100%}.filter-section{display:flex;gap:10px;margin-bottom:30px;flex-wrap:wrap}.filter-button{padding:10px 20px;font-size:.95rem;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s}.filter-button:hover{border-color:#8b5cf6;color:#8b5cf6}.filter-button.active{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.logs-table{background:#fff;border-radius:12px;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 250px);box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;-webkit-overflow-scrolling:touch}.logs-table table{width:100%;min-width:100%;border-collapse:collapse;table-layout:auto}.logs-table thead{background:#f8f9fa}.logs-table th{padding:15px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;position:sticky;top:0;background:#f8f9fa;z-index:10;white-space:nowrap}.logs-table th .sort-button{background:none;border:none;font-weight:600;color:#333;cursor:pointer;padding:0;font-size:inherit;width:100%;text-align:center}.logs-table th .sort-button:hover{color:#8b5cf6}.logs-table td{padding:15px;border-bottom:1px solid #f0f0f0;text-align:center;white-space:nowrap}.logs-table tbody tr:hover{background:#f8f9fa}.action-badge{display:inline-block;padding:5px 12px;border-radius:20px;font-size:.85rem;font-weight:600;color:#fff}.no-data{text-align:center;padding:40px;color:#666}.group-logo-edit-page{width:100%}.logo-edit-container{max-width:600px;margin:0 auto;background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a}.page-description{color:#6b7280;font-size:.95rem;margin:0 0 30px}.logo-section{margin-bottom:30px}.logo-label{display:block;font-weight:600;color:#333;margin-bottom:15px}.logo-preview{margin-top:20px;text-align:center}.logo-preview h3{font-size:1.1rem;color:#333;margin-bottom:15px}.preview-image{max-width:300px;max-height:300px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.action-buttons{display:flex;justify-content:flex-end;gap:10px}.save-button{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:8px;cursor:pointer;transition:all .3s}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #8b5cf64d}.save-button:disabled{opacity:.6;cursor:not-allowed}.unblock-requests-page{width:100%;height:100%}.page-header{margin-bottom:30px}.page-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 8px}.page-description{color:#6b7280;font-size:.95rem;margin:0;display:flex;align-items:center;gap:10px}.pending-badge{background:#dc3545;color:#fff;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.requests-list{display:flex;flex-direction:column;gap:15px}.request-item{background:#fff;padding:20px;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;align-items:center;transition:all .3s;box-shadow:0 1px 3px #0000001a}.request-item:hover{box-shadow:0 2px 8px #0000001a}.request-info{flex:1}.request-ip{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:8px}.request-date,.request-resolved-date{font-size:.9rem;color:#6b7280;margin-bottom:4px}.request-status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600;margin-top:8px}.request-status.pending{background:#fff3cd;color:#856404}.request-status.approved{background:#d4edda;color:#155724}.request-status.rejected{background:#f8d7da;color:#721c24}.request-actions{display:flex;gap:10px}.approve-button,.reject-button{padding:8px 16px;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s}.approve-button{background:#10b981;color:#fff}.approve-button:hover{background:#059669}.reject-button{background:#dc3545;color:#fff}.reject-button:hover{background:#c82333}.no-data{text-align:center;padding:40px;color:#6b7280;font-size:1rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.loading{text-align:center;padding:50px;font-size:1.2rem;color:#666}@media(max-width:768px){.request-item{flex-direction:column;align-items:flex-start;gap:15px}.request-actions{width:100%;justify-content:flex-end}}.group-inquiries-page{padding:30px;width:100%;box-sizing:border-box}.group-inquiries-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.group-inquiries-header h1{font-size:2rem;font-weight:700;margin:0;color:#1f2937}.filter-buttons{display:flex;gap:10px;flex-wrap:wrap}.filter-button{padding:8px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s;color:#6b7280}.filter-button:hover{border-color:#3b82f6;color:#3b82f6}.filter-button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.loading-section,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.inquiries-list{display:flex;flex-direction:column;gap:20px;width:100%}.inquiry-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000d;transition:all .3s;width:100%;box-sizing:border-box}.inquiry-card:hover{box-shadow:0 4px 12px #0000001a}.inquiry-card.pending{border-left:4px solid #f59e0b}.inquiry-card.approved{border-left:4px solid #10b981}.inquiry-card.rejected{border-left:4px solid #ef4444}.inquiry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;flex-wrap:wrap;gap:10px}.inquiry-title{display:flex;align-items:center;gap:12px;flex:1}.inquiry-title h3{font-size:1.3rem;font-weight:700;margin:0;color:#1f2937}.status-badge{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.approved{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fee2e2;color:#991b1b}.inquiry-date{font-size:.9rem;color:#6b7280}.inquiry-content{display:flex;flex-direction:column;gap:12px;margin-bottom:15px;width:100%}.inquiry-field{display:flex;flex-direction:row;align-items:center;gap:12px;width:100%;min-width:0}.inquiry-field label{font-weight:600;color:#374151;font-size:.9rem;min-width:140px;flex-shrink:0;white-space:nowrap}.inquiry-field span{color:#6b7280;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.inquiry-actions{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid #e5e7eb}.approve-button,.reject-button{padding:10px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.approve-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.approve-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #10b9814d}.reject-button{background:#ef4444;color:#fff}.reject-button:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 8px #ef44444d}.reopen-button{padding:10px 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.reopen-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.reject-reason{color:#ef4444!important;font-weight:500;background:#fee2e2;padding:8px 12px;border-radius:6px;border-left:3px solid #ef4444}.access-denied{text-align:center;padding:60px 20px;color:#6b7280}.access-denied h2{font-size:1.5rem;margin-bottom:10px;color:#1f2937}@media(max-width:768px){.group-inquiries-page{padding:15px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;max-height:calc(100vh - 56px)}.group-inquiries-header{flex-direction:column;align-items:flex-start}.inquiry-header,.inquiry-actions{flex-direction:column}.approve-button,.reject-button{width:100%}}.email-send-page{width:100%;padding:20px;box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden}.email-send-header{margin-bottom:30px}.page-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 10px}.page-description{color:#6b7280;font-size:1rem;margin:0}.email-send-form{background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;min-height:0;max-height:calc(100vh - 200px)}.form-section{margin-bottom:30px}.form-label{display:block;font-weight:600;color:#374151;margin-bottom:10px;font-size:1rem}.required{color:#dc2626}.recipient-type-selector{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.radio-option{display:flex;align-items:center;padding:12px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s}.radio-option:hover{border-color:#14b8a6;background:#f0fdfa}.radio-option input[type=radio]{margin-right:10px;width:18px;height:18px;cursor:pointer}.radio-option input[type=radio]:checked+span{color:#14b8a6;font-weight:600}.radio-option:has(input[type=radio]:checked){border-color:#14b8a6;background:#f0fdfa}.manual-email-input{margin-top:20px;padding:20px;background:#f9fafb;border-radius:8px}.input-hint{margin-top:8px;font-size:.85rem;color:#6b7280}.specific-recipient-section{margin-top:20px;padding:20px;background:#f9fafb;border-radius:8px}.input-group{margin-bottom:20px}.input-label{display:block;font-weight:500;color:#4b5563;margin-bottom:8px;font-size:.9rem}.form-input{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#14b8a6}.admin-selector{margin-top:20px}.admin-checkbox-list{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;padding:10px;background:#fff;border-radius:8px;border:2px solid #e5e7eb}.checkbox-option{display:flex;align-items:center;padding:8px;cursor:pointer;border-radius:4px;transition:background .2s}.checkbox-option:hover{background:#f3f4f6}.checkbox-option input[type=checkbox]{margin-right:10px;width:18px;height:18px;cursor:pointer}.recipient-preview{margin-top:15px;padding:15px;background:#f0fdfa;border-radius:8px;border:1px solid #14b8a6}.recipient-list{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.recipient-tag{display:inline-block;padding:4px 12px;background:#14b8a6;color:#fff;border-radius:20px;font-size:.85rem;font-weight:500}.form-textarea{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .2s;box-sizing:border-box}.form-textarea:focus{outline:none;border-color:#14b8a6}.textarea-hint{margin-top:8px;font-size:.85rem;color:#6b7280}.form-actions{margin-top:30px;display:flex;justify-content:flex-end}.submit-button{padding:12px 30px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #14b8a64d}.loading{text-align:center;padding:40px;color:#6b7280}.error-message{text-align:center;padding:40px;color:#dc2626;background:#fef2f2;border-radius:8px;border:1px solid #fecaca}.debug-section{margin-top:40px;background:#fff;border-radius:12px;padding:30px;box-shadow:0 1px 3px #0000001a;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;max-height:calc(100vh - 200px)}.debug-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.debug-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.debug-toggle-button{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.debug-toggle-button:hover{background:#e5e7eb}.debug-content{display:flex;flex-direction:column;gap:20px}.debug-info-box{padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.debug-info-box h4{margin:0 0 15px;color:#1f2937;font-size:1.1rem}.debug-checklist{margin:0;padding-left:20px;color:#374151}.debug-checklist li{margin:12px 0;line-height:1.6}.debug-hint{display:block;margin-top:5px;font-size:.85rem;color:#6b7280;font-style:italic}.debug-link{color:#14b8a6;text-decoration:underline;font-weight:500}.debug-link:hover{color:#0d9488}.recent-emails-box{padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.recent-emails-box h4{margin:0 0 15px;color:#1f2937;font-size:1.1rem}.no-emails{color:#6b7280;font-style:italic;text-align:center;padding:20px}.email-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;margin-bottom:15px}.email-item{padding:15px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.email-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.email-doc-id{font-size:.75rem;color:#6b7280;font-family:monospace}.email-item-subject{font-weight:500;color:#374151;margin-bottom:5px}.email-item-time{font-size:.85rem;color:#6b7280;margin-bottom:8px}.debug-link-small{display:inline-block;font-size:.85rem;color:#14b8a6;text-decoration:underline}.debug-link-small:hover{color:#0d9488}.refresh-button{padding:8px 16px;background:#14b8a6;color:#fff;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.refresh-button:hover{background:#0d9488}@media(max-width:768px){.email-send-page{padding:15px;height:100%;overflow:hidden}.email-send-header{flex-shrink:0;margin-bottom:15px}.email-send-form{padding:20px;max-height:calc(100vh - 150px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.debug-section{max-height:calc(100vh - 150px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.recipient-type-selector{gap:8px}.radio-option{padding:10px;font-size:.9rem}.admin-checkbox-list{max-height:200px}.form-actions{justify-content:stretch}.submit-button{width:100%}.debug-section{padding:20px}.email-item-header{flex-direction:column;align-items:flex-start;gap:5px}}.group-inquiry-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;position:relative;display:flex;align-items:flex-start;justify-content:center}.group-inquiry-container{max-width:600px;width:100%;margin:20px auto;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.group-inquiry-header{text-align:center;margin-bottom:20px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}.group-inquiry-nav-buttons{display:flex;flex-direction:column;align-items:center;gap:15px;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}.status-check-button{width:100%;max-width:400px;padding:12px 24px;font-size:1rem;font-weight:600;color:#3b82f6;background:#fff;border:2px solid #3b82f6;border-radius:8px;cursor:pointer;transition:all .3s}.status-check-button:hover{background:#3b82f6;color:#fff}.main-nav-button{width:100%;max-width:400px;padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;cursor:pointer;transition:all .3s}.group-inquiry-header h1{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.back-button{background:none;border:none;color:#3b82f6;font-size:1rem;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .3s;font-weight:600}.back-button:hover{background:#f0f0f0}.group-inquiry-form{display:flex;flex-direction:column;gap:20px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .3s;box-sizing:border-box;font-family:inherit}.form-group input:focus,.form-group textarea:focus{border-color:#3b82f6}.form-group textarea{resize:vertical;min-height:100px}.email-input-group{display:flex;gap:10px}.email-input-group input{flex:1}.email-check-button{padding:12px 20px;font-size:.95rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap}.email-check-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #14b8a64d}.email-check-button:disabled{opacity:.6;cursor:not-allowed}.email-status{font-size:.85rem;font-weight:500;margin-top:5px}.email-status.success{color:#10b981}.email-status.error{color:#ef4444}.email-valid{border-color:#10b981!important}.email-invalid{border-color:#ef4444!important}.shot-scale-type-selector{display:flex;gap:20px;margin-bottom:15px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.radio-label input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.shot-scale-input-group{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.shot-scale-input-group input{flex:1;min-width:120px}.input-suffix{font-weight:600;color:#6b7280;white-space:nowrap}.submit-button{width:100%;padding:14px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;cursor:pointer;transition:all .3s;margin-top:10px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.group-inquiry-page{padding:10px;align-items:flex-start}.group-inquiry-container{padding:20px;width:100%;max-width:600px;margin:10px auto;touch-action:pan-y;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.group-inquiry-header{flex-direction:column;align-items:flex-start;gap:15px}.group-inquiry-header h1{font-size:1.5rem}}.inquiry-status-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);padding:20px;box-sizing:border-box;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;overflow-x:hidden;position:relative}.inquiry-status-container{max-width:800px;width:100%;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;margin:20px auto;overflow-y:auto;overflow-x:hidden}.inquiry-status-header{text-align:center;margin-bottom:20px;padding-bottom:20px;border-bottom:2px solid #e5e7eb;width:100%}.inquiry-status-header h1{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.inquiries-section-title{text-align:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e5e7eb;width:100%}.inquiries-section-title h2{font-size:1.5rem;font-weight:600;margin:0;color:#1f2937}.inquiries-section{margin-bottom:20px;min-height:200px;width:100%;display:flex;flex-direction:column;align-items:center}.search-section{margin-bottom:30px;display:flex;justify-content:center;width:100%}.search-form{display:flex;gap:10px;max-width:600px;width:100%}.email-input{flex:1;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .3s;box-sizing:border-box}.email-input:focus{border-color:#3b82f6}.search-button{padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap}.search-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.search-button:disabled{opacity:.6;cursor:not-allowed}.inquiries-list{display:flex;flex-direction:column;gap:20px;align-items:center;justify-content:center;width:100%}.inquiry-status-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:24px;transition:all .3s;width:100%;max-width:800px;margin:0 auto}.inquiry-status-card.pending{border-left:4px solid #f59e0b}.inquiry-status-card.approved{border-left:4px solid #10b981}.inquiry-status-card.rejected{border-left:4px solid #ef4444}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.status-header h3{font-size:1.3rem;font-weight:700;margin:0;color:#1f2937}.status-badge{padding:6px 16px;border-radius:12px;font-size:.9rem;font-weight:600}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-approved{background:#d1fae5;color:#065f46}.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.status-badge.status-deleted{background:#f3f4f6;color:#6b7280}.status-timeline{position:relative;padding-left:30px;margin-bottom:24px}.status-timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:#e5e7eb}.timeline-item{position:relative;margin-bottom:24px}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-22px;top:4px;width:16px;height:16px;border-radius:50%;background:#e5e7eb;border:3px solid white;z-index:1}.timeline-item.active .timeline-dot{background:#3b82f6;border-color:#fff;box-shadow:0 0 0 4px #3b82f633}.timeline-item.completed .timeline-dot{background:#10b981;border-color:#fff}.timeline-item.rejected .timeline-dot{background:#ef4444;border-color:#fff}.timeline-content{padding-left:10px}.timeline-title{font-weight:600;color:#1f2937;margin-bottom:4px}.timeline-date{font-size:.85rem;color:#6b7280}.timeline-status{font-size:.85rem;color:#f59e0b;font-weight:500}.reject-reason{margin-top:8px;padding:10px;background:#fee2e2;border-left:3px solid #ef4444;border-radius:6px;font-size:.9rem;color:#991b1b}.reject-reason strong{display:block;margin-bottom:4px}.inquiry-details{display:flex;flex-direction:column;gap:12px;padding-top:20px;border-top:1px solid #e5e7eb}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-weight:600;color:#374151;font-size:.9rem}.detail-item span{color:#6b7280;font-size:.95rem;white-space:pre-wrap;word-break:break-word}.empty-state{text-align:center;padding:60px 20px;color:#6b7280;width:100%}.main-nav-section{display:flex;justify-content:center;padding-top:20px;border-top:2px solid #e5e7eb;width:100%}.main-nav-button{padding:14px 28px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;cursor:pointer;transition:all .3s}.main-nav-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}@media(max-width:768px){.inquiry-status-page{overflow:hidden}.inquiry-status-container{padding:20px;height:auto;max-height:none;min-height:auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;width:100%;max-width:800px;margin:10px auto}.inquiry-status-header{flex-direction:column;align-items:flex-start;gap:15px}.inquiry-status-header h1{font-size:1.5rem}.search-form{flex-direction:column}.search-button{width:100%}.status-header{flex-direction:column;align-items:flex-start;gap:10px}}.error-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;padding:20px}.error-container{width:100%;max-width:500px;background:#fff;border-radius:20px;padding:50px 40px;box-shadow:0 20px 60px #0000004d;text-align:center;height:auto;max-height:none;min-height:auto;margin:20px auto}.error-icon{font-size:5rem;margin-bottom:20px}.error-title{font-size:2rem;font-weight:700;margin-bottom:15px;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.error-message{font-size:1.2rem;color:#dc3545;margin-bottom:10px;font-weight:600}.error-description{font-size:1rem;color:#666;margin-bottom:30px;line-height:1.6}.error-actions{display:flex;flex-direction:column;gap:15px;align-items:center}.dashboard-button{padding:15px 40px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:10px;cursor:pointer;transition:all .3s;width:100%;max-width:300px}.dashboard-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.home-button{padding:15px 40px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;cursor:pointer;transition:all .3s;width:100%;max-width:300px}.home-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.admin-login-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#14b8a6,#0d9488);display:flex;align-items:center;justify-content:center;padding:20px}.login-container{width:100%;max-width:400px;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:30px;color:#333}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-group input{padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s}.form-group input:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{padding:12px;background-color:#fee;color:#c33;border-radius:8px;text-align:left;font-size:.9rem;line-height:1.5}.info-box{background:#e7f3ff;border:1px solid #2196F3;border-radius:8px;padding:12px 15px;font-size:.85rem;color:#0d47a1;line-height:1.5;margin-bottom:20px}.info-box strong{font-weight:600}.login-button{width:100%;padding:15px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:10px;cursor:pointer;transition:all .3s;margin-top:10px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #14b8a64d}.login-button:disabled{opacity:.6;cursor:not-allowed}.reset-password-link{background:none;border:none;color:#14b8a6;cursor:pointer;font-size:.9rem;text-decoration:underline;padding:10px 0;margin-top:10px}.reset-password-link:hover{color:#0d9488}.login-form h2{font-size:1.5rem;margin-bottom:20px;color:#333;text-align:center}.loading-container{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.loading-spinner{font-size:1.2rem;color:#666}.admin-layout{width:100%;height:100vh;max-height:100vh;background:#f0fdfa;display:flex;flex-direction:column;overflow:hidden}.admin-header{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.admin-logo{font-size:1.8rem;font-weight:700;margin:0}.admin-subtitle{font-size:.9rem;opacity:.9}.user-role.super_admin{background:#ffd7004d;color:gold}.admin-body{display:flex;flex:1;overflow:hidden}.admin-sidebar{background:#f0fdfa;width:250px;border-right:2px solid #e5e7eb;display:flex;flex-direction:column;padding:20px 0;transition:all .3s ease;overflow-y:auto;box-shadow:2px 0 10px #0000000d}.admin-sidebar.closed{width:70px}.sidebar-item:hover{background:#ccfbf1!important;color:#14b8a6!important}.sidebar-item:hover .sidebar-icon{color:#14b8a6!important}.sidebar-item:hover .sidebar-icon svg{color:#14b8a6!important;fill:#14b8a6!important}.sidebar-item.active{color:#14b8a6!important;border-left-color:#14b8a6!important;background:#a7f3d0!important;font-weight:600}.sidebar-item.active .sidebar-icon{color:#14b8a6!important}.sidebar-item.active .sidebar-icon svg{color:#14b8a6!important;fill:#14b8a6!important}.sidebar-icon svg{font-size:1.4rem;color:#6b7280;fill:#6b7280;transition:all .3s}.admin-sidebar.closed .sidebar-label{opacity:0;width:0;overflow:hidden}.admin-content{flex:1;padding:30px;overflow-y:auto;overflow-x:hidden;transition:all .3s ease;display:flex;flex-direction:column;min-height:0;width:100%;box-sizing:border-box}.admin-content.sidebar-open,.admin-content.sidebar-closed{margin-left:0}@media(max-width:768px){.admin-header{padding:12px 16px;min-height:56px}.header-left{gap:10px}.admin-logo{font-size:1.4rem}.admin-subtitle{display:none}.mobile-only{display:block}.desktop-only{display:none}.logout-button-mobile{padding:6px 12px;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .3s}.logout-button-mobile:hover{background:#ffffff4d}.admin-sidebar{position:fixed;left:0;top:56px;height:calc(100vh - 56px);z-index:90;transform:translate(0)}.admin-sidebar.closed{transform:translate(-100%)}.admin-content{padding:20px 15px;width:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;max-height:calc(100vh - 56px)}}.group-admin-layout{width:100%;height:100vh;max-height:100vh;background:#faf5ff;display:flex;flex-direction:column;overflow:hidden}.group-admin-header{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:15px;flex-shrink:0}.sidebar-toggle{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;padding:8px 12px;cursor:pointer;font-size:1.2rem;transition:all .3s}.sidebar-toggle:hover{background:#ffffff4d}.group-admin-logo{font-size:1.8rem;font-weight:700;margin:0}.group-admin-subtitle{font-size:.9rem;opacity:.9}.group-name-badge{background:#fff3;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.header-right{display:flex;align-items:center;gap:20px;flex-shrink:0;margin-left:auto}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.logout-button{flex-shrink:0;margin-top:4px}.user-email{font-size:.9rem;font-weight:500}.user-role{font-size:.75rem;padding:2px 8px;border-radius:12px;background:#fff3;font-weight:600}.user-role.group-admin{background:#ffd7004d;color:gold}.logout-button{padding:8px 20px;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s}.logout-button:hover{background:#ffffff4d;transform:translateY(-1px)}.group-admin-body{display:flex;flex:1;overflow:hidden}.group-admin-sidebar{background:#fff;width:250px;border-right:2px solid #e9d5ff;display:flex;flex-direction:column;padding:20px 0;transition:all .3s ease;overflow-y:auto;box-shadow:2px 0 10px #0000000d}.group-admin-sidebar.closed{width:70px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:15px 24px;background:none;border:none;color:#6b7280;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s;text-align:left;width:100%;border-left:3px solid transparent}.sidebar-item:hover{background:#faf5ff;color:#8b5cf6}.sidebar-item.active{color:#8b5cf6;border-left-color:#8b5cf6;background:transparent;font-weight:600}.sidebar-icon{font-size:1.2rem;min-width:24px;text-align:center;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{font-size:1.4rem}.sidebar-label{white-space:nowrap;opacity:1;transition:opacity .3s}.group-admin-sidebar.closed .sidebar-label{opacity:0;width:0;overflow:hidden}.group-admin-content{flex:1;padding:30px;overflow-y:auto;overflow-x:hidden;transition:all .3s ease;display:flex;flex-direction:column;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.mobile-only{display:none}.desktop-only{display:block}@media(max-width:768px){.group-admin-header{padding:12px 16px;min-height:56px}.header-left{gap:10px}.group-admin-logo{font-size:1.4rem}.group-admin-subtitle,.group-name-badge{display:none}.mobile-only{display:block}.desktop-only{display:none}.logout-button-mobile{padding:6px 12px;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .3s}.logout-button-mobile:hover{background:#ffffff4d}.group-admin-sidebar{position:fixed;left:0;top:56px;height:calc(100vh - 56px);z-index:90;transform:translate(0)}.group-admin-sidebar.closed{transform:translate(-100%)}.group-admin-content{padding:20px 15px;width:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;max-height:calc(100vh - 56px)}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden}#root{width:100%;min-height:100vh}[data-scroll-enabled=true]{padding-bottom:20px!important;padding-top:20px!important;box-sizing:border-box}@media(max-width:768px){[data-scroll-enabled=true]{padding-bottom:10px!important;padding-top:10px!important}}.test-container,.group-inquiry-container,.manual-container,.inquiry-status-container,.main-container,.consent-container,.effect-container,.frame-select-container,.select-container,.result-container,.photo-expired-container,.photo-view-container,.group-select-container,.group-code-input-container,.paused-container,.error-container,.login-container,.code-input-container{height:auto!important;max-height:none!important;min-height:auto!important}.test-container,.group-inquiry-container,.manual-container,.inquiry-status-container,.main-container,.consent-container,.effect-container,.frame-select-container,.select-container,.result-container,.photo-expired-container,.photo-view-container,.group-select-container,.group-code-input-container,.paused-container,.error-container,.login-container,.code-input-container{margin-top:20px!important;margin-bottom:20px!important}@media(max-width:768px){.test-container,.group-inquiry-container,.manual-container,.inquiry-status-container,.main-container,.consent-container,.effect-container,.frame-select-container,.select-container,.result-container,.photo-expired-container,.photo-view-container,.group-select-container,.group-code-input-container,.paused-container,.error-container,.login-container,.code-input-container{margin-top:10px!important;margin-bottom:10px!important}}
