.user-menu{position:relative}.avatar-button{padding:0;background:none;border:none;cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast)}.avatar-button:hover .avatar{background:var(--gradient-primary);color:var(--white);transform:scale(1.05)}.avatar-button:active .avatar{transform:scale(.95)}.avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:2px solid var(--gray-200);border-radius:var(--radius-full);color:var(--gray-700);transition:all var(--transition-base)}.user-menu-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;width:240px;background:#fffffff2;backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:var(--z-dropdown);animation:dropdownSlideIn var(--transition-fast)}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700);text-align:left;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.menu-item:hover{background:var(--gray-100);color:var(--gray-900);transform:translate(2px)}.menu-item.logout{color:var(--error-500)}.menu-item.logout:hover{background:#ef44441a;color:var(--error-500)}.menu-divider{height:1px;background:var(--gray-200);margin:var(--space-2) 0}@media(max-width:768px){.user-menu-dropdown{width:220px}}.header{grid-area:header;display:flex;justify-content:space-between;align-items:center;padding:0 var(--space-6);height:56px;background:var(--white);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:var(--z-sticky)}.header-left{display:flex;align-items:center;gap:var(--space-3)}.hamburger-button{display:none;padding:var(--space-2);background:none;border:none;color:var(--gray-700);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-base);position:relative}.hamburger-button:hover{background:var(--gradient-primary);color:var(--white);transform:scale(1.05)}.hamburger-button:active{transform:scale(.95)}.app-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0;position:relative;display:inline-block;cursor:default}.app-title:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:3px;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-base)}.app-title:hover:after{width:100%}@media(max-width:768px){.header{padding:0 var(--space-4)}.hamburger-button{display:flex}.app-title{font-size:var(--text-xl)}}.sidebar{grid-area:sidebar;background:var(--white);border-right:1px solid var(--gray-200);padding:var(--space-4) 0;overflow-y:auto}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1);padding:0 var(--space-3)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-base);position:relative}.sidebar-link:hover{background:var(--gray-100);color:var(--gray-900)}.sidebar-link:hover svg{transform:scale(1.1)}.sidebar-link.active{background:var(--gradient-primary);color:var(--white);box-shadow:var(--shadow-gradient);font-weight:var(--font-semibold)}.sidebar-link svg{flex-shrink:0;transition:transform var(--transition-base)}@media(max-width:768px){.sidebar-overlay{position:fixed;right:0;bottom:0;left:0;top:56px;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{position:fixed;top:56px;left:0;bottom:0;width:280px;z-index:var(--z-modal);transform:translate(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-xl)}.sidebar.is-open{transform:translate(0)}.sidebar-nav{padding:var(--space-4)}.sidebar-link{font-size:var(--text-lg);padding:var(--space-4)}}.root-layout{display:grid;grid-template-areas:"header header" "sidebar main";grid-template-rows:56px 1fr;grid-template-columns:256px 1fr;min-height:100vh;background:var(--cream-50)}.main-content{grid-area:main;overflow-y:auto;padding:var(--space-6)}.main-content-inner{max-width:1152px;margin:0 auto}@media(max-width:768px){.root-layout{grid-template-areas:"header" "main";grid-template-rows:56px 1fr;grid-template-columns:1fr}.main-content{padding:var(--space-4)}}:root{--gradient-primary: linear-gradient(135deg, #ff6b35 0%, #ff8e53 50%, #ffb88c 100%);--gradient-primary-hover: linear-gradient(135deg, #f55a24 0%, #ff7d42 50%, #ffa77b 100%);--gradient-accent: linear-gradient(90deg, #ff5722 0%, #ff7043 100%);--gradient-background: linear-gradient(to bottom right, #fff9f5 0%, #fff3eb 100%);--primary-500: #ff6b35;--primary-600: #f55a24;--primary-700: #e04d1a;--accent-coral: #ff7043;--accent-peach: #ffb88c;--gray-50: #f8f9fa;--gray-100: #f1f3f5;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-400: #ced4da;--gray-500: #adb5bd;--gray-600: #6c757d;--gray-700: #495057;--gray-800: #343a40;--gray-900: #212529;--white: #ffffff;--black: #000000;--success-500: #10b981;--warning-500: #f59e0b;--error-500: #ef4444;--info-500: #3b82f6;--font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--text-5xl: 48px;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.2;--leading-snug: 1.4;--leading-normal: 1.6;--leading-relaxed: 1.8;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .01em;--tracking-wider: .02em;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1), 0 10px 10px rgba(0, 0, 0, .04);--shadow-gradient: 0 8px 16px rgba(255, 107, 53, .15);--glass-backdrop: blur(12px) saturate(180%);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:var(--font-body);color:var(--gray-900);background:var(--gradient-background);background-attachment:fixed;min-height:100vh;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-3)}.login-form{width:100%;max-width:400px;padding:var(--space-8);background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border-top:4px solid transparent;border-image:var(--gradient-primary) 1;border-image-slice:1 0 0 0}.login-form h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2);text-align:center;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{font-family:var(--font-body);color:var(--gray-600);text-align:center;margin-bottom:var(--space-6);font-size:var(--text-sm)}.login-input{width:100%;padding:var(--space-3);border:2px solid var(--gray-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-base);margin-bottom:var(--space-4);background:var(--white);color:var(--gray-900);transition:all var(--transition-base)}.login-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #ff6b351a}.login-button{width:100%;padding:var(--space-3) var(--space-4);background:var(--gradient-primary);color:var(--white);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-gradient)}.login-button:hover{background:var(--gradient-primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.login-button:active{transform:translateY(0)}.error-message{color:var(--error-500);font-family:var(--font-body);font-size:var(--text-sm);margin-bottom:var(--space-4);padding:var(--space-3);background:#ef44441a;border-radius:var(--radius-md);border-left:3px solid var(--error-500)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-semibold);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;border:none;white-space:nowrap}.button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button-primary{background:var(--gradient-primary);color:var(--white);box-shadow:var(--shadow-gradient)}.button-primary:hover{background:var(--gradient-primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.button-primary:active{transform:translateY(0)}.button-secondary{background:transparent;color:var(--primary-500);border:2px solid var(--primary-500)}.button-secondary:hover{background:var(--primary-500);color:var(--white);box-shadow:var(--shadow-gradient)}.button-tertiary{background:transparent;color:var(--gray-700)}.button-tertiary:hover{background:var(--gray-100);color:var(--gray-900)}.button-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.button-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-lg)}.button-full{width:100%}.date-filter{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;padding:0 var(--space-6);margin-bottom:var(--space-8)}.date-filter-inputs{display:flex;align-items:center;gap:var(--space-2)}.date-input{font-family:var(--font-body);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border:2px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);color:var(--gray-900);transition:all var(--transition-base);width:auto;max-width:150px}.date-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #ff6b351a}.filter-separator,.date-separator{font-family:var(--font-body);color:var(--gray-500);font-size:var(--text-sm);font-weight:var(--font-normal)}.filter-actions,.date-filter-actions{display:flex;gap:var(--space-2)}.filter-button{font-family:var(--font-body);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;transition:all var(--transition-fast);cursor:pointer}.filter-apply{background:var(--charcoal-900);color:var(--warm-white);border:none}.filter-apply:hover{background:var(--charcoal-700)}.filter-reset{background:transparent;color:var(--charcoal-500);border:none}.filter-reset:hover{color:var(--charcoal-900)}@media(max-width:768px){.date-filter{padding:0 var(--space-4);margin-bottom:var(--space-6)}.date-filter-inputs{flex-direction:column;align-items:stretch;gap:var(--space-2);width:100%}.date-separator{text-align:center}.date-input{width:100%}.date-filter-actions{width:100%;gap:var(--space-2)}.filter-button{flex:1}}.image-grid-container{margin-bottom:var(--spacing-xl)}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media(max-width:640px){.image-grid{grid-template-columns:1fr}}.image-card{background:var(--white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;cursor:pointer}.image-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.image-card-thumbnail{width:100%;aspect-ratio:1;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.image-card-thumbnail img{width:100%;height:100%;object-fit:cover}.image-loading,.image-error{color:var(--text-secondary);font-size:.875rem}.image-card-info{padding:var(--spacing-sm)}.image-date{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.image-member{font-weight:600;margin-bottom:.25rem}.image-notes{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4)}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:48px;height:48px;background:#ffffff26;backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);font-size:var(--text-3xl);line-height:1;color:var(--white);cursor:pointer;z-index:var(--z-modal);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#ffffff40;transform:scale(1.05)}.modal-close:active{transform:scale(.95)}.modal-image{max-width:95vw;max-height:95vh;object-fit:contain;animation:modalEnter var(--transition-slow) cubic-bezier(.4,0,.2,1)}.modal-loading,.modal-error{color:var(--white);font-family:var(--font-body);font-size:var(--text-base)}.modal-pagination-counter{position:absolute;top:var(--space-4);left:50%;transform:translate(-50%);background:#0009;backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);color:var(--white);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);z-index:var(--z-modal);pointer-events:none;-webkit-user-select:none;user-select:none;border:1px solid rgba(255,255,255,.1)}.modal-overlay,.card-image-container{touch-action:pan-x pan-y}.modal-download-button{position:absolute;bottom:var(--space-4);left:50%;transform:translate(-50%);width:56px;height:56px;background:var(--gradient-primary);border:none;border-radius:var(--radius-full);font-size:var(--text-2xl);line-height:1;color:var(--white);cursor:pointer;z-index:var(--z-modal);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-gradient)}.modal-download-button:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translate(-50%) translateY(-4px);box-shadow:var(--shadow-xl)}.modal-download-button:active:not(:disabled){transform:translate(-50%) translateY(0)}.modal-download-button:disabled{opacity:.5;cursor:not-allowed}.download-icon{display:inline-block;font-size:var(--text-2xl)}.download-icon-loading{display:inline-block;font-size:var(--text-xl);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.modal-download-error{position:absolute;bottom:var(--space-12);left:50%;transform:translate(-50%);background:#c94c3de6;color:var(--warm-white);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:var(--text-sm);z-index:var(--z-modal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:80%;text-align:center}@media(max-width:768px){.modal-download-button{width:44px;height:44px;bottom:var(--space-3)}.modal-download-error{bottom:var(--space-10);font-size:var(--text-xs)}}.load-more-container{display:flex;justify-content:center;margin:var(--spacing-lg) 0}.load-more-button{padding:var(--spacing-sm) var(--spacing-xl);background:var(--primary);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:background .2s}.load-more-button:hover{background:var(--primary-hover)}.loading-container,.loading-more,.empty-container,.error-container{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.empty-hint,.error-hint{font-size:.875rem;margin-top:.5rem}.error-container{background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.error-container .error-message{color:var(--error);font-size:1rem;margin-bottom:.5rem}.comment-grid-container{margin-bottom:var(--spacing-xl)}.comment-grid{column-count:3;column-gap:var(--space-8);max-width:1200px;margin:0 auto var(--space-6)}@media(max-width:1024px){.comment-grid{column-count:2;column-gap:var(--space-6)}}@media(max-width:768px){.comment-grid{column-count:1}}.comment-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-slow);break-inside:avoid;margin-bottom:var(--space-8);animation:fadeUp var(--transition-slow) cubic-bezier(.4,0,.2,1) backwards;box-shadow:var(--shadow-sm);position:relative}.comment-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.comment-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--gray-300)}.comment-card:hover:before{opacity:1}.comment-card:nth-child(1){animation-delay:0ms}.comment-card:nth-child(2){animation-delay:50ms}.comment-card:nth-child(3){animation-delay:.1s}.comment-card:nth-child(4){animation-delay:.15s}.comment-card:nth-child(5){animation-delay:.2s}.comment-card:nth-child(6){animation-delay:.25s}.comment-card:nth-child(7){animation-delay:.3s}.comment-card:nth-child(8){animation-delay:.35s}.comment-card:nth-child(9){animation-delay:.4s}.card-image-container{position:relative;width:100%;aspect-ratio:4 / 5;overflow:hidden;cursor:pointer;background:var(--gray-100)}.card-featured-image{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-slow),transform var(--transition-slow)}.card-featured-image.loaded{opacity:1}.comment-card:hover .card-featured-image{transform:scale(1.02)}.image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--gray-100),var(--gray-200))}.image-placeholder.blur{filter:blur(20px)}.card-date{padding:var(--space-3) var(--space-4) var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);letter-spacing:var(--tracking-normal);color:var(--gray-600);margin:0}.carousel-indicators{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-2);pointer-events:none}.carousel-button{pointer-events:all;background:#ffffffe6;backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);color:var(--gray-900);border:1px solid rgba(255,255,255,.3);width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--transition-base);opacity:0;font-size:var(--text-lg);font-weight:var(--font-semibold)}.comment-card:hover .carousel-button{opacity:1}.carousel-button:hover{background:var(--white);box-shadow:var(--shadow-lg);transform:scale(1.1)}.carousel-button:active{transform:scale(.95)}.carousel-dots{position:absolute;bottom:var(--space-3);left:50%;transform:translate(-50%);display:flex;gap:var(--space-2);pointer-events:all;background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:var(--space-2);border-radius:var(--radius-full)}.carousel-dots .dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--gray-400);cursor:pointer;transition:all var(--transition-base)}.carousel-dots .dot.active{background:var(--gradient-primary);width:24px}.carousel-dots .dot:hover{background:var(--primary-500)}.card-notes{padding:var(--space-3) var(--space-4) var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--gray-700);white-space:pre-wrap;border-top:1px solid var(--gray-200)}.comment-images-empty{padding:var(--space-6);text-align:center;color:var(--gray-600);font-family:var(--font-body);font-size:var(--text-sm);background:var(--gray-50);border-radius:var(--radius-md);margin:var(--space-4)}.image-error{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:var(--font-body);font-size:var(--text-sm);color:var(--gray-600);background:var(--gray-100)}@media(max-width:768px){.comment-card{max-width:600px;margin:0 auto var(--space-6)}.comment-card:hover{transform:none}.carousel-button{opacity:.7}.carousel-button:hover{opacity:1}}.album-browser{padding:0 var(--space-6)}.album-browser-header{margin-bottom:var(--space-6)}.album-browser-header h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-6);color:var(--gray-900)}.album-list{display:flex;flex-direction:column;gap:var(--space-3);max-width:800px;margin:0 auto}.album-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.album-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--gray-300)}.album-info{flex:1}.album-title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900);margin-bottom:var(--space-2)}.album-meta{display:flex;gap:var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);color:var(--gray-600)}.download-button{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-semibold);padding:var(--space-3) var(--space-5);background:var(--gradient-primary);color:var(--white);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;box-shadow:var(--shadow-gradient)}.download-button:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.download-button:disabled{background:var(--gray-300);color:var(--gray-500);cursor:not-allowed;opacity:.6}.empty-state{text-align:center;padding:var(--space-12);color:var(--gray-600);font-family:var(--font-body);font-size:var(--text-base);background:var(--gray-50);border-radius:var(--radius-lg);border:2px dashed var(--gray-300)}.loading{text-align:center;padding:var(--space-12);color:var(--gray-600);font-family:var(--font-body);font-size:var(--text-base)}@media(max-width:768px){.album-browser{padding:0 var(--space-4)}.album-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.download-button{width:100%}}.saved-albums{padding:0 var(--space-6)}.saved-albums-header{margin-bottom:var(--space-6)}.saved-albums-header h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--gray-900)}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4);max-width:1200px;margin:0 auto}.saved-album-card{background:var(--white);border:1px solid var(--gray-200);padding:var(--space-5);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-base)}.saved-album-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--gray-300)}.album-card-content{display:flex;flex-direction:column;gap:var(--space-2)}.album-card-title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900)}.album-card-meta{display:flex;gap:var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);color:var(--gray-600)}.album-card-status{margin-top:var(--space-1)}.status-badge{display:inline-block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.status-badge.success{background:#10b9811a;color:var(--success-500);border:1px solid rgba(16,185,129,.2)}.status-badge.partial{background:#f59e0b1a;color:var(--warning-500);border:1px solid rgba(245,158,11,.2)}.status-badge.failed{background:#ef44441a;color:var(--error-500);border:1px solid rgba(239,68,68,.2)}@media(max-width:768px){.saved-albums{padding:0 var(--space-4)}.album-grid{grid-template-columns:1fr}}.album-photo-grid{padding:0 var(--space-6)}.album-photo-grid-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--sand-200)}.back-button{font-family:var(--font-body);font-size:var(--text-base);font-weight:500;padding:var(--space-2) var(--space-3);background:transparent;color:var(--charcoal-500);border:1px solid var(--sand-200);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.back-button:hover{background:var(--sand-100);color:var(--charcoal-900)}.album-photo-grid-header h2{flex:1;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:500;color:var(--charcoal-900)}.photo-count{font-family:var(--font-body);font-size:var(--text-sm);color:var(--charcoal-500)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3);max-width:1200px;margin:0 auto}.photo-item{aspect-ratio:1;overflow:hidden;border-radius:var(--radius-sm);cursor:pointer;background:var(--sand-100);transition:all var(--transition-fast)}.photo-item:hover{transform:scale(1.05);box-shadow:var(--shadow-soft)}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--charcoal-400);font-family:var(--font-body);font-size:var(--text-sm)}@media(max-width:768px){.album-photo-grid{padding:0 var(--space-4)}.album-photo-grid-header{flex-wrap:wrap}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-2)}}
