@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";body{margin:0;font-family:Inter,sans-serif;overflow:hidden}.app-wrapper{background:#e5e5f7;width:100vw;height:100vh;display:flex}.app-wrapper.desktop-layout{flex-direction:row}.app-wrapper.mobile-layout{flex-direction:column}.sidebar{z-index:20;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:220px;display:flex;box-shadow:2px 0 10px #0000000d}.sidebar .thumb-list{background:#f8fafc;flex-direction:column;flex:1;gap:10px;padding:10px;display:flex;overflow-y:auto}.sidebar .thumb-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:8px;transition:all .2s;overflow:hidden;box-shadow:0 1px 3px #0000001a}.sidebar .thumb-item:hover{border-color:#cbd5e1}.sidebar .thumb-item.active{border-color:#3b82f6;box-shadow:0 4px 6px #3b82f64d}.sidebar .thumb-item img{object-fit:cover;width:100%;height:100px;display:block}.sidebar .thumb-name{text-align:center;color:#475569;white-space:nowrap;text-overflow:ellipsis;padding:6px;font-size:11px;overflow:hidden}.main-area{background-image:radial-gradient(#cbd5e1 1px,#0000 1px);background-size:20px 20px;flex:1;position:relative;overflow:hidden}.toolbar{z-index:10;background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:10px;padding:8px 12px;display:flex;position:absolute;top:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 15px -3px #0000001a}.bottom-bar{z-index:20;background:#fff;border-top:1px solid #e2e8f0;flex-direction:column;display:flex;box-shadow:0 -2px 10px #0000000d}.bottom-thumbnails{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0;gap:10px;padding:10px;display:flex;overflow-x:auto}.bottom-thumbnails::-webkit-scrollbar{height:6px}.bottom-thumbnails::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bottom-bar .thumb-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:8px;flex-direction:column;flex-shrink:0;width:80px;transition:all .2s;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.bottom-bar .thumb-item:hover{border-color:#cbd5e1}.bottom-bar .thumb-item.active{border-color:#3b82f6;box-shadow:0 4px 6px #3b82f64d}.bottom-bar .thumb-item img{object-fit:cover;width:100%;height:60px;display:block}.bottom-bar .thumb-name{text-align:center;color:#475569;white-space:nowrap;text-overflow:ellipsis;padding:4px;font-size:11px;overflow:hidden}.bottom-tools{background:#fff;flex-shrink:0;align-items:center;gap:6px;padding:8px 10px;display:flex;overflow-x:auto}.bottom-tools .file-input-wrapper{flex-shrink:0}.bottom-tools .divider{background:#e2e8f0;flex-shrink:0;width:1px;height:24px;margin:0 2px}.bottom-tools::-webkit-scrollbar{height:6px}.bottom-tools::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.btn{cursor:pointer;color:#475569;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn:hover:not(:disabled){color:#0f172a;background:#f1f5f9}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover:not(:disabled){color:#fff;background:#1d4ed8}.btn-danger{color:#ef4444}.btn-danger:hover:not(:disabled){color:#dc2626;background:#fef2f2}.file-input-wrapper{display:inline-block;position:relative;overflow:hidden}.file-input-wrapper input[type=file]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.divider{background:#cbd5e1;flex-shrink:0;width:1px;height:24px}.hint-text{color:#fff;pointer-events:none;z-index:10;background:#000000b3;border-radius:20px;padding:6px 16px;font-size:13px;position:absolute;top:20px;left:50%;transform:translate(-50%)}.empty-state{box-sizing:border-box;background:#f8fafc;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.upload-box{cursor:pointer;color:#64748b;text-align:center;background:#fff;border:2px dashed #94a3b8;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:400px;height:100%;max-height:300px;transition:all .2s;display:flex;position:relative;box-shadow:0 4px 6px -1px #0000001a}.upload-box:hover{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.upload-box h2{color:#334155;margin:10px 0 5px;font-size:20px}.upload-box p{opacity:.8;margin:0;font-size:14px}.upload-box input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.btn-icon{border-radius:10px;flex-shrink:0;justify-content:center;min-width:40px;min-height:40px;padding:8px}.btn-icon.active-tool{border:1px solid #facc15;color:#ca8a04!important;background:#fef08a!important}.mobile-history-overlay{z-index:50;background:#0006;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-history-modal{background:#fff;border-radius:20px 20px 0 0;flex-direction:column;width:100%;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow:hidden}.mobile-history-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.mobile-history-list{background:#f8fafc;flex-wrap:wrap;gap:10px;max-height:50vh;padding:20px;display:flex;overflow-y:auto}.mobile-history-list .thumb-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:8px;flex-direction:column;width:calc(33.33% - 7px);transition:all .2s;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.mobile-history-list .thumb-item:hover{border-color:#cbd5e1}.mobile-history-list .thumb-item.active{border-color:#3b82f6;box-shadow:0 4px 6px #3b82f64d}.mobile-history-list .thumb-item img{object-fit:cover;width:100%;height:80px;display:block}.mobile-history-list .thumb-name{text-align:center;color:#475569;white-space:nowrap;text-overflow:ellipsis;padding:6px;font-size:11px;overflow:hidden}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.floating-dim-toolbar{z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:9999px;align-items:center;gap:8px;padding:8px 16px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 25px -5px #00000026,0 8px 10px -6px #0000001a}.floating-dim-toolbar.mobile-floating{padding:6px 16px;bottom:90px}.project-list-page{background:linear-gradient(135deg,#f0f4ff 0%,#e8ecf4 100%);flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.project-header{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;box-shadow:0 1px 3px #0000000d}.project-header-left{align-items:center;gap:12px;display:flex}.project-logo{border-radius:10px;width:40px;height:40px}.project-header h1{color:#1e293b;margin:0;font-size:20px}.project-header p{color:#94a3b8;margin:0;font-size:13px}.project-create-bar{background:#fff;border-bottom:1px solid #e2e8f0;gap:10px;padding:16px 24px;display:flex}.project-input{border:1px solid #cbd5e1;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s}.project-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.project-grid{flex-direction:column;flex:1;gap:10px;padding:20px 24px;display:flex;overflow-y:auto}.project-card{cursor:pointer;background:#fff;border:1px solid #0000;border-radius:14px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000000f}.project-card:hover{border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f61f}.project-card:active{transform:scale(.99)}.project-card-icon{color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.project-card-info{flex:1;min-width:0}.project-card-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.project-card-date{color:#94a3b8;margin-top:2px;font-size:12px}.project-card-count{color:#3b82f6;background:#eff6ff;border-radius:99px;margin-top:4px;padding:2px 8px;font-size:11px;display:inline-block}.project-card-actions{flex-shrink:0;gap:4px;display:flex}.project-empty{color:#64748b;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.project-empty p{margin:4px 0}.btn-sm{min-width:28px;min-height:28px;padding:4px 6px}.loading-screen{color:#64748b;background:#f8fafc;flex-direction:column;justify-content:center;align-items:center;gap:12px;width:100vw;height:100vh;display:flex}.loading-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.gallery-view{z-index:30;background:#f8fafc;flex-direction:column;display:flex;position:absolute;inset:0;overflow:hidden}.gallery-header{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex;box-shadow:0 1px 3px #0000000d}.gallery-grid{flex:1;grid-template-columns:repeat(3,1fr);align-content:start;gap:8px;padding:12px;display:grid;overflow-y:auto}@media (width>=769px){.gallery-grid{grid-template-columns:repeat(4,1fr);gap:12px;padding:16px}}.gallery-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:10px;transition:all .2s;overflow:hidden;box-shadow:0 1px 3px #0000001a}.gallery-item:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.gallery-item:active{transform:scale(.97)}.gallery-item img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.gallery-item-name{text-align:center;color:#475569;white-space:nowrap;text-overflow:ellipsis;padding:6px 8px;font-size:11px;overflow:hidden}.gallery-item.selected{border-color:#2563eb;box-shadow:0 4px 12px #2563eb40}.gallery-item .select-overlay{background:#ffffffe6;border-radius:6px;justify-content:center;align-items:center;padding:2px;display:flex;position:absolute;top:6px;right:6px}.gallery-item{position:relative}.gallery-select-bar{background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;box-shadow:0 -2px 10px #0000000d}.sync-progress-bar{color:#2563eb;background:#eff6ff;border-bottom:1px solid #bfdbfe;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}@keyframes spin-anim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-icon{animation:1s linear infinite spin-anim}.upgrade-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.upgrade-modal{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:380px;padding:30px 24px;animation:.3s cubic-bezier(.16,1,.3,1) scaleIn;position:relative;box-shadow:0 25px 50px -12px #00000040}.upgrade-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;padding:4px;position:absolute;top:12px;right:12px}.upgrade-icon{border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex}.upgrade-title{color:#1e293b;margin:0 0 8px;font-size:20px}.upgrade-desc{color:#64748b;margin:0 0 20px;font-size:14px}.upgrade-tier-card{text-align:left;border:2px solid;border-radius:14px;margin-bottom:20px;overflow:hidden}.upgrade-tier-header{justify-content:space-between;align-items:center;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.upgrade-features{margin:0;padding:12px 16px;list-style:none}.upgrade-features li{color:#475569;padding:4px 0;font-size:13px}.upgrade-features li:before{content:"✓ ";color:inherit;font-weight:600}.upgrade-actions{flex-direction:column;gap:8px;display:flex}.upgrade-btn{border-radius:12px;justify-content:center;width:100%;padding:12px;font-size:15px;font-weight:600}.upgrade-btn-secondary{color:#94a3b8;font-size:13px}.pricing-page{background:linear-gradient(135deg,#f0f4ff 0%,#faf5ff 50%,#fff7ed 100%);flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.pricing-header{background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:16px 20px;display:flex;box-shadow:0 1px 3px #0000000d}.pricing-cards{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}@media (width>=769px){.pricing-cards{flex-direction:row;justify-content:center;align-items:flex-start;gap:20px;padding:40px}}.pricing-card{background:#fff;border:2px solid #e2e8f0;border-radius:18px;padding:24px 20px;transition:all .2s;position:relative;box-shadow:0 1px 3px #0000000f}@media (width>=769px){.pricing-card{flex:1;max-width:320px}}.pricing-card.popular{border-color:#2563eb;transform:scale(1.02);box-shadow:0 8px 25px #2563eb26}.pricing-badge{color:#fff;white-space:nowrap;background:#2563eb;border-radius:99px;padding:4px 14px;font-size:11px;font-weight:600;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pricing-card-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:12px;display:flex}.pricing-card-name{margin-bottom:4px;font-size:20px;font-weight:700}.pricing-card-price{color:#1e293b;margin-bottom:4px;font-size:22px;font-weight:800}.pricing-card-desc{color:#94a3b8;margin:0 0 16px;font-size:13px}.pricing-card-features{margin:0 0 20px;padding:0;list-style:none}.pricing-card-features li{color:#475569;align-items:center;gap:8px;padding:5px 0;font-size:13px;display:flex}.pricing-card-btn{border-radius:12px;justify-content:center;width:100%;padding:12px;font-size:15px;font-weight:600}.pricing-card.current{border-color:#34d399}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.auth-page{background:linear-gradient(135deg,#eff6ff 0%,#f0f4ff 100%);flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.auth-header{background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:16px 20px;display:flex;box-shadow:0 1px 3px #0000000d}.auth-form-container{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px;display:flex;overflow-y:auto}.auth-logo{text-align:center;margin-bottom:24px}.auth-form{flex-direction:column;gap:14px;width:100%;max-width:360px;display:flex}.auth-field{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;padding:0 14px;transition:border-color .2s;display:flex}.auth-field:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.auth-field-icon{color:#94a3b8;flex-shrink:0;margin-right:10px}.auth-field input{background:0 0;border:none;outline:none;flex:1;padding:14px 0;font-family:Inter,sans-serif;font-size:15px}.auth-eye{cursor:pointer;color:#94a3b8;background:0 0;border:none;flex-shrink:0;padding:4px}.auth-error{color:#ef4444;text-align:center;background:#fef2f2;border-radius:8px;padding:8px;font-size:13px}.auth-submit{border-radius:12px;justify-content:center;width:100%;margin-top:4px;padding:14px;font-size:16px;font-weight:600}.auth-switch{text-align:center;margin-top:20px}.auth-switch p{color:#64748b;font-size:14px}.auth-switch button{color:#2563eb;cursor:pointer;background:0 0;border:none;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.auth-profile{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.auth-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;font-weight:700;display:flex;box-shadow:0 8px 20px #3b82f64d}.auth-actions{margin-top:24px}.auth-btn-logout{color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:10px 24px;font-size:14px}.settings-page{background:#f8fafc;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.settings-header{background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:16px 20px;display:flex;box-shadow:0 1px 3px #0000000d}.settings-content{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex;overflow-y:auto}.settings-section{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:18px;box-shadow:0 1px 3px #0000000f}.settings-section-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.settings-section-header h3{color:#1e293b;margin:0;font-size:16px}.settings-item{cursor:pointer;border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex}.settings-item:first-of-type{border-top:none}.gdrive-connected{flex-direction:column;gap:4px;display:flex}.gdrive-status{background:#f0fdf4;border-radius:10px;align-items:center;gap:10px;margin-bottom:8px;padding:12px;display:flex}.gdrive-setup{flex-direction:column;gap:14px;display:flex}.gdrive-info{text-align:center;padding:16px}.gdrive-info p{color:#64748b;margin:8px 0 0;font-size:13px}.settings-input-group{flex-direction:column;gap:6px;display:flex}.settings-input-group label{color:#475569;font-size:12px;font-weight:600}.settings-input{border:1px solid #e2e8f0;border-radius:10px;outline:none;padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s}.settings-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.settings-help-link{color:#3b82f6;align-items:center;gap:4px;font-size:11px;text-decoration:none;display:inline-flex}.settings-error{color:#ef4444;background:#fef2f2;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:flex}.settings-connect-btn{background:#4285f4;border-radius:12px;justify-content:center;width:100%;padding:12px;font-size:15px;font-weight:600}.settings-disconnect{color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;justify-content:center;margin-top:8px;padding:10px;font-size:13px}.toggle{cursor:pointer;background:#cbd5e1;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle.active{background:#22c55e}.toggle-knob{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.toggle.active .toggle-knob{transform:translate(20px)}
