*{margin:0;padding:0;box-sizing:border-box}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:3rem;border-radius:1rem;box-shadow:0 10px 40px #0003;text-align:center;max-width:400px;width:90%}.login-card h1{font-size:2.5rem;margin-bottom:.5rem;color:#333}.login-card p{color:#666;margin-bottom:2rem;font-size:1.1rem}.menu-overlay{position:fixed;inset:0;background:#0f172a66;z-index:1001;animation:overlayFadeIn .35s cubic-bezier(.4,0,.2,1)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.menu-sidebar{position:fixed;top:0;left:-320px;width:320px;height:100vh;background:#fff;z-index:1002;box-shadow:2px 0 24px #0f172a14;transition:left .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden}.menu-sidebar.open{left:0}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:2.5rem 2rem 2rem;border-bottom:1px solid rgba(15,23,42,.06)}.menu-brand-text{margin:0;font-size:.875rem;font-weight:600;color:#0f172a;letter-spacing:.18em;text-transform:uppercase}.menu-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:50%;cursor:pointer;color:#94a3b8;padding:0;transition:all .2s cubic-bezier(.4,0,.2,1)}.menu-close:hover{background:#0f172a0a;color:#0f172a}.menu-close svg{stroke-width:1.5}.menu-list{list-style:none;padding:2.5rem 0;margin:0}.menu-list li{opacity:0;animation:menuItemSlideIn .35s cubic-bezier(.4,0,.2,1) forwards}@keyframes menuItemSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.menu-list a{position:relative;display:flex;align-items:center;gap:.875rem;padding:1rem 2rem;text-decoration:none;color:#64748b;font-size:.9375rem;font-weight:500;letter-spacing:.01em;transition:all .25s cubic-bezier(.4,0,.2,1);border-left:2px solid transparent;margin:.125rem 0}.menu-list a:hover{color:#0f172a;background:#0f172a05;transform:translate(2px);border-left-color:#0f172a14}.menu-list a.active{color:#0f172a;background:#0f172a0a;border-left-color:#0f172a;font-weight:600}.menu-item-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;opacity:.5;transition:opacity .25s}.menu-list a:hover .menu-item-icon{opacity:.7}.menu-list a.active .menu-item-icon{opacity:1}.menu-item-text{flex:1}.menu-item-indicator{position:absolute;right:2rem;width:3px;height:3px;background:#0f172a;border-radius:50%;opacity:.6}.menu-footer{margin-top:auto;padding:1.5rem 0 2rem;border-top:1px solid rgba(15,23,42,.06)}.menu-divider{height:1px;background:#0f172a0a;margin:0 2rem 1.5rem}.menu-logout{display:flex;align-items:center;gap:.875rem;width:100%;padding:1rem 2rem;background:none;border:none;border-left:2px solid transparent;color:#94a3b8;font-size:.9375rem;font-weight:500;letter-spacing:.01em;cursor:pointer;font-family:inherit;transition:all .25s cubic-bezier(.4,0,.2,1);text-align:left}.menu-logout:hover{color:#ef4444;background:#ef44440a;transform:translate(2px);border-left-color:#ef444433}.menu-logout .menu-item-icon{opacity:.5}.menu-logout:hover .menu-item-icon{opacity:.8}.menu-user-info{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin:1.5rem 0 0;background:#0f172a05;border-top:1px solid rgba(15,23,42,.06);border-bottom:1px solid rgba(15,23,42,.06)}.menu-user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(15,23,42,.08);flex-shrink:0}.menu-user-details{flex:1;min-width:0}.menu-user-name{margin:0 0 .125rem;font-size:.875rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.menu-user-email{margin:0;font-size:.75rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}.menu-sidebar::-webkit-scrollbar{width:4px}.menu-sidebar::-webkit-scrollbar-track{background:transparent}.menu-sidebar::-webkit-scrollbar-thumb{background:#0f172a14;border-radius:2px}.menu-sidebar::-webkit-scrollbar-thumb:hover{background:#0f172a1f}@media(max-width:640px){.menu-sidebar{width:280px;left:-280px}.menu-header{padding:2rem 1.5rem 1.75rem}.menu-list{padding:2rem 0}.menu-list a,.menu-logout{padding:.875rem 1.5rem}.menu-user-info{margin:1.25rem 0 0;padding:.875rem 1.5rem}}.home-container{min-height:100vh;background:#f8f9fa}.header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 0;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:.75rem}.header h1{font-size:1.5rem;color:#333;margin:0}.header-actions{display:flex;align-items:center;gap:.75rem}.icon-button{width:40px;height:40px;border:none;background:transparent;color:#666;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;position:relative}.notification-button{position:relative}.notification-badge{position:absolute;top:4px;right:4px;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #ee5a6f66;border:2px solid white}.sort-container{position:relative}.sort-dropdown{position:absolute;top:calc(100% + .75rem);right:0;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:1.25rem;box-shadow:0 10px 40px #0000001f,0 4px 12px #00000014,0 1px 3px #0000000d;min-width:220px;z-index:1000;padding:.5rem;animation:menuSlideIn .25s cubic-bezier(.4,0,.2,1)}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.sort-dropdown button{display:block;width:100%;padding:1rem 1.25rem;border:none;background:transparent;text-align:left;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);color:#1a1a1a;font-size:.95rem;font-weight:500;border-radius:.875rem;line-height:1.5;letter-spacing:-.01em;position:relative;overflow:hidden}.sort-dropdown button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#667eea14,#764ba214);opacity:0;transition:opacity .25s ease}.sort-dropdown button:hover{background:#667eea0f;transform:translate(2px)}.sort-dropdown button:hover:before{opacity:1}.sort-dropdown button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;box-shadow:0 4px 12px #667eea66,0 2px 4px #667eea40;transform:translate(0)}.sort-dropdown button.active:before{opacity:0}.sort-dropdown button:first-child{border-radius:.875rem}.sort-dropdown button:last-child{border-radius:.875rem}.search-bar{max-width:1400px;margin:0 auto;padding:1rem;display:flex;align-items:center;gap:.5rem;animation:slideDown .2s ease}.search-bar input{flex:1;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:.5rem;font-size:1rem;outline:none;transition:border-color .2s}.search-bar input:focus{border-color:#667eea}.search-close{width:36px;height:36px;border:none;background:#f0f0f0;border-radius:50%;font-size:1.5rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.search-close:hover{background:#e0e0e0;color:#333}.user-menu-container{position:relative}.user-avatar-button{border:none;background:transparent;padding:0;cursor:pointer;display:flex;align-items:center;border-radius:50%;transition:transform .2s ease}.user-avatar-button:hover{transform:scale(1.05)}.user-avatar-button img{width:40px;height:40px;border-radius:50%;border:2px solid transparent;transition:border-color .2s ease}.user-avatar-button:hover img{border-color:#667eea}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:1px solid #e0e0e0;border-radius:.75rem;box-shadow:0 8px 24px #00000026;min-width:200px;overflow:hidden;z-index:1000;animation:slideDown .2s ease}.user-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;border:none;background:transparent;text-align:left;cursor:pointer;transition:background .2s;color:#333;text-decoration:none;font-size:.95rem;font-weight:500}.user-dropdown-item:hover{background:#f5f5f5}.user-dropdown-item.logout{color:#f44336}.user-dropdown-item.logout:hover{background:#ffebee}.user-dropdown-item svg{flex-shrink:0}.user-dropdown-divider{height:1px;background:#e0e0e0;margin:.25rem 0}.content{max-width:1400px;margin:0 auto;padding:2rem 1rem}.main-layout{display:flex;gap:2rem;align-items:flex-start}.main-content{flex:1;min-width:0}.actions{margin-bottom:2rem}.btn-primary{display:inline-block;padding:1rem 2rem;background:#667eea;color:#fff;text-decoration:none;border-radius:.5rem;font-weight:600;font-size:1.1rem}.btn-primary:hover{background:#5568d3}.log-card{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;overflow:hidden;text-decoration:none;color:inherit;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.04);position:relative}.log-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 12px 40px #00000026,0 2px 8px #00000014}.log-image{width:100%;height:320px;object-fit:cover;filter:brightness(.98);transition:filter .3s ease}.log-card:hover .log-image{filter:brightness(1.02)}.log-info{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1;gap:1rem}.log-info h3{margin:0;font-size:1.25rem;font-weight:700;color:#1a1a1a;line-height:1.4;letter-spacing:-.01em;flex-grow:1}.log-badges{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.log-type-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:2rem;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 8px #667eea4d;transition:transform .2s ease,box-shadow .2s ease}.log-type-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.log-score-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border-radius:2rem;font-weight:700;font-size:.85rem;box-shadow:0 2px 8px #f5576c4d;transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;gap:.25rem}.log-score-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f5576c66}.filter-panel{width:280px;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:1.25rem;padding:1.75rem;box-shadow:0 4px 24px #0000001a,0 1px 4px #0000000d;border:1px solid rgba(255,255,255,.8);position:sticky;top:90px;max-height:calc(100vh - 120px);overflow-y:auto}@media(max-width:768px){.header h1{font-size:1.25rem}.icon-button{width:44px;height:44px}.main-layout{flex-direction:column}.filter-panel{width:100%;position:static;max-height:none;margin-bottom:1rem}.logs-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.search-bar{padding:.75rem 1rem}.sort-dropdown{right:-.5rem}}.app-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000000d;gap:1rem}.app-header-left{display:flex;align-items:center;gap:1rem;flex:1}.app-header-title{font-size:1.25rem;font-weight:700;margin:0;color:#111827;letter-spacing:-.02em}.btn-smart-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);color:#374151}.btn-smart-back:hover{background:#f3f4f6;color:#111827}.btn-smart-back:active{transform:scale(.95)}.btn-menu{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;transition:all .2s;color:#374151}.btn-menu:hover{background:#f3f4f6}.btn-post-header{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #667eea40}.btn-post-header:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.btn-post-header:active{transform:translateY(0)}.btn-post-header svg{flex-shrink:0}.btn-post-header span{font-weight:600;letter-spacing:.01em}.app-header-right{display:flex;align-items:center;gap:.75rem}.btn-profile-avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;padding:0;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-profile-avatar:hover{transform:scale(1.05)}.btn-profile-avatar img{width:40px;height:40px;border-radius:50%;border:2px solid transparent;transition:border-color .2s;object-fit:cover}.btn-profile-avatar:hover img{border-color:#667eea}@media(max-width:640px){.app-header{padding:.625rem .75rem}.app-header-title{font-size:1.125rem}.btn-post-header{padding:.5rem 1rem;font-size:.875rem}.btn-post-header span{display:none}.btn-post-header svg{margin:0}}.new-log-container{min-height:100vh;background:#f8f9fa;padding-bottom:3rem}.upload-section{max-width:680px;margin:3rem auto;padding:0 2rem}.upload-box{background:linear-gradient(135deg,#fafbfc,#f8f9fa);border:1px solid #e5e7eb;border-radius:24px;padding:6rem 3rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #0000000a,0 2px 8px #00000008,0 1px 4px #00000005}.upload-label:hover .upload-box{border-color:#667eea;transform:translateY(-4px);box-shadow:0 12px 32px #667eea1f,0 6px 16px #667eea14,0 2px 8px #667eea0a}.upload-box svg{color:#667eea;margin-bottom:1.5rem;opacity:.8}.upload-box p{color:#64748b;font-size:1.125rem;font-weight:500;margin:0;letter-spacing:-.01em}.analyzing{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.analyzing p{font-size:1.125rem;color:#667eea;font-weight:600;margin:0;letter-spacing:-.01em}.spinner{width:56px;height:56px;border:4px solid #f1f5f9;border-top:4px solid #667eea;border-radius:50%;animation:spin .8s linear infinite}.edit-section{max-width:900px;margin:3rem auto;padding:0 2rem}.preview-image{background:#fff;border-radius:20px;padding:1.5rem;margin-bottom:2.5rem;box-shadow:0 4px 16px #0000000a,0 2px 8px #00000008}.preview-image img{width:100%;max-height:480px;object-fit:contain;border-radius:12px}.edit-form{background:#fff;border-radius:20px;padding:3rem;box-shadow:0 4px 16px #0000000a,0 2px 8px #00000008}.form-group{margin-bottom:2rem}.form-group label{display:block;margin-bottom:.625rem;font-weight:600;font-size:.9rem;color:#0f172a;letter-spacing:-.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:1px solid #e2e8f0;background:#f8fafc;border-radius:.75rem;font-size:1rem;font-family:inherit;color:#0f172a;transition:all .2s cubic-bezier(.4,0,.2,1)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea14}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.btn-submit{width:100%;padding:1.125rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;font-size:1.0625rem;font-weight:600;cursor:pointer;margin-top:1.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #667eea4d;letter-spacing:-.01em}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{background:#cbd5e1;cursor:not-allowed;transform:none;box-shadow:none}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-top:none;border-radius:0 0 .75rem .75rem;list-style:none;margin:0;padding:0;max-height:240px;overflow-y:auto;z-index:1000;box-shadow:0 8px 24px #0000001f}.autocomplete-suggestions li{padding:.875rem 1rem;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:.9375rem}.autocomplete-suggestions li:hover{background:#f8fafc;color:#667eea}.form-group input.error{border-color:#ef4444;background:#fef2f2}.error-message{display:block;color:#ef4444;font-size:.875rem;margin-top:.375rem;font-weight:500}.helper-text{font-size:.875rem;color:#64748b;margin-top:.625rem;line-height:1.5}.helper-text a{color:#667eea;text-decoration:none;font-weight:600}@media(max-width:768px){.upload-section,.edit-section{padding:0 1rem;margin:2rem auto}.upload-box{padding:4rem 2rem;border-radius:20px}.preview-image,.edit-form{border-radius:16px;padding:1.5rem}.form-row{grid-template-columns:1fr}}.new-log-container{min-height:100vh;background:#f5f5f5;padding-bottom:2rem}.new-log-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem;display:flex;align-items:center;gap:1rem}.btn-back{padding:.5rem 1rem;background:#666;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:500}.btn-back:hover{background:#555}.new-log-header h1{margin:0;font-size:1.5rem}.upload-section{max-width:600px;margin:2rem auto;padding:0 1rem}.upload-label{display:block;cursor:pointer}.upload-box{background:#fff;border:3px dashed #ccc;border-radius:1rem;padding:4rem 2rem;text-align:center;transition:border-color .2s}.upload-label:hover .upload-box{border-color:#667eea}.upload-box svg{color:#999;margin-bottom:1rem}.upload-box p{color:#666;font-size:1.1rem;margin:0}.analyzing{display:flex;flex-direction:column;align-items:center;gap:1rem}.analyzing p{font-size:1.2rem;color:#667eea;font-weight:600;margin:0}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.edit-section{max-width:800px;margin:2rem auto;padding:0 1rem}.preview-image{background:#fff;border-radius:1rem;padding:1rem;margin-bottom:2rem}.preview-image img{width:100%;max-height:400px;object-fit:contain;border-radius:.5rem}.image-rotation-controls{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.btn-rotate{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-rotate:hover{background:#5568d3}.btn-rotate:active{transform:scale(.95)}.edit-form{background:#fff;border-radius:1rem;padding:2rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:.5rem;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.btn-submit{width:100%;padding:1rem;background:#667eea;color:#fff;border:none;border-radius:.5rem;font-size:1.1rem;font-weight:600;cursor:pointer;margin-top:1rem}.btn-submit:hover{background:#5568d3}.btn-submit:disabled{background:#ccc;cursor:not-allowed}.autocomplete-container{position:relative}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e0e0e0;border-top:none;border-radius:0 0 .5rem .5rem;list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px #0000001a}.autocomplete-suggestions li{padding:.75rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.autocomplete-suggestions li:last-child{border-bottom:none}.autocomplete-suggestions li:hover{background:#f5f5f5}.form-group input.error{border-color:#e74c3c}.error-message{display:block;color:#e74c3c;font-size:.875rem;margin-top:.25rem}.helper-text{font-size:.875rem;color:#999;margin-top:.5rem}.helper-text a{color:#667eea;text-decoration:none}.helper-text a:hover{text-decoration:underline}.log-detail-container{min-height:100vh;background:#f9fafb}.log-actions-header{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:101}.btn-edit-icon,.btn-delete-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000001a}.btn-edit-icon{color:#667eea}.btn-edit-icon:hover{background:#667eea;color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.btn-delete-icon{color:#ef4444}.btn-delete-icon:hover{background:#ef4444;color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #ef44444d}.btn-edit-icon svg,.btn-delete-icon svg{flex-shrink:0}.loading-page,.error-page{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.5rem;color:#666}.log-detail-content{max-width:1200px;margin:0 auto;padding:3rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem}@media(max-width:768px){.log-detail-content{grid-template-columns:1fr}}.log-detail-image{background:#fff;border-radius:1rem;padding:1rem;height:fit-content;position:sticky;top:2rem}.log-detail-image img{width:100%;border-radius:.5rem}.log-detail-info{background:#fff;border-radius:1rem;padding:2.5rem}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.user-info img{width:40px;height:40px;border-radius:50%}.user-name{font-weight:600;color:#667eea;text-decoration:none}.user-name:hover{text-decoration:underline}.log-detail-info h1{margin:0 0 2rem;font-size:2.25rem;font-weight:700;color:#0f172a;line-height:1.3;letter-spacing:-.02em}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-size:.7rem;color:#a0a0a0;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.info-value{font-size:1.15rem;color:#0f172a;font-weight:600;line-height:1.5}.score-badge{display:inline-block;padding:.5rem 1rem;background:#667eea;color:#fff;border-radius:2rem;font-weight:600}.memo-section{border-top:1px solid #e0e0e0;padding-top:2rem;margin-bottom:2rem}.memo-section h3{margin:0 0 1rem;font-size:1.3rem;color:#333}.memo-section p{font-size:1.1rem;line-height:1.6;color:#666;white-space:pre-wrap}.engagement-section{border-top:1px solid #e0e0e0;padding-top:1.5rem;margin-bottom:2rem}.engagement-actions{display:flex;gap:.75rem;align-items:center}.btn-engagement{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:1px solid #e5e7eb;background:#fafafa;border-radius:1.5rem;font-size:.95rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-engagement:hover:not(:disabled){background:#fff;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.btn-engagement:disabled{opacity:.5;cursor:not-allowed}.btn-engagement svg{flex-shrink:0}.btn-like:hover:not(:disabled){border-color:#ff6b9d;color:#ff6b9d}.btn-like.liked{border-color:#ff6b9d;background:linear-gradient(135deg,#ff6b9d,#ff4d7d);color:#fff;box-shadow:0 4px 15px #ff6b9d66}.btn-like.liked svg{fill:#fff;stroke:none}.btn-comment:hover:not(:disabled){border-color:#667eea;color:#667eea}.btn-bookmark:hover:not(:disabled){border-color:#f59e0b;color:#f59e0b}.btn-bookmark.bookmarked{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 15px #f59e0b66}.btn-bookmark.bookmarked svg{fill:#fff;stroke:none}.comments-section{border-top:1px solid #e0e0e0;padding-top:2rem}.comments-section h3{margin:0 0 1.5rem;font-size:1.3rem;color:#333}.comment-form{margin-bottom:2rem}.comment-form textarea{width:100%;padding:1rem 1.25rem;border:1px solid #f1f5f9;background:#f8fafc;border-radius:.75rem;font-size:.95rem;font-family:inherit;resize:vertical;transition:all .2s;margin-bottom:.75rem;line-height:1.6}.comment-form textarea:focus{outline:none;border-color:#e2e8f0;background:#fff;box-shadow:0 0 0 3px #667eea0d}.btn-submit-comment{padding:.625rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.btn-submit-comment:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.btn-submit-comment:disabled{opacity:.5;cursor:not-allowed}.comments-list{display:flex;flex-direction:column;gap:.75rem}.no-comments{text-align:center;color:#999;padding:2rem;font-size:1rem}.comment-item{display:flex;gap:1rem;padding:1.25rem;background:#f8fafc;border-radius:.75rem;border:1px solid #f1f5f9}.comment-item:last-child{margin-bottom:0}.comment-avatar{flex-shrink:0}.comment-avatar img{width:40px;height:40px;border-radius:50%;border:2px solid #e5e7eb}.comment-content{flex:1;min-width:0}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.comment-user{text-decoration:none;color:inherit;display:flex;align-items:center;gap:.5rem}.comment-user strong{color:#333;font-weight:600}.comment-username{color:#667eea;font-size:.9rem}.comment-time{color:#999;font-size:.85rem}.comment-text{margin:0 0 .75rem;color:#333;line-height:1.5;word-wrap:break-word}.btn-delete-comment{padding:.25rem .75rem;background:transparent;border:1px solid #e0e0e0;border-radius:.5rem;color:#e74c3c;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-delete-comment:hover{background:#fee;border-color:#fcc}.user-profile-container{min-height:100vh;background:linear-gradient(to bottom,#fafafa,#f0f0f0)}.profile-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem}.profile-content{max-width:1200px;margin:0 auto;padding:2rem 1rem}.profile-info{text-align:center;background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;padding:3rem 2rem;margin-bottom:2rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.profile-avatar{width:120px;height:120px;border-radius:50%;margin-bottom:1rem;border:4px solid #667eea;box-shadow:0 4px 16px #667eea4d;transition:transform .3s ease}.profile-avatar:hover{transform:scale(1.05)}.profile-info h1{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#1a1a1a;letter-spacing:-.02em}.profile-username{color:#667eea;font-size:1.1rem;font-weight:600;margin:.25rem 0}.profile-bio{color:#666;font-size:1rem;line-height:1.6;margin:1rem auto;max-width:600px;padding:0 1rem}.profile-stats{color:#666;font-size:.95rem;font-weight:400;margin:1rem 0;display:flex;align-items:center;justify-content:center;gap:.5rem}.profile-stats .stat-link{color:#1a1a1a;text-decoration:none;transition:color .2s}.profile-stats .stat-link:hover{color:#667eea}.profile-stats .stat-link strong{font-weight:600;color:#667eea}.profile-stats .stat-divider{color:#ccc}.btn-follow{margin-top:1.5rem;padding:.75rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:2rem;font-weight:600;font-size:1rem;cursor:pointer;box-shadow:0 4px 15px #667eea66;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-follow:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.btn-follow.following{background:#fff;color:#667eea;border:2px solid #667eea;box-shadow:0 2px 8px #667eea33}.btn-follow.following:hover:not(:disabled){background:#f8f9ff;border-color:#764ba2;color:#764ba2}.btn-follow:disabled{opacity:.6;cursor:not-allowed}.profile-tabs{display:flex;gap:.5rem;justify-content:center;margin-bottom:2rem;background:#fff;border-radius:1.25rem;padding:.5rem;box-shadow:0 2px 10px #00000014;border:1px solid rgba(0,0,0,.04)}.profile-tabs .tab-button{flex:1;max-width:200px;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border:none;background:transparent;color:#666;font-size:1rem;font-weight:600;border-radius:.75rem;cursor:pointer;transition:all .2s}.profile-tabs .tab-button:hover{background:#f5f5f5;color:#333}.profile-tabs .tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.profile-tabs .tab-button svg{flex-shrink:0}.bar-filter{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;padding:1.5rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.bar-filter label{font-weight:600;color:#1a1a1a}.bar-filter select{flex:1;max-width:300px;padding:.75rem;border:2px solid #e0e0e0;border-radius:.5rem;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s}.bar-filter select:focus{outline:none;border-color:#667eea}.profile-logs,.profile-spots{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;padding:2rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.spots-list{display:flex;flex-direction:column;gap:1rem}.spot-item{position:relative;padding:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.spot-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014;border-color:#cbd5e1}.spot-rank{position:absolute;top:1rem;left:1rem;width:36px;height:36px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;box-shadow:0 2px 8px #667eea4d;z-index:1}.spot-content{display:flex;gap:1.5rem;align-items:flex-start;margin-left:2.5rem}.spot-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.spot-name{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a;letter-spacing:-.02em;line-height:1.3}.spot-drink-count{padding:.375rem .875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.8125rem;font-weight:600;border-radius:1rem;white-space:nowrap;box-shadow:0 2px 6px #667eea40}.spot-badge{display:inline-block;margin:0 0 .625rem;padding:.25rem .75rem;font-size:.6875rem;color:#667eea;background:#667eea14;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:.375rem}.spot-images{display:flex;gap:.5rem;flex-shrink:0}.spot-preview-image{width:80px;height:80px;object-fit:cover;border-radius:.625rem;box-shadow:0 2px 8px #0000001a;transition:all .2s}.spot-preview-image:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.logs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.log-card{display:block;background:#fff;border-radius:1rem;overflow:hidden;text-decoration:none;color:inherit;box-shadow:0 2px 8px #00000014;transition:all .2s}.log-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.log-image{width:100%;aspect-ratio:1;object-fit:cover}.log-info{padding:1rem}.log-info h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#1a1a1a;line-height:1.3}.log-type{margin:0 0 .5rem;font-size:.875rem;color:#666}.log-score{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.875rem;font-weight:600;border-radius:.5rem}.empty-state{text-align:center;padding:3rem 1rem;color:#666}.empty-state p{font-size:1rem;margin:0}@media(max-width:768px){.profile-content{padding:1rem}.profile-info{padding:2rem 1rem}.profile-avatar{width:100px;height:100px}.profile-info h1{font-size:1.5rem}.profile-stats{flex-wrap:wrap;font-size:.875rem}.profile-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.profile-tabs .tab-button{min-width:120px;padding:.75rem 1rem;font-size:.9rem}.bar-filter{flex-direction:column;align-items:stretch;padding:1rem}.bar-filter select{max-width:100%}.profile-logs,.profile-spots{padding:1rem}.logs-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.spot-item{padding:1rem}.spot-rank{width:32px;height:32px;font-size:.8125rem}.spot-content{flex-direction:column;margin-left:2rem;gap:1rem}.spot-header{flex-direction:column;align-items:flex-start;gap:.5rem}.spot-name{font-size:1.125rem}.spot-images{align-self:flex-start}.spot-preview-image{width:70px;height:70px}}.profile-settings-container{min-height:100vh;background:linear-gradient(to bottom,#fafafa,#f0f0f0);padding:2rem 1rem}.settings-content{max-width:700px;margin:0 auto}.settings-header{margin-bottom:2rem}.settings-header h1{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem;letter-spacing:-.02em}.settings-header p{color:#666;font-size:1rem;margin:0}.settings-form{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;padding:2rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.alert{padding:1rem 1.25rem;border-radius:.75rem;margin-bottom:1.5rem;font-weight:500}.alert-error{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;box-shadow:0 2px 8px #ff6b6b4d}.alert-success{background:linear-gradient(135deg,#51cf66,#37b24d);color:#fff;box-shadow:0 2px 8px #51cf664d}.form-section{margin-bottom:2rem}.form-section h2{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid rgba(102,126,234,.1)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:#1a1a1a;margin-bottom:.5rem;font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:.75rem;font-size:1rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.form-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#999}.username-input-group{position:relative;display:flex;align-items:center}.username-prefix{position:absolute;left:1rem;color:#666;font-weight:600;pointer-events:none}.username-input-group input{padding-left:2.25rem;padding-right:7rem}.username-status{position:absolute;right:1rem;font-size:.85rem;font-weight:600}.username-status.checking{color:#999}.username-status.available{color:#37b24d}.username-status.taken{color:#ee5a6f}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #f0f0f0}.btn-primary,.btn-secondary{padding:.875rem 2rem;border:none;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:#666;border:2px solid #e0e0e0}.btn-secondary:hover{background:#f5f5f5;border-color:#ccc}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}@media(max-width:768px){.profile-settings-container{padding:1rem}.settings-form{padding:1.5rem}.settings-header h1{font-size:1.75rem}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.my-spots-container{min-height:100vh;background:#f8f9fa}.my-spots-content{max-width:900px;margin:0 auto;padding:0 2rem 3rem}.hero-search-section{padding:3rem 0 2.5rem;text-align:center}.page-title{font-size:2.5rem;font-weight:700;color:#0f172a;margin:0 0 .75rem;letter-spacing:-.02em}.page-subtitle{font-size:1.1rem;color:#64748b;margin:0 0 2.5rem;font-weight:400}.hero-search-form{display:flex;gap:.75rem;max-width:600px;margin:0 auto}.search-input-wrapper{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1.25rem;color:#94a3b8;pointer-events:none}.hero-search-input{width:100%;padding:1rem 1.25rem 1rem 3.25rem;border:1px solid #e2e8f0;background:#fff;border-radius:1.5rem;font-size:1rem;font-family:inherit;transition:all .2s cubic-bezier(.4,0,.2,1);color:#0f172a}.hero-search-input::placeholder{color:#94a3b8}.hero-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.search-clear-button{position:absolute;right:1rem;width:24px;height:24px;border:none;background:#e2e8f0;color:#64748b;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}.search-clear-button:hover{background:#cbd5e1;color:#0f172a}.hero-search-button{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #667eea40;white-space:nowrap;min-width:100px;display:flex;align-items:center;justify-content:center}.hero-search-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.hero-search-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner{animation:spin 1s linear infinite}.spot-error{padding:1rem 1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem;color:#dc2626;margin-bottom:1.5rem;text-align:center;font-size:.95rem}.search-results{margin-bottom:3rem}.search-results h2{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0 0 1.25rem}.section-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem;letter-spacing:-.01em}.spot-list{display:flex;flex-direction:column;gap:1rem}.spot-card{display:flex;align-items:center;gap:1.5rem;padding:1.75rem 2rem;background:#fff;border:1px solid #e5e7eb;border-radius:1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.spot-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014;border-color:#cbd5e1}.spot-card.saved{background:#fafafa}.spot-info{flex:1;min-width:0}.spot-info h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#0f172a;letter-spacing:-.02em;line-height:1.3}.spot-category{display:inline-block;margin:0 0 .625rem;padding:.25rem .75rem;font-size:.6875rem;color:#667eea;background:#667eea14;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:.375rem}.spot-address{margin:0;font-size:.875rem;color:#64748b;line-height:1.5;font-weight:400}.spot-maps-link{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;font-size:.8125rem;color:#667eea;text-decoration:none;font-weight:600;letter-spacing:-.01em;transition:all .2s}.spot-maps-link:hover{color:#764ba2;text-decoration:underline;transform:translate(2px)}.spot-add-button,.spot-delete-button{padding:.625rem 1.5rem;border:none;border-radius:.75rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.spot-add-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea40}.spot-add-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.spot-delete-button{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.spot-delete-button:hover{background:#dc2626;color:#fff;border-color:#dc2626;transform:translateY(-1px)}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border:1px solid #e5e7eb;border-radius:1rem;max-width:480px;margin:0 auto}.empty-state-icon{margin:0 auto 1.5rem;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:50%;color:#94a3b8}.empty-state-title{font-size:1.375rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.empty-state-description{font-size:1rem;color:#64748b;margin:0;line-height:1.6}.my-spots-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.25rem;color:#64748b}@media(max-width:768px){.my-spots-content{padding:0 1rem 2rem}.hero-search-section{padding:2rem 0 1.5rem}.page-title{font-size:2rem}.page-subtitle{font-size:1rem}.hero-search-form{flex-direction:column;gap:.75rem}.hero-search-button{width:100%}.spot-card{padding:1.5rem;gap:1rem}.spot-info h3{font-size:1.125rem}.spot-add-button,.spot-delete-button{padding:.5rem 1.25rem;font-size:.875rem}.empty-state{padding:3rem 1.5rem}.empty-state-title{font-size:1.25rem}.empty-state-description{font-size:.9375rem}}.discovery-container{min-height:100vh;background:linear-gradient(to bottom,#fafafa,#f0f0f0)}.discovery-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 0;position:sticky;top:0;z-index:100}.discovery-header .header-content{max-width:1400px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.tabs-container{max-width:1400px;margin:1rem auto 0;padding:0 1rem;display:flex;gap:.5rem;border-bottom:2px solid #e0e0e0}.tab-button{flex:1;max-width:200px;padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;font-weight:600;font-size:1rem;color:#666;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;bottom:-2px}.tab-button:hover{color:#667eea}.tab-button.active{color:#667eea;border-bottom-color:#667eea}.discovery-layout{display:flex;gap:2rem;align-items:flex-start}.discovery-main{flex:1;min-width:0}.filter-panel{width:280px;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:1.25rem;padding:1.75rem;box-shadow:0 4px 24px #0000001a,0 1px 4px #0000000d;border:1px solid rgba(255,255,255,.8);position:sticky;top:180px;max-height:calc(100vh - 200px);overflow-y:auto}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:2px solid rgba(102,126,234,.1)}.filter-header h2{font-size:1.5rem;font-weight:700;margin:0;color:#1a1a1a;letter-spacing:-.02em}.filter-clear{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;font-weight:600;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;border-radius:2rem;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #667eea4d}.filter-clear:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.filter-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #f0f0f0}.filter-section:last-child{border-bottom:none}.filter-row{display:flex;gap:1rem}.filter-input-group{flex:1}.filter-input-group label{display:block;margin-bottom:.5rem;color:#666;font-size:.9rem;font-weight:500}.filter-input-group input{width:100%;padding:.5rem;border:1px solid #e0e0e0;border-radius:.5rem;font-size:.95rem;outline:none;transition:border-color .2s}.filter-input-group input:focus{border-color:#667eea}.filter-section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;background:none;border:none;font-size:1rem;font-weight:600;color:#333;cursor:pointer;text-align:left}.filter-section-header:hover{color:#667eea}.filter-options{margin-top:.5rem;max-height:200px;overflow-y:auto}.filter-checkbox{display:flex;align-items:center;padding:.75rem;cursor:pointer;gap:.75rem;border-radius:.75rem;transition:background .2s ease}.filter-checkbox:hover{background:#667eea0d}.filter-checkbox input{cursor:pointer;width:18px;height:18px;accent-color:#667eea}.filter-checkbox span:nth-child(2){flex:1;color:#1a1a1a;font-size:.95rem;font-weight:500}.filter-count{color:#999;font-size:.85rem}.discovery-header .header-left{display:flex;align-items:center;gap:.75rem}.discovery-header h1{font-size:1.5rem;color:#333;margin:0}.icon-button{width:40px;height:40px;border:none;background:transparent;color:#666;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.icon-button:hover{background:#f0f0f0;color:#333}.icon-button.active{background:#e8e8e8;color:#333}.discovery-header .header-actions{display:flex;align-items:center;gap:.75rem}.discovery-header .sort-container{position:relative}.discovery-header .sort-dropdown{position:absolute;top:calc(100% + .75rem);right:0;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:1.25rem;box-shadow:0 10px 40px #0000001f,0 4px 12px #00000014,0 1px 3px #0000000d;min-width:220px;z-index:1000;padding:.5rem;animation:menuSlideIn .25s cubic-bezier(.4,0,.2,1)}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.discovery-header .sort-dropdown button{display:block;width:100%;padding:1rem 1.25rem;border:none;background:transparent;text-align:left;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);color:#1a1a1a;font-size:.95rem;font-weight:500;border-radius:.875rem;line-height:1.5;letter-spacing:-.01em;position:relative;overflow:hidden}.discovery-header .sort-dropdown button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#667eea14,#764ba214);opacity:0;transition:opacity .25s ease}.discovery-header .sort-dropdown button:hover{background:#667eea0f;transform:translate(2px)}.discovery-header .sort-dropdown button:hover:before{opacity:1}.discovery-header .sort-dropdown button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;box-shadow:0 4px 12px #667eea66,0 2px 4px #667eea40;transform:translate(0)}.discovery-header .sort-dropdown button.active:before{opacity:0}.discovery-header .notification-button{position:relative}.discovery-header .notification-badge{position:absolute;top:4px;right:4px;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #ee5a6f66;border:2px solid white}.discovery-header .user-menu-container{position:relative}.discovery-header .user-avatar-button{width:40px;height:40px;border-radius:50%;border:2px solid #667eea;background:#fff;cursor:pointer;padding:0;overflow:hidden;transition:all .2s}.discovery-header .user-avatar-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.discovery-header .user-avatar-button img{width:100%;height:100%;object-fit:cover}.discovery-header .user-dropdown{position:absolute;top:calc(100% + .75rem);right:0;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:1.25rem;box-shadow:0 10px 40px #0000001f,0 4px 12px #00000014;min-width:200px;z-index:1000;padding:.5rem;animation:menuSlideIn .25s cubic-bezier(.4,0,.2,1)}.discovery-header .user-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;transition:all .2s;color:#1a1a1a;text-decoration:none;font-size:.95rem;font-weight:500;border-radius:.875rem}.discovery-header .user-dropdown-item:hover{background:#667eea0f}.discovery-header .user-dropdown-item.logout{color:#ff6b6b}.discovery-header .user-dropdown-item.logout:hover{background:#ff6b6b0f}.discovery-header .user-dropdown-divider{height:1px;background:linear-gradient(90deg,transparent,#e0e0e0,transparent);margin:.5rem 0}.discovery-header .search-bar{max-width:1400px;margin:0 auto;padding:1rem;display:flex;align-items:center;gap:.5rem;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.discovery-header .search-bar input{flex:1;padding:.875rem 1.25rem;border:2px solid #e0e0e0;border-radius:2rem;font-size:1rem;transition:all .2s;background:#fff}.discovery-header .search-bar input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.discovery-header .search-close{width:36px;height:36px;border:none;background:#f0f0f0;color:#666;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.discovery-header .search-close:hover{background:#e0e0e0;color:#333}.discovery-content{max-width:1400px;margin:0 auto;padding:2rem 1rem}.discovery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.discovery-card{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;overflow:hidden;text-decoration:none;color:inherit;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.04);height:100%}.discovery-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 12px 40px #00000026,0 2px 8px #00000014}.discovery-image{width:100%;height:320px;object-fit:cover;filter:brightness(.98);transition:filter .3s ease}.discovery-card:hover .discovery-image{filter:brightness(1.02)}.discovery-info{padding:1.5rem;display:flex;flex-direction:column;gap:1rem;flex:1}.discovery-user{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit;padding:.5rem;margin:-.5rem;border-radius:.5rem;transition:background .2s}.discovery-user:hover{background:#667eea0d}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid #667eea}.user-details{display:flex;flex-direction:column;gap:.125rem}.user-name{font-weight:600;font-size:.9rem;color:#1a1a1a}.user-username{font-size:.8rem;color:#667eea;font-weight:500}.discovery-info h3{margin:0;font-size:1.25rem;font-weight:700;color:#1a1a1a;line-height:1.4;letter-spacing:-.01em}.discovery-badges{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:auto}.drink-type-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:2rem;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 8px #667eea4d}.score-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border-radius:2rem;font-weight:700;font-size:.85rem;box-shadow:0 2px 8px #f5576c4d}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.skeleton-card{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;overflow:hidden;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.skeleton-image{width:100%;height:320px;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:shimmer 2s infinite}.skeleton-content{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.skeleton-user{height:2.5rem;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:shimmer 2s infinite;border-radius:.5rem;width:50%}.skeleton-title{height:1.5rem;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:shimmer 2s infinite;border-radius:.5rem;width:70%}.skeleton-badges{display:flex;gap:.75rem}.skeleton-badge{height:2rem;width:5rem;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:shimmer 2s infinite;border-radius:2rem}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-more{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 0}.spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-more p{color:#666;font-size:.95rem;font-weight:500}.end-message{text-align:center;padding:3rem 0}.end-message p{color:#999;font-size:1rem;font-weight:500}.empty-state{text-align:center;padding:3rem;background:#fff;border-radius:1rem}.empty-state p{font-size:1.2rem;color:#666}.engagement-stats{display:flex;align-items:center;gap:1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f0f0f0}.engagement-stats .stat-item{display:flex;align-items:center;gap:.375rem;color:#666;font-size:.875rem;font-weight:500}.engagement-stats .stat-item svg{color:#999}.engagement-stats .stat-item:first-child svg{color:#ff6b9d}.engagement-stats .bookmark-btn{background:none;border:none;padding:0;cursor:pointer;transition:all .2s}.engagement-stats .bookmark-btn:disabled{opacity:.5;cursor:not-allowed}.engagement-stats .bookmark-btn:not(:disabled):hover{transform:scale(1.1)}.engagement-stats .bookmark-btn svg{color:#666}.engagement-stats .bookmark-btn.bookmarked svg{color:#f59e0b;fill:#f59e0b}@media(max-width:768px){.discovery-layout{flex-direction:column}.filter-panel{width:100%;position:static;max-height:none;margin-bottom:1rem}.discovery-grid,.skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.discovery-header h1{font-size:1.25rem}}.follow-list-container{min-height:100vh;background:linear-gradient(to bottom,#fafafa,#f0f0f0)}.follow-list-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem;display:flex;align-items:center;gap:1rem}.follow-list-header h1{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.follow-list-content{max-width:800px;margin:0 auto;padding:2rem 1rem}.users-list{display:flex;flex-direction:column;gap:1rem}.user-card{display:flex;gap:1.5rem;padding:1.5rem;background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04);text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.4,0,.2,1)}.user-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #667eea26,0 2px 5px #0000001a}.user-avatar{width:60px;height:60px;border-radius:50%;border:3px solid #667eea;box-shadow:0 2px 8px #667eea4d;flex-shrink:0}.user-info{flex:1;min-width:0}.user-info h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#1a1a1a}.user-username{color:#667eea;font-size:.95rem;font-weight:500;margin:0 0 .5rem}.user-bio{color:#666;font-size:.9rem;line-height:1.5;margin:0 0 .75rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.user-stats{color:#999;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.user-stats strong{color:#667eea;font-weight:600}.user-stats .stat-divider{color:#ccc}.btn-load-more{width:100%;margin-top:2rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;box-shadow:0 4px 15px #667eea66;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-load-more:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.btn-load-more:disabled{opacity:.6;cursor:not-allowed}.empty-state{text-align:center;padding:3rem 2rem;background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d}.empty-state p{color:#999;font-size:1rem;margin:0}.notifications-container{min-height:100vh;background:linear-gradient(to bottom,#fafafa,#f0f0f0)}.notifications-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:100}.notifications-header h1{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.btn-back{width:40px;height:40px;border:none;background:transparent;color:#666;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-back:hover{background:#f0f0f0}.notifications-content{max-width:800px;margin:0 auto;padding:0}.notifications-list{background:#fff;border-radius:0}.notification-item{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;text-decoration:none;color:inherit;transition:background .2s;position:relative}.notification-item:hover{background:#fafafa}.notification-item.unread{background:linear-gradient(to right,#667eea0d,#667eea05)}.notification-item.unread:hover{background:linear-gradient(to right,#667eea14,#667eea0a)}.notification-avatar{width:48px;height:48px;border-radius:50%;border:2px solid #667eea;box-shadow:0 2px 8px #667eea33;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-text{color:#333;font-size:.95rem;line-height:1.5;margin-bottom:.25rem}.notification-text strong{color:#667eea;font-weight:600}.notification-time{color:#999;font-size:.85rem}.unread-dot{width:10px;height:10px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;box-shadow:0 2px 6px #667eea66}.empty-state{text-align:center;padding:3rem 2rem;background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;margin:2rem auto;max-width:480px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04);display:flex;flex-direction:column;align-items:center;gap:1.25rem}.empty-state svg{color:#cbd5e1;flex-shrink:0}.empty-state p{color:#64748b;font-size:1rem;font-weight:500;margin:0;letter-spacing:-.01em}.feedback-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.feedback-modal{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:1.25rem;box-shadow:0 12px 40px #00000026,0 2px 8px #00000014;max-width:500px;width:100%;padding:2rem;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.feedback-header h2{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0}.feedback-close{width:36px;height:36px;border:none;background:transparent;color:#666;font-size:2rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.feedback-close:hover{background:#667eea1a;color:#667eea}.feedback-categories{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.category-chip{flex:1;min-width:100px;padding:.625rem 1rem;background:#f8f8f8;border:1.5px solid #e8e8e8;border-radius:.625rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.875rem;color:#555;letter-spacing:.01em}.category-chip:hover{background:#f0f0f0;border-color:#d8d8d8;color:#333}.category-chip.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 2px 8px #667eea40}.feedback-input-group{margin-bottom:1.5rem}.feedback-input-group label{display:block;font-size:.95rem;font-weight:600;color:#333;margin-bottom:.5rem}.feedback-input-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:.75rem;font-size:1rem;font-family:inherit;resize:vertical;transition:all .2s}.feedback-input-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.feedback-input-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.feedback-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-secondary{background:#f0f0f0;color:#666}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.feedback-success{text-align:center;padding:2rem 0}.success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:scaleIn .5s cubic-bezier(.4,0,.2,1)}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.feedback-success h3{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem}.feedback-success p{font-size:1rem;color:#666;margin:0}@media(max-width:768px){.feedback-modal{padding:1.5rem}.feedback-header h2{font-size:1.25rem}.category-chip{min-width:90px;padding:.5rem .75rem;font-size:.8125rem}}.feedback-fab{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;box-shadow:0 4px 20px #667eea66,0 2px 8px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:999}.feedback-fab:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 28px #667eea80,0 4px 12px #00000026}.feedback-fab:active{transform:translateY(-2px) scale(1.02)}.feedback-fab svg{width:24px;height:24px}@keyframes pulse{0%,to{box-shadow:0 4px 20px #667eea66,0 2px 8px #0000001a}50%{box-shadow:0 4px 20px #667eea99,0 2px 8px #00000026,0 0 0 8px #667eea33}}@media(max-width:768px){.feedback-fab{bottom:1.5rem;right:1.5rem;width:52px;height:52px}.feedback-fab svg{width:22px;height:22px}}:root{--color-primary: #667eea;--color-primary-dark: #5568d3;--color-primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--color-secondary: #ff6b9d;--color-secondary-dark: #ff4d7d;--color-accent: #f59e0b;--color-accent-dark: #d97706;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem;--spacing-2xl: 2rem;--spacing-3xl: 3rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--shadow-2xl: 0 25px 50px rgba(0, 0, 0, .25);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:1.5;text-decoration:none;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn-primary{background:var(--color-primary-gradient);color:#fff;box-shadow:0 2px 8px #667eea40}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.btn-secondary{background:#fff;color:var(--color-primary);border:2px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.btn-danger{background:#fff;color:var(--color-danger);border:2px solid #fee2e2}.btn-danger:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-body{padding:var(--spacing-xl)}.input,.textarea,.select{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.loading-page,.error-page{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:var(--font-size-xl);color:var(--color-text-secondary)}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--transition-slow),transform var(--transition-slow)}*{box-sizing:border-box}body{margin:0;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}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.5rem;color:#666}
