:root{--color-bg: #ffffff;--color-background: #f7fafc;--color-text: #2c3e50;--color-text-light: #6c757d;--color-border: #e1e4e8;--color-primary: #5a67d8;--color-primary-hover: #4c51bf;--color-success: #48bb78;--color-danger: #f56565;--color-warning: #ed8936;--color-secondary: #718096;--color-card-bg: #ffffff;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--border-radius: 8px;--spacing-unit: 1rem}@media(prefers-color-scheme:dark){:root{--color-bg: #1a202c;--color-background: #0f1419;--color-text: #e2e8f0;--color-text-light: #a0aec0;--color-border: #2d3748;--color-card-bg: #2d3748;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{margin-bottom:1rem;font-weight:600;line-height:1.2;color:var(--color-text)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin-bottom:1rem}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-hover);text-decoration:underline}button{font-family:inherit;font-size:1rem;padding:.625rem 1.25rem;border-radius:var(--border-radius);border:1px solid var(--color-border);background-color:var(--color-card-bg);color:var(--color-text);cursor:pointer;transition:all .2s;font-weight:500;display:inline-flex;align-items:center;gap:.5rem}button:disabled{opacity:.6;cursor:not-allowed}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background-color:var(--color-primary)!important;color:#fff!important;border-color:var(--color-primary)!important}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)!important;border-color:var(--color-primary-hover)!important}.btn-secondary{background-color:var(--color-secondary)!important;color:#fff!important;border-color:var(--color-secondary)!important}.btn-secondary:hover:not(:disabled){background-color:#5a6c7d!important;border-color:#5a6c7d!important}.btn-outline{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover:not(:disabled){background-color:var(--color-border)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}input,textarea,select{font-family:inherit;font-size:1rem;padding:.625rem;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:var(--color-card-bg);color:var(--color-text);transition:border-color .2s;width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary)}.card{background-color:var(--color-card-bg);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.text-muted{color:var(--color-text-light)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:var(--color-card-bg);border-bottom:1px solid var(--color-border);padding:1rem 0;box-shadow:var(--shadow-sm)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:2rem}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--color-text);text-decoration:none}.logo:hover{text-decoration:none;color:var(--color-primary)}.nav{display:flex;gap:1.5rem;flex:1;padding-left:2rem}.nav a{color:var(--color-text);text-decoration:none;font-weight:500;transition:color .2s;padding:.5rem 0;border-bottom:2px solid transparent}.nav a:hover{color:var(--color-primary);text-decoration:none;border-bottom-color:var(--color-primary)}.auth-section{display:flex;align-items:center;gap:1rem}.auth-section .btn-primary{background-color:var(--color-primary);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:background-color .2s}.auth-section .btn-primary:hover{background-color:var(--color-primary-hover)}.auth-section a{text-decoration:none}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;transition:all .2s}.user-menu-trigger:hover{background-color:var(--color-background);border-color:var(--color-primary)}.user-email{color:var(--color-text);font-size:.875rem;font-weight:500}.user-menu-overlay{position:fixed;inset:0;z-index:999}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow-md);min-width:200px;z-index:1000;overflow:hidden}.user-menu-dropdown a,.user-menu-dropdown button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--color-text);text-decoration:none;border:none;background:none;width:100%;text-align:left;cursor:pointer;transition:background-color .2s;font-size:.875rem}.user-menu-dropdown a:hover,.user-menu-dropdown button:hover{background-color:var(--color-background);text-decoration:none}.user-menu-dropdown hr{border:none;border-top:1px solid var(--color-border);margin:.25rem 0}.user-menu-dropdown .logout-btn{color:var(--color-danger)}.user-menu-dropdown .logout-btn:hover{background-color:#dc35451a}.main-content{flex:1;padding:2rem 0}.footer{background-color:var(--color-card-bg);border-top:1px solid var(--color-border);padding:2rem 0;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-links{display:flex;gap:1.5rem;align-items:center}.footer-links a{color:var(--color-text-light);font-size:.875rem}@media(max-width:768px){.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.nav{flex-wrap:wrap;padding-left:0}.footer-content{flex-direction:column;text-align:center}}.home{padding:2rem 0}.hero{text-align:center;padding:4rem 2rem;max-width:800px;margin:0 auto}.hero h1{font-size:3rem;margin-bottom:1rem;color:var(--color-text)}.subtitle{font-size:1.25rem;color:var(--color-text-light);margin-bottom:2rem;line-height:1.6}.hero-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.notice{font-size:.875rem;margin-top:1.5rem}.features{padding:4rem 2rem}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.feature-card{text-align:center;padding:2rem;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{color:var(--color-primary);margin-bottom:1rem;display:flex;justify-content:center}.feature-card h3{margin-bottom:1rem;color:var(--color-text)}.info-section{padding:2rem;max-width:700px;margin:2rem auto}.info-card{padding:2rem}.steps-list{padding-left:1.5rem;text-align:left}.steps-list li{margin-bottom:1rem;line-height:1.6}.steps-list strong{color:var(--color-primary)}@media(max-width:768px){.hero h1{font-size:2rem}.subtitle{font-size:1rem}.hero-actions{flex-direction:column;align-items:center}.hero-actions button{width:100%;max-width:300px}.feature-grid{grid-template-columns:1fr}}.login-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{width:100%;max-width:450px}.login-card{padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-header svg{color:var(--color-primary);margin-bottom:1rem}.login-header h2{margin-bottom:.5rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-weight:500;color:var(--color-text)}.alert{padding:.75rem 1rem;border-radius:var(--border-radius);margin-bottom:1rem}.alert-error{background-color:#f565651a;border:1px solid var(--color-danger);color:var(--color-danger)}.alert-success{background-color:#48bb781a;border:1px solid #48bb78;color:#2f855a}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:.5rem;font-size:.95rem;text-decoration:underline;margin-bottom:1rem}.btn-link:hover{color:var(--color-primary-hover)}.login-form .btn-primary{background-color:var(--color-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-weight:500;font-size:1rem;cursor:pointer;transition:background-color .2s}.login-form .btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.login-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.form-group input{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:1rem;background-color:var(--color-background);color:var(--color-text);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--color-primary)}.login-footer{margin-top:2rem;text-align:center}@media(max-width:480px){.login-card{padding:1.5rem}}.file-viewer-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.file-viewer-modal{background:var(--color-bg);border-radius:8px;width:100%;max-width:1200px;height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0000004d}.file-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-background)}.file-viewer-title h3{margin:0;font-size:1.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:600px}.file-viewer-title p{margin:.25rem 0 0;font-size:.875rem}.file-viewer-actions{display:flex;gap:.5rem}.file-viewer-content{flex:1;overflow:auto;background:var(--color-background);position:relative}.file-viewer-loading,.file-viewer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-light)}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.file-viewer-text{margin:0;padding:2rem;font-family:Courier New,monospace;font-size:.875rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;color:var(--color-text);background:var(--color-background);overflow-x:auto}.file-viewer-iframe{width:100%;height:100%;border:none}.file-viewer-office{display:flex;align-items:center;justify-content:center;height:100%}.office-preview-notice{text-align:center;padding:2rem;max-width:400px}.office-preview-notice svg{opacity:.5;margin-bottom:1rem;color:var(--color-text-light)}.office-preview-notice h3{margin:0 0 .5rem}.office-preview-notice p{color:var(--color-text-light);margin-bottom:1.5rem}@media(max-width:768px){.file-viewer-modal{height:100vh;max-width:none;border-radius:0}.file-viewer-title h3{max-width:200px}.file-viewer-text{padding:1rem;font-size:.8125rem}}.files-page{padding:2rem 0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.storage-info{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;min-width:300px}.storage-details{flex:1}.storage-text{font-size:.875rem;margin-bottom:.5rem;color:var(--color-text)}.storage-bar{height:8px;background-color:var(--color-border);border-radius:4px;overflow:hidden}.storage-fill{height:100%;background-color:var(--color-primary);transition:width .3s}.files-toolbar{margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.toolbar-left{display:flex;gap:1rem}.view-toggle{display:flex;gap:.5rem;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:6px;padding:.25rem}.view-toggle-btn{background:transparent;border:none;padding:.5rem;cursor:pointer;border-radius:4px;color:var(--color-text-light);transition:all .2s;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover{background:var(--color-background);color:var(--color-text)}.view-toggle-btn.active{background:var(--color-primary);color:#fff}.upload-progress{margin-bottom:1.5rem;padding:1rem}.progress-bar{height:24px;background-color:var(--color-border);border-radius:var(--border-radius);overflow:hidden;margin-top:.5rem}.progress-fill{height:100%;background-color:var(--color-success);transition:width .3s}.dropzone{min-height:400px;border:2px dashed var(--color-border);border-radius:var(--border-radius);padding:2rem;transition:border-color .2s,background-color .2s}.dropzone.active{border-color:var(--color-primary);background-color:#5a67d80d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:var(--color-text-light)}.empty-state svg{color:var(--color-text-light)}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.files-grid .file-item{display:flex;flex-direction:column;align-items:center;padding:1.5rem;transition:transform .2s,box-shadow .2s;position:relative;text-align:center}.files-grid .file-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.files-grid .file-item svg{color:var(--color-primary);margin-bottom:1rem}.files-grid .file-item-content{display:flex;flex-direction:column;align-items:center}.files-grid .file-info{width:100%;margin-bottom:1rem;text-align:center}.files-grid .file-actions{display:flex;gap:.5rem;justify-content:center}.files-list{display:flex;flex-direction:column;gap:.5rem}.files-list .file-item{display:flex;flex-direction:row;align-items:center;padding:1rem 1.5rem;transition:background-color .2s;text-align:left;gap:1rem}.files-list .file-item:hover{background-color:var(--color-background)}.files-list .file-item svg{color:var(--color-primary);flex-shrink:0}.files-list .file-item-content{display:flex;flex-direction:row;align-items:center;gap:1rem;flex:1;cursor:pointer}.files-list .file-info{flex:1;min-width:0}.files-list .file-actions{display:flex;gap:.5rem;margin-left:auto}.file-name{font-weight:500;word-break:break-word;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.875rem}.file-actions button{padding:.5rem}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.storage-info{width:100%}.files-grid{grid-template-columns:1fr}}.photos-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.photos-content{display:flex;flex-direction:column;gap:3rem}.photo-group{margin-bottom:2rem}.photo-group-date{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary);font-weight:600}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.photo-item{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.photo-item:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.photo-thumbnail{aspect-ratio:1;overflow:hidden;background:var(--secondary-bg);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center}.photo-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-thumbnail:hover img{transform:scale(1.05)}.photo-loading{color:var(--text-secondary);font-size:.875rem}.photo-info{padding:1rem;flex:1}.photo-name{font-weight:500;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-meta{font-size:.875rem;margin:0}.photo-actions{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border-color);justify-content:flex-end}.btn-icon{background:transparent;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--secondary-bg);color:var(--primary-color);border-color:var(--primary-color)}.lightbox-overlay{position:fixed;inset:0;background:#000000f2;z-index:10000;display:flex;align-items:center;justify-content:center;padding:2rem}.lightbox-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;border-radius:50%;width:48px;height:48px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10001}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;border-radius:50%;width:56px;height:56px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10001}.lightbox-nav:hover{background:#fff3}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:1rem}.lightbox-content img{max-width:100%;max-height:calc(90vh - 80px);object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080}.lightbox-info{text-align:center;color:#fff;background:#000000b3;padding:1rem 2rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-name{margin:0 0 .5rem;font-weight:600;font-size:1.125rem}.lightbox-meta{margin:0;font-size:.875rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state p:first-of-type{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}@media(max-width:768px){.photos-page{padding:1rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.lightbox-nav{width:40px;height:40px}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}.lightbox-content{max-width:95vw}}.videos-page{padding:2rem 0}.video-group{margin-bottom:3rem}.video-group-date{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:var(--color-text)}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.video-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s}.video-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.video-thumbnail{position:relative;width:100%;padding-bottom:56.25%;background:var(--color-background);cursor:pointer;overflow:hidden}.video-thumbnail video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.video-play-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0000004d;color:#fff;opacity:0;transition:opacity .2s}.video-thumbnail:hover .video-play-overlay{opacity:1}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--color-text-light)}.video-info{padding:.75rem 1rem}.video-name{font-weight:500;margin-bottom:.25rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-meta{font-size:.875rem}.video-actions{padding:.5rem 1rem .75rem;display:flex;gap:.5rem;border-top:1px solid var(--color-border)}.video-actions .btn-icon{padding:.5rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .2s}.video-actions .btn-icon:hover{background:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.video-actions .btn-icon.btn-danger:hover{background:#fee;border-color:#dc3545;color:#dc3545}.video-player-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.player-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem;border-radius:4px;cursor:pointer;transition:background .2s;z-index:1001}.player-close:hover{background:#fff3}.player-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;transition:background .2s;z-index:1001;display:flex;align-items:center;justify-content:center;font-size:2rem;line-height:1}.player-nav:hover{background:#fff3}.player-nav.player-prev{left:1rem}.player-nav.player-next{right:1rem}.player-content{max-width:90%;max-height:90%;display:flex;flex-direction:column;gap:1rem}.video-player{max-width:100%;max-height:calc(90vh - 5rem);border-radius:8px}.player-info{text-align:center;color:#fff}.player-name{font-size:1.125rem;font-weight:500;margin-bottom:.25rem}.player-meta{font-size:.875rem;opacity:.8}@media(max-width:768px){.video-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.video-player-overlay{padding:1rem}.player-content{max-width:100%}.video-player{max-height:calc(100vh - 8rem)}.player-nav{width:40px;height:40px;font-size:1.5rem}.player-nav.player-prev{left:.5rem}.player-nav.player-next{right:.5rem}}.public-page{padding:2rem 0}.public-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-buttons button{padding:.5rem 1rem;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.filter-buttons button:hover{background:var(--color-background);border-color:var(--color-primary)}.filter-buttons button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.view-toggle{display:flex;gap:.25rem}.view-toggle button{padding:.5rem .75rem;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .2s;font-size:1.2rem}.view-toggle button:first-child{border-radius:4px 0 0 4px}.view-toggle button:last-child{border-radius:0 4px 4px 0}.view-toggle button:hover{background:var(--color-background)}.view-toggle button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.public-files.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.public-files.grid .public-file-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;gap:1rem}.public-files.grid .public-file-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.public-files.grid .file-icon{width:48px;height:48px;border-radius:8px;background:var(--color-background);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.public-files.grid .file-details{flex:1}.public-files.grid .file-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.public-files.list{display:flex;flex-direction:column;gap:.5rem}.public-files.list .public-file-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.public-files.list .public-file-item:hover{background:var(--color-background);border-color:var(--color-primary)}.public-files.list .file-icon{width:40px;height:40px;border-radius:4px;background:var(--color-background);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.public-files.list .file-details{flex:1;min-width:0}.public-files.list .file-actions{display:flex;gap:.5rem;flex-shrink:0}.file-name{font-size:1rem;font-weight:500;margin-bottom:.25rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{font-size:.875rem;line-height:1.5}.file-actions .btn-icon{padding:.5rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.file-actions .btn-icon:hover{background:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.preview-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.preview-content{max-width:90%;max-height:90%;display:flex;flex-direction:column;gap:1rem;position:relative}.preview-close{position:absolute;top:-2.5rem;right:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s;font-size:1.5rem}.preview-close:hover{background:#fff3}.preview-content img,.preview-content video{max-width:100%;max-height:calc(90vh - 5rem);border-radius:8px;object-fit:contain}.preview-content audio{width:100%;max-width:500px}.preview-info{text-align:center;color:#fff}.preview-name{font-size:1.125rem;font-weight:500;margin-bottom:.25rem}.preview-meta{font-size:.875rem;opacity:.8}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-light)}@media(max-width:768px){.public-controls{flex-direction:column;align-items:stretch}.filter-buttons,.view-toggle{justify-content:center}.public-files.grid{grid-template-columns:1fr}.public-files.list .file-details{min-width:0}.public-files.list .file-name{font-size:.9rem}.public-files.list .file-meta{font-size:.8rem}}.chat-page{padding:2rem 0}.page-header h1{display:flex;align-items:center;gap:.75rem;position:relative}.badge{position:absolute;top:-8px;right:-20px;background:#dc3545;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:12px;font-weight:600}.chat-container{display:grid;grid-template-columns:350px 1fr;gap:0;height:calc(100vh - 200px);min-height:500px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.chat-sidebar{border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.search-panel{padding:1rem;border-bottom:1px solid var(--color-border);background:var(--color-background)}.search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.search-header h3{font-size:1rem;margin:0}.search-header button{background:none;border:none;color:var(--color-text);cursor:pointer;padding:.25rem}.search-form{display:flex;gap:.5rem}.search-form input{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text)}.search-form button{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:4px;cursor:pointer}.search-form button:disabled{opacity:.5;cursor:not-allowed}.search-result{margin-top:1rem;padding:1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px}.result-info{margin-bottom:.75rem}.result-email{font-weight:500;margin-bottom:.25rem}.requests-section{padding:1rem;border-bottom:1px solid var(--color-border);background:var(--color-background)}.requests-section h3{font-size:.875rem;margin-bottom:.75rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px}.request-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;margin-bottom:.5rem}.request-item:last-child{margin-bottom:0}.request-info{flex:1;min-width:0}.request-email{font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.request-actions{display:flex;gap:.5rem}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.conversations-list{flex:1;overflow-y:auto}.conversation-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .2s}.conversation-item:hover{background:var(--color-background)}.conversation-item.active{background:var(--color-background);border-left:3px solid var(--color-primary)}.conversation-info{flex:1;min-width:0}.conversation-email{font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.last-message{font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.time{font-size:.75rem}.unread-badge{background:var(--color-primary);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:10px;font-weight:600}.chat-area{display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background:var(--color-bg)}.chat-header h3{margin:0;font-size:1.125rem}.messages-area{flex:1;overflow-y:auto;padding:1.5rem;background:var(--color-background)}.message{display:flex;margin-bottom:1rem}.message.own{justify-content:flex-end}.message.other{justify-content:flex-start}.message-bubble{max-width:70%;padding:.75rem 1rem;border-radius:12px;position:relative}.message.own .message-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message.other .message-bubble{background:var(--color-bg);color:var(--color-text);border-bottom-left-radius:4px;border:1px solid var(--color-border)}.message-bubble p{margin:0;margin-bottom:.25rem;word-wrap:break-word}.message-time{font-size:.75rem;opacity:.7}.message-input-form{display:flex;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border);background:var(--color-bg)}.message-input-form input{flex:1;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:24px;background:var(--color-background);color:var(--color-text);font-size:.9375rem}.message-input-form input:focus{outline:none;border-color:var(--color-primary)}.message-input-form button{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.message-input-form button:hover:not(:disabled){background:var(--color-primary-dark);transform:scale(1.05)}.message-input-form button:disabled{opacity:.5;cursor:not-allowed}.no-conversation{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-light);gap:1rem}.empty-state{padding:3rem 1rem;text-align:center;color:var(--color-text-light)}@media(max-width:768px){.chat-container{grid-template-columns:1fr;height:calc(100vh - 180px);position:relative}.chat-sidebar{display:flex;position:absolute;inset:0;z-index:10}.chat-sidebar.hide-on-mobile{display:none}.chat-area{display:none;position:absolute;inset:0;z-index:11}.chat-area.show-on-mobile{display:flex}#back-button,#back-button-group{display:flex!important}.message-bubble{max-width:85%}}.guest-upload-page{padding:2rem 0;min-height:60vh;display:flex;align-items:center}.upload-container{max-width:600px;margin:0 auto;padding:2rem;text-align:center}.upload-area{border:2px dashed var(--color-border);border-radius:var(--border-radius);padding:3rem 2rem;margin:2rem 0;cursor:pointer;transition:border-color .2s,background-color .2s}.upload-area:hover{border-color:var(--color-primary);background-color:#5a67d80d}.upload-area svg{color:var(--color-primary);margin-bottom:1rem}.success-message{padding:2rem;text-align:center}.success-message svg{color:var(--color-success);margin-bottom:1rem}.error-card{max-width:500px;margin:0 auto;padding:2rem;text-align:center}.sharing-page{padding:2rem 0}.shares-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.share-item{display:flex;align-items:center;gap:1rem;padding:1.5rem}.share-icon{color:var(--color-primary)}.share-info{flex:1}.share-name{font-weight:500;margin-bottom:.25rem}.share-meta{font-size:.875rem}.share-actions{display:flex;gap:.5rem}.share-actions button{padding:.5rem}.share-access{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.share-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 25px #00000026;max-width:400px;width:100%;text-align:center}.share-card.error{border:2px solid #ef4444}.share-header{margin-bottom:2rem}.share-header svg{color:#667eea;margin-bottom:1rem}.share-header h2{color:#1f2937;margin-bottom:.5rem;font-size:1.5rem}.file-name{color:#6b7280;font-weight:500;font-size:1.1rem;word-break:break-all}.password-section{margin-bottom:1.5rem}.input-group{position:relative;margin-bottom:1rem}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;z-index:1}.input-group input{width:100%;padding:12px 12px 12px 44px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.input-group input:focus{outline:none;border-color:#667eea}.error-message{color:#ef4444;margin-bottom:1rem;padding:.75rem;background:#fef2f2;border-radius:6px;border:1px solid #fecaca}.share-actions{margin-bottom:1.5rem}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.expiry-info{color:#6b7280;font-size:.875rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}@media(max-width:480px){.share-access{padding:.5rem}.share-card{padding:1.5rem}.share-header h2{font-size:1.25rem}}.user-management{padding:2rem;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.header-content{display:flex;align-items:center;gap:.75rem}.header-content h1{margin:0;color:#1f2937;font-size:1.875rem;font-weight:600}.header-content svg{color:#667eea}.page-loading{text-align:center;padding:4rem;color:#6b7280;font-size:1.125rem}.users-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.users-table table{width:100%;border-collapse:collapse}.users-table th{background:#f9fafb;color:#374151;font-weight:600;padding:1rem;text-align:left;border-bottom:1px solid #e5e7eb}.users-table td{padding:1rem;border-bottom:1px solid #f3f4f6;vertical-align:middle}.users-table tr:hover{background:#f9fafb}.role-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.role-badge.role-red{background:#fee2e2;color:#dc2626}.role-badge.role-blue{background:#dbeafe;color:#2563eb}.role-badge.role-gray{background:#f3f4f6;color:#6b7280}.storage-info{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.storage-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.user-actions{display:flex;gap:.5rem}.user-actions button{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;cursor:pointer;transition:all .2s ease}.user-actions button:hover{background:#f9fafb;color:#374151}.user-actions .btn-danger{border-color:#fca5a5;color:#dc2626}.user-actions .btn-danger:hover{background:#fef2f2;border-color:#f87171}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:600}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-actions button{padding:.75rem 1.5rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-actions button:hover{background:#f9fafb}.modal-actions .btn-primary{background:#667eea;color:#fff;border-color:#667eea}.modal-actions .btn-primary:hover{background:#5a67d8;border-color:#5a67d8}@media(max-width:768px){.user-management{padding:1rem}.page-header{flex-direction:column;gap:1rem;align-items:stretch}.users-table{overflow-x:auto}.users-table table{min-width:700px}.modal{padding:1.5rem;width:95%}.modal-actions{flex-direction:column}.user-actions{flex-wrap:wrap}}.settings{padding:2rem;max-width:800px;margin:0 auto}.page-header h1{margin:0 0 2rem;color:#1f2937;font-size:1.875rem;font-weight:600;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.settings-sections{display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.settings-section h2{margin:0 0 1.5rem;color:#374151;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.profile-info{display:flex;flex-direction:column;gap:1rem}.info-item{display:grid;grid-template-columns:150px 1fr;gap:1rem;align-items:center}.info-item label{font-weight:500;color:#6b7280}.info-item span{color:#1f2937}.storage-display{display:flex;flex-direction:column;gap:.5rem}.storage-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;width:200px}.storage-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s ease}.password-form{display:flex;flex-direction:column;gap:1.5rem;max-width:400px}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#374151}.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.form-group small{color:#6b7280;font-size:.875rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;justify-content:center;max-width:200px}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#059669;padding:1rem;border-radius:8px;margin-bottom:1rem}@media(max-width:768px){.settings{padding:1rem}.settings-section{padding:1.5rem}.info-item{grid-template-columns:1fr;gap:.5rem}.info-item label{font-size:.875rem}.storage-bar{width:100%}.password-form,.btn{max-width:none}}.help-page{padding:2rem 0}.help-header{text-align:center;margin-bottom:3rem}.help-header svg{color:var(--color-primary);margin-bottom:1rem}.faq-section{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.faq-item{padding:1.5rem}.faq-item h3{color:var(--color-primary);margin-bottom:.75rem}.faq-item p{margin-bottom:0;line-height:1.6}.privacy-section{padding:2rem;background-color:#5a67d80d;border-left:4px solid var(--color-primary)}.privacy-section h2{color:var(--color-primary);margin-bottom:1rem}.privacy-section p{line-height:1.6}.activity-page{padding:2rem 0}.activities-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.activity-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem}.activity-icon{color:var(--color-primary);padding-top:.25rem}.activity-info{flex:1}.activity-details{margin-bottom:.25rem}.activity-time{font-size:.875rem}.trash-page{padding:2rem 0}.trash-info{display:flex;align-items:center;gap:1rem;padding:1rem;margin-bottom:1.5rem;background-color:#fff3cd;border-left:4px solid #ffc107}.trash-info p{margin:0;color:#856404}.trash-list{display:flex;flex-direction:column;gap:1rem}.trash-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border:1px solid var(--color-border);border-radius:var(--border-radius);transition:background-color .2s}.trash-item:hover{background-color:var(--color-background)}.trash-item-info{flex:1}.trash-item-name{font-weight:500;margin-bottom:.25rem}.trash-item-meta{font-size:.875rem}.trash-item-actions{display:flex;gap:.5rem}.trash-item-actions button{display:flex;align-items:center;gap:.5rem;white-space:nowrap}@media(max-width:768px){.trash-item{flex-direction:column;align-items:flex-start;gap:1rem}.trash-item-actions{width:100%;flex-direction:column}.trash-item-actions button{width:100%;justify-content:center}}.invites-page{padding:2rem;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{display:flex;align-items:center;gap:1rem;margin:0}.create-invite-form{margin-bottom:2rem}.create-invite-form h3{margin-top:0;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;font-size:1rem;background:var(--color-background);color:var(--color-text)}.form-group input:focus{outline:none;border-color:var(--color-primary);background:var(--color-card-bg)}.form-hint{display:block;margin-top:.25rem;font-size:.875rem;color:var(--color-text-light)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:6px;border:none;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--color-primary)!important;color:#fff!important;border-color:var(--color-primary)!important}.btn-primary:hover{background:var(--color-primary-hover)!important;border-color:var(--color-primary-hover)!important}.btn-secondary{background:var(--color-secondary)!important;color:#fff!important;border:1px solid var(--color-secondary)!important}.btn-secondary:hover{background:#8b95a8!important;border-color:#8b95a8!important}.invites-list{display:flex;flex-direction:column;gap:1rem}.invite-item{padding:1.5rem}.invite-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.invite-status{display:flex;align-items:center;gap:.5rem}.status-icon.active{color:#28a745}.status-icon.inactive{color:#dc3545}.status-icon.expired{color:#ffc107}.status-icon.used-up{color:#6c757d}.status-text{font-weight:600;font-size:1rem}.invite-actions{display:flex;gap:.5rem}.btn-icon{background:transparent;border:1px solid var(--color-border);border-radius:6px;padding:.5rem;cursor:pointer;color:var(--color-text-light);transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--color-card-bg);color:var(--color-primary);border-color:var(--color-primary)}.btn-icon.btn-danger:hover{background:#fee;color:#d00;border-color:#d00}.invite-details{display:flex;flex-direction:column;gap:.75rem}.invite-detail{display:flex;gap:1rem}.invite-detail strong{min-width:140px;color:var(--color-text-light);font-weight:500}.invite-detail code{background:var(--color-card-bg);padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem;word-break:break-all}.used-by-list{margin:0;padding-left:1.5rem}.used-by-list li{margin-bottom:.25rem;color:var(--color-text)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--color-text-light)}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p:first-of-type{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text)}@media(max-width:768px){.invites-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-actions{flex-direction:column}.btn{width:100%;justify-content:center}.invite-header{flex-direction:column;align-items:flex-start;gap:1rem}.invite-detail{flex-direction:column;gap:.25rem}.invite-detail strong{min-width:auto}}
