.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0}.navbar-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:center;gap:1rem;background:var(--card-background);border:1px solid var(--border-color);border-radius:16px;padding:.75rem 1rem;box-shadow:0 4px 12px #0000001a}@media (min-width: 640px){.navbar-container{padding:0 2rem;gap:2rem;padding:1rem 2rem}}.navbar-link{color:var(--text-primary);text-decoration:none;font-size:.875rem;font-weight:500;padding:.5rem .75rem;border-radius:8px;transition:background-color .2s ease,color .2s ease}@media (min-width: 640px){.navbar-link{font-size:1rem;padding:.5rem 1rem}}.navbar-link:hover{background-color:var(--hover-bg)}.navbar-toggle-container{margin-left:auto}.navbar-mode-toggle{gap:0}.navbar-logo{display:flex;align-items:center;text-decoration:none;margin-right:auto}.logo-icon{width:24px;height:24px;display:block}@media (min-width: 640px){.logo-icon{width:28px;height:28px}}.footer{margin-top:auto;padding:2rem 0;border-top:1px solid var(--border-color);background-color:#fff}.footer-container{max-width:1400px;margin:0 auto;padding:0 1rem;text-align:center}@media (min-width: 640px){.footer-container{padding:0 3rem}}.footer-text{margin:0;font-size:.875rem;color:var(--text-secondary)}.motion-graphics-thumbnail img{object-position:0 -185px}.misc-thumbnail img{object-position:0 -90px}.nba-gameday-thumbnail img{object-position:0 -20px}.portfolio{min-height:100vh;padding:1rem 1rem 4rem;max-width:1400px;margin:0 auto}@media (min-width: 640px){.portfolio{padding:3rem 3rem 6rem}}.portfolio-header{text-align:center;margin-bottom:2rem;padding-top:6rem}.portfolio-header-left{text-align:left}@media (min-width: 640px){.portfolio-header{margin-bottom:2rem}}.mode-toggle-container{display:flex;justify-content:center;margin-bottom:2rem}.mode-toggle{display:flex;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;padding:.5rem;font-family:inherit}@media (min-width: 640px){.mode-toggle{gap:1rem}}.mode-label{font-size:.75rem;color:var(--text-secondary);transition:color .2s ease}@media (min-width: 640px){.mode-label{font-size:.875rem}}.mode-toggle:hover .mode-label{color:var(--text-primary)}.mode-switch{position:relative;width:50px;height:26px;border-radius:13px;background-color:var(--border-color);transition:background-color .3s ease}@media (min-width: 640px){.mode-switch{width:60px;height:30px;border-radius:15px}}.mode-switch.developer{background-color:#3b82f6}.mode-switch.designer{background-color:#ef4444}.mode-slider{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background-color:#fff;transition:transform .3s ease;box-shadow:0 2px 4px #0003}@media (min-width: 640px){.mode-slider{top:3px;left:3px;width:24px;height:24px}}.mode-switch.designer .mode-slider{transform:translate(24px)}@media (min-width: 640px){.mode-switch.designer .mode-slider{transform:translate(30px)}}.portfolio-name{font-size:2.5rem;font-weight:600;margin:0;color:var(--text-primary)}@media (min-width: 640px){.portfolio-name{font-size:3.5rem}}@media (min-width: 1024px){.portfolio-name{font-size:4.5rem}}.portfolio-title{font-size:1rem;margin:0;color:var(--text-secondary)}@media (min-width: 640px){.portfolio-title{font-size:1.25rem}}.portfolio-content{display:flex;flex-direction:column;gap:2rem;padding-bottom:4rem}@media (min-width: 640px){.portfolio-content{gap:2rem;padding-bottom:6rem}}.portfolio-section{display:flex;flex-direction:column;gap:0}@media (min-width: 640px){.portfolio-section{gap:0}}.section-title{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}@media (min-width: 640px){.section-title{font-size:1.5rem}}.section-text{font-size:1rem;line-height:1.6;margin:0;color:var(--text-secondary)}.projects-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:3rem}}.project-card{padding:2rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--card-background);transition:transform .2s ease,box-shadow .2s ease;min-height:200px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.project-thumbnail{width:100%;height:200px;margin-bottom:1.5rem;border-radius:4px;overflow:hidden}.project-thumbnail img{width:100%;height:100%;display:block;object-fit:cover}@media (min-width: 640px){.project-thumbnail{height:240px}}@media (min-width: 1024px){.project-thumbnail{height:280px}}.project-card-placeholder{display:flex;align-items:center;justify-content:center}.project-card-placeholder .project-title{font-size:4rem;margin:0;color:var(--text-secondary);font-weight:300}@media (min-width: 640px){.project-card-placeholder .project-title{font-size:5rem}}@media (min-width: 1024px){.project-card-placeholder .project-title{font-size:6rem}}@media (min-width: 640px){.project-card{padding:2.5rem;min-height:220px}}@media (min-width: 1024px){.project-card{padding:3rem;min-height:240px}}.project-card-link{text-decoration:none;display:block;color:inherit}.project-card-link:hover,.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.project-title{font-size:1.25rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}@media (min-width: 640px){.project-title{font-size:1.5rem;margin-bottom:1rem}}@media (min-width: 1024px){.project-title{font-size:1.75rem}}.project-description{font-size:1rem;line-height:1.7;margin:0;color:var(--text-secondary)}@media (min-width: 640px){.project-description{font-size:1.125rem}}@media (min-width: 1024px){.project-description{font-size:1.25rem}}.contact-link{color:var(--text-primary);text-decoration:none;border-bottom:1px solid var(--border-color);transition:border-color .2s ease}.contact-link:hover{border-bottom-color:var(--text-primary)}.back-link{display:inline-block;margin-bottom:2rem;padding:.75rem 1.5rem;color:var(--text-primary);text-decoration:none;font-size:1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--card-background);transition:all .2s ease}.back-link:hover{background-color:var(--hover-bg);border-color:var(--text-primary)}.project-detail-card{padding:3rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--card-background)}@media (min-width: 640px){.project-detail-card{padding:4rem}}@media (min-width: 1024px){.project-detail-card{padding:5rem}}.project-detail-content{display:flex;flex-direction:column;gap:2rem}.project-link-container{margin-top:1rem;display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.project-link-container{flex-direction:row;gap:1rem}}.external-link{display:inline-block;color:#fff;text-decoration:none;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;border:1px solid var(--text-primary);border-radius:8px;background-color:var(--text-primary);transition:all .2s ease}.external-link:hover{background-color:var(--text-secondary);border-color:var(--text-secondary);color:#fff}.external-link-secondary{background-color:var(--card-background);color:var(--text-primary);border-color:var(--border-color)}.external-link-secondary:hover{background-color:var(--hover-bg);border-color:var(--text-primary);color:var(--text-primary)}.project-layout{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start}@media (min-width: 1024px){.project-layout{grid-template-columns:2fr 1fr;gap:4rem;align-items:start}}.project-sidebar{display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:2rem}@media (max-width: 1023px){.project-sidebar{justify-content:flex-start}}.gallery-section{margin-top:4rem;width:100%}@media (min-width: 1024px){.gallery-section{margin-top:6rem}}.mytype-layout{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start}@media (min-width: 1024px){.mytype-layout{grid-template-columns:2fr 1fr;gap:4rem;align-items:start}}.font-card-container{display:flex;justify-content:center;align-items:start}@media (max-width: 1023px){.font-card-container{justify-content:flex-start}}.font-card-wrapper{perspective:1000px;width:25rem;aspect-ratio:4/5;flex:0 0 auto;cursor:crosshair;padding:.5rem;box-sizing:border-box;transform:translateZ(0);overflow:visible;position:relative;opacity:0;transition:opacity .3s ease}.font-card-wrapper.animate{opacity:1}.font-card-wrapper:hover .font-card-inner{transition:all .4s ease-in-out;box-shadow:0 2px 18px #00000008}.font-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .4s}.font-card-inner.flipped{transform:rotateY(180deg)}.font-card-front,.font-card-back-wrapper{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:.5rem;box-shadow:0 2px 8px #0000001a;background:var(--card-background);border:1px solid var(--border-color);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1rem;box-sizing:border-box}.font-card-back-wrapper{transform:rotateY(180deg);text-align:left;padding:0}.font-card-image{width:100%;height:100%;object-fit:cover;border-radius:.5rem;pointer-events:none;-webkit-user-select:none;user-select:none}.font-card-back-content{width:100%;height:100%;border-radius:.5rem}@media (max-width: 768px){.font-card-wrapper{width:20rem}}.font-card-back{width:100%;height:100%;display:flex;flex-direction:column;padding:1.5rem;box-sizing:border-box;position:relative}.font-card-back.with-grid{background-image:linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:20px 20px}.font-card-back-header{margin-bottom:1.5rem}.font-card-back-name{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.font-card-back-tagline{font-size:.875rem;margin:0;color:var(--text-secondary)}.font-card-back-preview{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:1rem}.font-card-back-preview-text{font-size:1rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;text-align:center;width:100%}.font-card-back-preview-text[data-type=letters]{font-size:.875rem;line-height:1.4}.font-card-back-toggle-group{display:flex;gap:.5rem;justify-content:center}.font-card-back-control-button{padding:.5rem 1rem;border:1px solid var(--border-color);background-color:var(--card-background);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s ease;font-family:inherit}.font-card-back-control-button:hover{background-color:var(--hover-bg)}.font-card-back-control-button.active{background-color:var(--text-primary);color:var(--background);border-color:var(--text-primary)}@media (max-width: 768px){.font-card-back{padding:1rem}.font-card-back-name{font-size:1.25rem}.font-card-back-preview-text{font-size:.875rem}}.drawing-canvas-container{width:100%;display:flex;flex-direction:column;gap:1rem}.drawing-tools{display:flex;flex-direction:column;gap:1rem;padding:1rem;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px}.color-picker-section,.brush-size-section,.tool-selector-section{display:flex;flex-direction:column;gap:.5rem}.color-picker-section label,.brush-size-section label,.tool-selector-section label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.color-palette{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.color-button{width:32px;height:32px;border:2px solid var(--border-color);border-radius:4px;cursor:pointer;transition:transform .1s ease;padding:0}.color-button:hover{transform:scale(1.1)}.color-button.active{border-color:var(--text-primary);border-width:3px;transform:scale(1.1)}.brush-slider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none}.brush-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--text-primary);cursor:pointer}.brush-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--text-primary);cursor:pointer;border:none}.tool-buttons{display:flex;gap:.75rem}.tool-button{flex:1;padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--card-background);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.tool-button:hover{background-color:var(--hover-bg)}.tool-button-primary{background-color:var(--text-primary);color:#fff;border-color:var(--text-primary)}.tool-button-primary:hover{background-color:var(--text-secondary);border-color:var(--text-secondary)}.tool-selector{display:flex;gap:.5rem}.tool-select-button{flex:1;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--card-background);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.tool-select-button:hover{background-color:var(--hover-bg)}.tool-select-button.active{background-color:var(--text-primary);color:#fff;border-color:var(--text-primary)}.tool-select-button.active:hover{background-color:var(--text-secondary);border-color:var(--text-secondary)}.drawing-canvas{width:100%;height:300px;border:2px solid var(--border-color);border-radius:8px;cursor:crosshair;touch-action:none;background-color:#fff;display:block}.save-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.save-dialog{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:2rem;max-width:400px;width:90%;display:flex;flex-direction:column;gap:1.5rem}.save-dialog h3{margin:0;font-size:1.5rem;color:var(--text-primary)}.name-input{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:inherit;background-color:var(--background);color:var(--text-primary)}.name-input:focus{outline:none;border-color:var(--text-primary)}.save-dialog-buttons{display:flex;gap:1rem}.dialog-button{flex:1;padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.dialog-button-secondary{background-color:var(--card-background);color:var(--text-primary)}.dialog-button-secondary:hover{background-color:var(--hover-bg)}.dialog-button-primary{background-color:var(--text-primary);color:#fff;border-color:var(--text-primary)}.dialog-button-primary:hover{background-color:var(--text-secondary);border-color:var(--text-secondary)}@media (max-width: 768px){.color-palette{grid-template-columns:repeat(5,1fr)}.drawing-canvas{height:250px}}.gallery-container{width:100%}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.gallery-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.gallery-reset-info{margin:0;font-size:.875rem;color:var(--text-secondary)}.gallery-empty{padding:3rem 1rem;text-align:center;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px}.gallery-empty p{margin:0;color:var(--text-secondary)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.gallery-item{position:relative;aspect-ratio:4/3;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;cursor:pointer;background-color:var(--card-background);transition:transform .2s ease,box-shadow .2s ease}.gallery-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.gallery-item img{width:100%;height:100%;object-fit:contain;background-color:#fff}.gallery-item-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:1rem .5rem .5rem}.gallery-author{color:#fff;font-size:.75rem;font-weight:500}.gallery-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.gallery-modal{position:relative;max-width:90%;max-height:90vh;background-color:var(--card-background);border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:1rem}.gallery-modal-close{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;border:none;background-color:#00000080;color:#fff;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.gallery-modal-close:hover{background-color:#000000b3}.gallery-modal img{max-width:100%;max-height:70vh;object-fit:contain;background-color:#fff;border-radius:4px}.gallery-modal-info{text-align:center}.gallery-modal-author{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.gallery-modal-date{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary)}@media (max-width: 768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.gallery-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.asset-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:0}@media (min-width: 768px){.asset-gallery{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem}}.asset-gallery.full-width{grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.asset-gallery.full-width{gap:2.5rem}}.asset-item{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;background-color:var(--card-background);border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease;aspect-ratio:1 / 1}.asset-gallery.full-width .asset-item{aspect-ratio:16 / 9}.asset-item:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.asset-gallery.preserve-aspect .asset-item{aspect-ratio:auto}.asset-item img,.asset-item video{width:100%;height:100%;display:block;object-fit:cover}.asset-gallery.preserve-aspect .asset-item img,.asset-gallery.preserve-aspect .asset-item video{height:auto;object-fit:contain}.asset-video-thumbnail{position:relative;width:100%;height:100%;background-color:#000}.asset-video-thumbnail video{width:100%;height:100%;object-fit:cover}.asset-onedrive-thumbnail{overflow:hidden;background-color:#000}.asset-onedrive-thumbnail iframe{width:100%;height:100%;border:none;pointer-events:none;opacity:.8}.asset-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);pointer-events:none}.asset-gallery-loading,.asset-gallery-empty{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.asset-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.asset-modal{position:relative;max-width:95vw;max-height:95vh;width:90vw;height:auto;background-color:var(--card-background);border-radius:8px;overflow:hidden}.asset-modal-close{position:absolute;top:1rem;right:1rem;background-color:#000000b3;color:#fff;border:none;width:2.5rem;height:2.5rem;border-radius:50%;font-size:1.5rem;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.asset-modal-close:hover{background-color:#000000e6}.asset-modal img,.asset-modal video{width:100%;height:auto;max-height:80vh;display:block;object-fit:contain}.asset-modal iframe{width:100%;min-height:70vh;aspect-ratio:16 / 9;border:none;display:block;background-color:#000}.asset-modal-video{width:95vw;max-width:1400px}@media (min-width: 768px){.asset-modal iframe{min-height:80vh}.asset-modal-video{width:90vw;max-width:1600px}}.asset-modal-title{padding:1.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);text-align:center}.asset-modal-description{padding:0 1.5rem 1.5rem;font-size:1rem;color:var(--text-secondary);text-align:center;line-height:1.6}.bulk-upload-container{max-width:1200px;margin:0 auto;padding:2rem}.bulk-upload-header{margin-bottom:2rem}.bulk-upload-header h2{margin:0 0 .5rem;font-size:2rem;color:var(--text-primary)}.bulk-upload-header p{margin:0;color:var(--text-secondary)}.bulk-upload-dropzone{border:2px dashed var(--border-color);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s ease;background-color:var(--card-background);margin-bottom:2rem}.bulk-upload-dropzone:hover{border-color:var(--text-primary);background-color:var(--hover-bg)}.bulk-upload-dropzone.dragging{border-color:var(--text-primary);background-color:var(--hover-bg);transform:scale(1.02)}.bulk-upload-input-hidden{display:none}.bulk-upload-label{display:flex;flex-direction:column;align-items:center;gap:1rem;cursor:pointer;color:var(--text-secondary)}.bulk-upload-label svg{color:var(--text-primary)}.bulk-upload-label p{margin:0;font-size:1rem}.bulk-upload-hint{font-size:.875rem;color:var(--text-secondary)}.bulk-upload-files{margin-top:2rem}.bulk-upload-actions{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.bulk-upload-actions button{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-primary);font-family:inherit;font-size:.875rem;transition:all .2s ease}.bulk-upload-actions button:hover:not(:disabled){background-color:var(--hover-bg);border-color:var(--text-primary)}.bulk-upload-actions button:disabled{opacity:.5;cursor:not-allowed}.bulk-upload-count{color:var(--text-secondary);font-size:.875rem;margin-left:auto}.bulk-upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.bulk-upload-item{position:relative;border:2px solid var(--border-color);border-radius:8px;overflow:hidden;background-color:var(--card-background);transition:all .2s ease}.bulk-upload-item.selected{border-color:var(--text-primary)}.bulk-upload-checkbox{position:absolute;top:.5rem;left:.5rem;z-index:10;background:#ffffffe6;border-radius:4px;padding:.25rem}.bulk-upload-checkbox input{cursor:pointer}.bulk-upload-preview{width:100%;aspect-ratio:1 / 1;overflow:hidden;background-color:#000}.bulk-upload-preview img,.bulk-upload-preview video{width:100%;height:100%;object-fit:cover}.bulk-upload-info{padding:.75rem}.bulk-upload-filename{margin:0 0 .5rem;font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bulk-upload-category-select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--card-background);color:var(--text-primary);font-family:inherit;font-size:.875rem;cursor:pointer}.bulk-upload-category-select:disabled{opacity:.5;cursor:not-allowed}.bulk-upload-remove{position:absolute;top:.5rem;right:.5rem;width:1.5rem;height:1.5rem;border:none;background:#ef4444e6;color:#fff;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;z-index:10;transition:background-color .2s ease}.bulk-upload-remove:hover:not(:disabled){background:#ef4444}.bulk-upload-remove:disabled{opacity:.5;cursor:not-allowed}.bulk-upload-submit{display:flex;flex-direction:column;gap:1rem;align-items:center}.bulk-upload-progress-bar{width:100%;max-width:400px;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden}.bulk-upload-progress-fill{height:100%;background-color:var(--text-primary);transition:width .3s ease}.bulk-upload-button{padding:.75rem 2rem;background-color:var(--text-primary);color:var(--card-background);border:none;border-radius:4px;font-size:1rem;font-family:inherit;cursor:pointer;transition:opacity .2s ease}.bulk-upload-button:hover:not(:disabled){opacity:.9}.bulk-upload-button:disabled{opacity:.5;cursor:not-allowed}.bulk-upload-error{margin-top:1rem;padding:1rem;background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:4px;color:#ef4444}.bulk-upload-error p{margin:0}.bulk-upload-success{margin-top:1rem;padding:1rem;background-color:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:4px;color:#22c55e}.bulk-upload-success p{margin:0}.bulk-upload-reddit-section{margin-bottom:2rem;padding:1.5rem;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px}.bulk-upload-reddit-form{display:flex;gap:1rem;align-items:flex-start}.bulk-upload-reddit-input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-family:inherit;font-size:1rem;background-color:var(--card-background);color:var(--text-primary)}.bulk-upload-reddit-input:focus{outline:none;border-color:var(--text-primary)}.bulk-upload-reddit-input:disabled{opacity:.6;cursor:not-allowed}.bulk-upload-reddit-button{padding:.75rem 1.5rem;background-color:var(--text-primary);color:var(--card-background);border:none;border-radius:4px;font-size:1rem;font-family:inherit;cursor:pointer;white-space:nowrap;transition:opacity .2s ease}.bulk-upload-reddit-button:hover:not(:disabled){opacity:.9}.bulk-upload-reddit-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.bulk-upload-reddit-form{flex-direction:column}.bulk-upload-reddit-button{width:100%}}:root{--background: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #e0e0e0;--card-background: #FFFFFF;--hover-bg: #f0f0f0;--grid-color: #000000}*{box-sizing:border-box;margin:0;padding:0}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background-color:var(--background);background-image:radial-gradient(circle,rgba(0,0,0,.3) 1.5px,transparent 1.5px);background-size:60px 60px;background-position:0 0;color:var(--text-primary);line-height:1.6}#root{min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1}body[data-mode=developer] ::selection{background-color:#3b82f6;color:#fff}body[data-mode=developer] ::-moz-selection{background-color:#3b82f6;color:#fff}body[data-mode=designer] ::selection{background-color:#ef4444;color:#fff}body[data-mode=designer] ::-moz-selection{background-color:#ef4444;color:#fff}
