.app-header{background:var(--color-primary);z-index:100;box-shadow:var(--shadow-header);padding:0 1rem;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:1100px;height:56px;margin:0 auto;display:flex}.header-brand{color:var(--text-on-dark);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;transition:opacity .2s;display:flex}.header-brand:hover{opacity:.85}.brand-icon{font-size:1.4rem}.header-nav{gap:.5rem;display:flex}.header-nav .nav-link{color:var(--text-dim);border-radius:6px;padding:.4rem .9rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s}.header-nav .nav-link:hover{color:var(--text-on-dark);background:#b4b4b41f}.header-nav .nav-link.active{color:var(--text-on-dark);background:#ffffff1a}.header-user{align-items:center;gap:.8rem;display:flex}.header-inner .user-email{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.85rem;overflow:hidden}.logout-btn{border:1px solid var(--logout-border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .8rem;font-size:.8rem;transition:all .2s}.logout-btn:hover{border-color:var(--color-danger);color:var(--color-danger);background:0 0}@media (width<=600px){.header-inner{flex-wrap:wrap;gap:.5rem;height:auto;padding:.6rem 0}.header-brand{font-size:1rem}.header-nav{order:3;justify-content:center;width:100%}.user-email{display:none}}.auth-container{background-color:var(--auth-dark-bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background-color:var(--color-primary);border-radius:12px;width:100%;max-width:420px;padding:40px;box-shadow:0 4px 24px #0000004d}.auth-title{color:var(--text-on-dark);text-align:center;margin:0 0 8px;font-size:2rem}.auth-subtitle{color:var(--text-dim);text-align:center;margin:0 0 28px;font-size:.95rem}.auth-error{background-color:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border);border-radius:6px;margin-bottom:18px;padding:10px 14px;font-size:.9rem}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-dim);font-size:.85rem;font-weight:500}.auth-field input{background-color:var(--auth-dark-bg);border:1px solid var(--dark-border);color:var(--text-on-dark);border-radius:6px;outline:none;padding:12px 14px;font-size:16px;transition:border-color .2s}.auth-field input:focus{border-color:var(--color-accent)}.auth-field input::placeholder{color:var(--text-secondary)}.auth-submit{background-color:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:14px;font-size:1rem;font-weight:600;transition:background-color .2s}.auth-submit:hover{background-color:var(--color-accent-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;margin-top:24px}.auth-switch p{color:var(--text-dim);font-size:.9rem}.auth-link-btn{color:var(--color-accent);font-weight:500;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:none}.auth-link-btn:hover{text-decoration:underline}.auth-hint-warn{color:var(--color-warning);margin-top:2px;font-size:.8rem;display:block}.addcar-container{max-width:600px;margin:0 auto;padding:2rem}.addcar-container h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem}.subtitle{color:var(--text-secondary);margin-bottom:2rem}.car-form{background:var(--bg-light);border:1px solid var(--bg-input-readonly);border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-placeholder);font-size:.9rem;font-weight:600}.form-group select{border:1px solid var(--border-input);background:var(--bg-surface);cursor:pointer;border-radius:8px;padding:.7rem;font-size:1rem;transition:border-color .2s}.form-group select:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb), .2);outline:none}.form-group select:disabled{background:var(--bg-input-readonly);cursor:not-allowed}.form-group input[type=text]{border:1px solid var(--border-input);background:var(--bg-surface);border-radius:8px;padding:.7rem;font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb), .2);outline:none}.form-group textarea{border:1px solid var(--border-input);background:var(--bg-surface);resize:vertical;border-radius:8px;min-height:80px;padding:.7rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb), .2);outline:none}.optional{color:var(--text-secondary);font-size:.8rem;font-weight:400}.save-btn{background:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.8rem 1.5rem;font-size:1rem;font-weight:600;transition:background .2s}.save-btn:hover:not(:disabled){background:var(--color-accent-hover)}.message{border-radius:8px;margin-bottom:1rem;padding:.8rem;font-weight:500}.message.success{background:var(--bg-success-light);color:var(--success-toast-text);border:1px solid var(--success-toast-border)}.message.error{background:var(--alert-danger-bg);color:var(--alert-danger-text);border:1px solid var(--alert-danger-border)}.saved-cars{margin-top:2rem}.saved-cars h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.4rem}.saved-cars ul{padding:0;list-style:none}.saved-cars li{background:var(--bg-surface);border:1px solid var(--bg-input-readonly);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.8rem 1rem;transition:box-shadow .2s;display:flex}.saved-cars li:hover{box-shadow:0 2px 8px #00000014}.car-info{color:var(--text-primary);font-weight:500}.car-nickname{color:var(--color-accent);font-style:italic}.delete-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.3rem;font-size:1.2rem;transition:background .2s}@media (width<=600px){.addcar-container{max-width:100%;padding:.8rem}}.confirm-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--bg-surface);text-align:center;border-radius:16px;width:100%;max-width:400px;padding:2rem;animation:.2s slideUp;box-shadow:0 20px 60px #0000004d}.confirm-icon{margin-bottom:.5rem;font-size:3rem}.confirm-title{color:var(--text-heading);margin:0 0 .5rem;font-size:1.3rem}.confirm-message{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.confirm-actions{justify-content:center;gap:.8rem;display:flex}.confirm-cancel{background:var(--bg-light);color:var(--text-secondary);cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;transition:background .2s}.confirm-cancel:hover:not(:disabled){background:var(--border-default)}.confirm-cancel:disabled{opacity:.5;cursor:not-allowed}.confirm-delete{background:var(--color-danger);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;transition:background .2s}.confirm-delete:hover:not(:disabled){background:var(--color-danger-hover)}.confirm-delete:disabled{opacity:.6;cursor:not-allowed}.confirm-safe{background:var(--color-success);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;transition:background .2s}.confirm-safe:hover:not(:disabled){background:var(--color-success)}.confirm-safe:disabled{opacity:.6;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.garage-container{max-width:900px;margin:0 auto;padding:2rem}.garage-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.garage-header h1{color:var(--text-primary);margin:0;font-size:2rem}.add-car-link{background:var(--color-accent);color:var(--text-on-dark);border-radius:8px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .2s}.add-car-link:hover{background:var(--color-accent-hover)}.garage-loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.1rem}.garage-empty{text-align:center;background:var(--bg-light);border:2px dashed var(--border-default);border-radius:12px;padding:4rem 2rem}.empty-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.garage-empty h2{color:var(--text-primary);margin:0 0 .5rem}.garage-empty p{color:var(--text-secondary);margin:0 0 1.5rem}.add-car-btn{background:var(--color-accent);color:var(--text-on-dark);border-radius:8px;padding:.8rem 1.5rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.add-car-btn:hover{background:var(--color-accent-hover)}.garage-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.car-card{background:var(--bg-surface);box-shadow:var(--shadow-card);color:inherit;border-radius:14px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;position:relative;overflow:hidden}.car-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.car-card-image{aspect-ratio:16/10;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.car-card-cover{object-fit:cover;width:100%;height:100%}.car-icon{filter:grayscale(.1);font-size:3.5rem}.car-card-info{text-align:center;padding:1rem 1.1rem}.car-card-year{color:var(--text-secondary);margin:0;font-size:.85rem;font-weight:500}.car-card-name{color:var(--text-heading);margin:.2rem 0 0;font-size:1.05rem;font-weight:700}.car-card-nickname{color:var(--color-accent);margin:0;font-size:.8rem;font-style:italic}.car-card-nickname-row{cursor:pointer;border-radius:4px;justify-content:center;align-items:center;gap:.3rem;min-height:1.4rem;margin-top:.2rem;padding:.1rem .3rem;transition:background .2s;display:flex}.car-card-nickname-row:hover{background:rgba(var(--color-accent-rgb), .08)}.car-card-edit-icon{opacity:0;font-size:.7rem;transition:opacity .2s}.car-card-nickname-row:hover .car-card-edit-icon{opacity:1}.car-card-add-nickname{color:var(--text-dim);font-size:.75rem;transition:color .2s}.car-card-nickname-row:hover .car-card-add-nickname{color:var(--color-accent)}.car-card-stats{color:var(--text-secondary);gap:.8rem;margin-top:.3rem;font-size:.78rem;display:flex}.car-card-visibility{cursor:pointer;color:var(--color-accent);background:var(--bg-ghost);border:1px solid var(--color-accent);border-radius:12px;margin-top:.5rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-block}.car-card-visibility:hover{background:var(--bg-ghost-hover);color:var(--color-accent-hover)}.car-card-edit-input{text-align:center;width:100%;color:var(--color-accent);background:var(--bg-surface);border:2px solid var(--color-accent);border-radius:6px;outline:none;margin-top:.2rem;padding:.25rem .4rem;font-size:.8rem;font-style:italic}.car-card-delete{width:28px;height:28px;color:var(--text-on-dark);cursor:pointer;opacity:0;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.2rem;line-height:1;transition:opacity .2s,background .2s;display:flex;position:absolute;top:8px;right:8px}.car-card:hover .car-card-delete{opacity:1}.car-card-delete:hover{background:var(--color-danger)}@media (width<=800px){.garage-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.garage-container{max-width:100%;padding:.8rem}.garage-grid{grid-template-columns:repeat(1,1fr)}.garage-header{text-align:center;flex-direction:column;gap:1rem}}.detail-container{max-width:800px;margin:0 auto;padding:2rem}.detail-loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.1rem}.detail-not-found{text-align:center;background:var(--bg-light);border:2px dashed var(--border-default);border-radius:12px;padding:4rem 2rem}.nf-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.detail-not-found h2{color:var(--text-primary);margin:0 0 .5rem}.detail-not-found p{color:var(--text-secondary);margin:0 0 1.5rem}.detail-visibility-btn{float:right;border:1px solid var(--color-accent);cursor:pointer;color:var(--color-accent);background:var(--bg-ghost);border-radius:20px;margin-bottom:.5rem;padding:.35rem .9rem;font-size:.82rem;font-weight:600;transition:all .2s}.detail-visibility-btn:hover{background:var(--bg-ghost-hover);color:var(--color-accent-hover)}.detail-hero{margin-bottom:1.5rem}.detail-image{aspect-ratio:16/9;cursor:pointer;border-radius:16px;justify-content:center;align-items:center;width:100%;transition:opacity .2s;display:flex;position:relative;overflow:hidden}.detail-image:hover{opacity:.92}.detail-image.uploading{cursor:wait;pointer-events:none}.detail-cover-img{object-fit:cover;width:100%;height:100%}.detail-placeholder{flex-direction:column;align-items:center;gap:.8rem;display:flex}.detail-car-icon{filter:grayscale(.1);font-size:6rem}.upload-hint{color:#fffc;opacity:0;background:#00000040;border-radius:20px;padding:.3rem .8rem;font-size:.85rem;font-weight:500;transition:opacity .2s}.detail-image:hover .upload-hint{opacity:1}.upload-overlay{color:var(--text-on-dark);background:#00000080;border-radius:16px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex;position:absolute;inset:0}.detail-content{background:var(--bg-surface);border-radius:16px;padding:2rem;box-shadow:0 2px 12px #0000000f}.detail-name{color:var(--text-heading);margin:0;font-size:2rem}.detail-nickname{color:var(--color-accent);font-size:1.5rem;font-style:italic}.detail-nickname-row{cursor:pointer;border-radius:6px;align-items:center;gap:.4rem;padding:.2rem .5rem;transition:background .2s;display:inline-flex}.detail-nickname-row:hover{background:rgba(var(--color-accent-rgb), .08)}.detail-edit-icon{opacity:0;font-size:.9rem;transition:opacity .2s}.detail-nickname-row:hover .detail-edit-icon{opacity:1}.detail-add-nickname{color:var(--text-dim);font-size:1rem;transition:color .2s}.detail-nickname-row:hover .detail-add-nickname{color:var(--color-accent)}.detail-nickname-edit{margin:.3rem 0}.detail-nickname-input{color:var(--color-accent);background:var(--bg-surface);border:2px solid var(--color-accent);border-radius:8px;outline:none;width:100%;max-width:350px;padding:.3rem .6rem;font-size:1.4rem;font-style:italic}.detail-year{background:var(--bg-ghost);color:var(--color-accent);border-radius:20px;margin-top:.5rem;padding:.25rem .8rem;font-size:.9rem;font-weight:600;display:inline-block}.detail-info-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;display:grid}.info-card{background:var(--bg-light);border-radius:10px;padding:1rem}.info-card-wide{grid-column:1/-1}.info-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;font-size:.75rem;display:block}.info-value{color:var(--text-primary);word-break:break-all;font-size:1.05rem;font-weight:600;display:block}.info-vin{letter-spacing:.1em;font-family:SF Mono,Fira Code,monospace;font-size:.9rem}.detail-desc-section{border-top:1px solid var(--border-light);margin-top:1.5rem;padding-top:1.5rem}.detail-desc-label{color:var(--text-secondary);margin:0 0 .5rem;font-size:1rem}.detail-desc-row{cursor:pointer;border-radius:8px;padding:.5rem;transition:background .2s;position:relative}.detail-desc-row:hover{background:var(--bg-light)}.detail-desc-text{color:var(--text-secondary);white-space:pre-wrap;margin:0;line-height:1.6}.detail-desc-row:hover .detail-edit-icon{opacity:1}.detail-add-desc{color:var(--text-dim);font-size:.95rem;transition:color .2s}.detail-desc-row:hover .detail-add-desc{color:var(--color-accent)}.detail-desc-input{border:2px solid var(--color-accent);resize:vertical;box-sizing:border-box;width:100%;min-height:80px;color:var(--text-primary);border-radius:8px;outline:none;padding:.7rem;font-family:inherit;font-size:1rem;line-height:1.6}.detail-notes{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.detail-notes h3{color:var(--text-secondary);margin:0 0 .5rem;font-size:1rem}.detail-notes p{color:var(--text-secondary);margin:0;line-height:1.6}.detail-actions{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.detail-actions .delete-btn{border:2px solid var(--color-danger);color:var(--color-danger);cursor:pointer;background:0 0;border-radius:8px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;transition:background .2s,color .2s}.detail-actions .delete-btn:hover{background:var(--color-danger);color:var(--text-on-dark)}.detail-meta{text-align:center;color:var(--text-dim);margin-top:1.5rem;font-size:.8rem}@media (width<=600px){.detail-container{max-width:100%;padding:0 .8rem}.detail-info-grid{grid-template-columns:repeat(2,1fr)}.detail-name{font-size:1.5rem}.detail-car-icon{font-size:4rem}}.detail-car-like-area,.carview-like-area{align-items:center;gap:.6rem;margin-bottom:.8rem;display:flex}.car-like-btn{border:1px solid var(--border-default);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:20px;align-items:center;gap:.3rem;padding:.3rem .9rem;font-size:.85rem;transition:all .2s;display:inline-flex}.car-like-btn:hover:not(:disabled){border-color:var(--color-danger);color:var(--color-danger);background:var(--bg-like)}.car-like-btn:disabled{opacity:.5;cursor:default}.car-like-btn.liked{border-color:var(--color-danger);color:var(--color-danger);background:var(--bg-like)}.car-like-count{color:var(--text-secondary);font-size:.85rem}.car-follow-count-display{color:var(--text-muted);font-size:.85rem}.detail-follow-area,.carview-follow-area{margin-bottom:.8rem}.carview-login-to-like{color:var(--text-dim);border:1px solid var(--border-default);border-radius:20px;padding:.3rem .9rem;font-size:.85rem}.post-like-count-header{color:var(--text-secondary);margin-left:.5rem;font-size:.8rem}.mod-like-indicator{color:var(--color-danger);font-size:.8rem}.mods-section{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.mods-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.mods-title{color:var(--text-secondary);align-items:center;gap:.4rem;margin:0;font-size:1rem;display:flex}.add-mod-btn{background:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:background .2s}.add-mod-btn:hover{background:var(--color-accent-hover)}.mod-form{background:var(--bg-light);border-radius:12px;margin-bottom:1rem;padding:1.2rem}.mod-form-row{gap:.8rem;margin-bottom:.8rem;display:flex}.mod-form-row:last-child{margin-bottom:0}.mod-form input[type=text],.mod-form input[type=number],.mod-desc-input{border:1px solid var(--border-default);border-radius:8px;outline:none;flex:1;padding:.6rem .8rem;font-family:inherit;font-size:.9rem}.mod-desc-input{resize:vertical;width:100%;min-height:60px}.mod-form input:focus,.mod-desc-input:focus{border-color:var(--color-accent)}.mod-form input[type=number]{flex:.5}.mod-upload-btn{border:1px dashed var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:.3rem;padding:.5rem 1rem;font-size:.85rem;transition:border-color .2s,color .2s;display:inline-flex}.mod-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.mod-upload-btn.has-image{border-style:solid;border-color:var(--color-accent);color:var(--color-accent)}.mod-form-actions{justify-content:flex-end;gap:.6rem;display:flex}.mod-form-actions button{cursor:pointer;border-radius:8px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s}.mod-save-btn{background:var(--color-accent);color:var(--text-on-dark);border:none}.mod-save-btn:hover{background:var(--color-accent-hover)}.mod-save-btn:disabled{background:var(--disabled-bg);cursor:not-allowed}.mod-cancel-btn{background:var(--bg-ghost);color:var(--color-accent);border:1px solid var(--color-accent)}.mod-cancel-btn:hover{background:var(--bg-ghost-hover);color:var(--color-accent-hover)}.mods-list{flex-direction:column;gap:.8rem;display:flex}.mod-card{background:var(--bg-light);cursor:pointer;border:1px solid #0000;border-radius:12px;align-items:flex-start;gap:1rem;padding:1rem;transition:all .2s;display:flex;position:relative}.mod-card:hover{background:var(--bg-surface);border-color:var(--border-default);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.mod-card:after{content:"→";color:var(--text-dim);opacity:0;font-size:1.1rem;transition:opacity .2s,color .2s;position:absolute;top:50%;right:.8rem;transform:translateY(-50%)}.mod-card:hover:after{opacity:1;color:var(--color-accent)}.mod-card .mod-delete-btn{z-index:1;position:relative}.mod-image{background:var(--bg-input-readonly);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden}.mod-image img{object-fit:cover;width:100%;height:100%}.mod-image-placeholder{opacity:.4;font-size:1.5rem}.mod-info{flex:1;min-width:0}.mod-type{background:var(--bg-ghost-hover);color:var(--color-accent);text-transform:uppercase;letter-spacing:.03em;border-radius:20px;margin-bottom:.3rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.mod-name{color:var(--text-primary);margin:0 0 .2rem;font-size:1rem;font-weight:600}.mod-cost{color:var(--text-secondary);margin:0;font-size:.9rem}.mod-cost strong{color:var(--text-primary)}.mod-date{color:var(--text-secondary);font-size:.8rem;font-weight:400}.mod-desc-preview{color:var(--text-subtle);margin:.2rem 0 0;font-size:.8rem;line-height:1.4}.mod-delete-btn{color:var(--color-danger);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:.2rem .4rem;font-size:1.2rem;transition:background .2s}.mod-delete-btn:hover{background:#e74c3c1a}.gallery-section{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.gallery-title{color:var(--text-secondary);align-items:center;gap:.4rem;margin:0;font-size:1rem;display:flex}.gallery-upload-btn{background:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:background .2s}.gallery-upload-btn:hover:not(:disabled){background:var(--color-accent-hover)}.gallery-upload-btn:disabled{background:var(--disabled-bg);cursor:not-allowed}.gallery-empty{text-align:center;color:var(--text-dim);padding:2rem;font-size:.9rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem;display:grid}.gallery-item{aspect-ratio:1;background:var(--bg-input-readonly);border-radius:12px;position:relative;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;display:block}.gallery-delete-btn{color:var(--text-on-dark);cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1rem;line-height:1;transition:opacity .2s;display:flex;position:absolute;top:.3rem;right:.3rem}.gallery-item:hover .gallery-delete-btn{opacity:1}.gallery-delete-btn:hover{background:#e74c3ce6}.mods-empty{text-align:center;color:var(--text-dim);padding:2rem;font-size:.9rem}.planned-mod-card{padding-left:1.2rem}@media (width<=600px){.mod-form-row{flex-direction:column;gap:.5rem}.mod-form input[type=number]{flex:1}.mod-card{flex-direction:column;gap:.6rem}.mod-image{width:100%;height:160px}}.lightbox-overlay{z-index:2000;background:#000000eb;justify-content:center;align-items:center;animation:.2s lbFadeIn;display:flex;position:fixed;inset:0}.lightbox-content{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.lightbox-image-wrap{justify-content:center;align-items:center;max-width:90vw;max-height:85vh;display:flex}.lightbox-image-wrap img{object-fit:contain;border-radius:8px;max-width:100%;max-height:85vh;animation:.2s lbZoomIn;box-shadow:0 20px 60px #00000080}.lightbox-close{color:var(--text-on-dark);cursor:pointer;z-index:10;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.4rem;transition:background .2s;display:flex;position:absolute;top:1.2rem;right:1.2rem}.lightbox-close:hover{background:#ffffff4d}.lightbox-counter{color:#fffc;z-index:10;background:#0006;border-radius:20px;padding:.3rem .8rem;font-size:.9rem;font-weight:500;position:absolute;top:1.2rem;left:50%;transform:translate(-50%)}.lightbox-arrow{color:var(--text-on-dark);cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:2.5rem;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-arrow:hover{background:#ffffff4d}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}@keyframes lbZoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (width<=600px){.lightbox-arrow{width:40px;height:40px;font-size:2rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}.lightbox-close{top:.8rem;right:.8rem}}.gallery-detail-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.gallery-detail-car-info{flex-direction:column;gap:.2rem;display:flex}.gallery-detail-title{color:var(--text-heading);align-items:center;gap:.4rem;margin:0;font-size:1.3rem;font-weight:700;display:flex}.gallery-detail-subtitle{color:var(--text-subtle);margin:0;font-size:.9rem}.gallery-detail-owner-badge{background:var(--bg-success-light);color:var(--text-success-dark);white-space:nowrap;border-radius:20px;padding:.25rem .7rem;font-size:.8rem;font-weight:600}.gallery-detail-header-actions{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.gallery-grid-full .gallery-item{min-height:0}.gallery-expand-btn{background:var(--bg-ghost);width:100%;color:var(--color-accent);border:1px solid var(--color-accent);cursor:pointer;border-radius:12px;margin-top:1rem;padding:.6rem 0;font-size:.9rem;font-weight:600;transition:all .2s;display:block}.gallery-expand-btn:hover{background:var(--bg-ghost-hover);border-color:var(--color-accent-hover);color:var(--color-accent-hover)}.post-detail-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.post-detail-title{color:var(--text-heading);margin:0 0 .2rem;font-size:1.3rem;font-weight:700}.post-detail-subtitle{color:var(--text-subtle);margin:0;font-size:.9rem}.post-create-form{background:var(--bg-light);border-radius:12px;margin-bottom:1.5rem;padding:1.2rem}.post-create-form textarea{border:1px solid var(--border-default);resize:vertical;box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:.7rem;font-family:inherit;font-size:.95rem;line-height:1.5;transition:border-color .2s}.post-create-form textarea:focus{border-color:var(--color-accent)}.post-create-images{flex-wrap:wrap;gap:.5rem;margin-top:.8rem;display:flex}.post-create-image-preview{background:var(--bg-input-readonly);border-radius:8px;width:80px;height:80px;position:relative;overflow:hidden}.post-create-image-preview img{object-fit:cover;width:100%;height:100%}.post-image-remove{width:20px;height:20px;color:var(--text-on-dark);cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;line-height:1;display:flex;position:absolute;top:2px;right:2px}.post-create-actions{justify-content:space-between;align-items:center;margin-top:.8rem;display:flex}.post-add-images-btn{background:var(--bg-ghost);border:1px solid var(--color-accent);color:var(--color-accent);cursor:pointer;border-radius:8px;padding:.45rem .9rem;font-size:.85rem;transition:background .2s}.post-add-images-btn:hover:not(:disabled){background:var(--bg-ghost-hover)}.post-create-actions button[type=submit]{background:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;padding:.45rem 1.4rem;font-size:.9rem;font-weight:600;transition:background .2s}.post-create-actions button[type=submit]:hover:not(:disabled){background:var(--color-accent-hover)}.post-create-actions button[type=submit]:disabled,.post-add-images-btn:disabled{opacity:.5;cursor:not-allowed}.post-list{flex-direction:column;gap:1rem;display:flex}.post-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:12px;padding:1.2rem;transition:all .2s;position:relative}.post-card:hover{background:var(--bg-surface);border-color:var(--border-default);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.post-card:after{content:"→";color:var(--text-dim);opacity:0;font-size:1.1rem;transition:opacity .2s,color .2s;position:absolute;top:50%;right:.8rem;transform:translateY(-50%)}.post-card:hover:after{opacity:1;color:var(--color-accent)}.post-card .post-delete-btn,.post-card .post-card-image,.post-card .post-comment-count{z-index:1;position:relative}.post-card-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.post-card-date{color:var(--text-secondary);font-size:.8rem}.post-comment-count{color:var(--text-secondary);align-items:center;gap:.2rem;margin-left:auto;margin-right:.5rem;font-size:.8rem;display:flex}.post-delete-btn{cursor:pointer;opacity:.4;background:0 0;border:none;padding:.2rem;font-size:1rem;transition:opacity .2s}.post-delete-btn:hover{opacity:1}.post-card-content{color:var(--text-primary);white-space:pre-wrap;font-size:.95rem;line-height:1.6}.post-card-images{flex-wrap:wrap;gap:.5rem;margin-top:.8rem;display:flex}.post-card-image{background:var(--bg-input-readonly);border-radius:8px;width:120px;height:120px;overflow:hidden}.post-card-image img{object-fit:cover;width:100%;height:100%}.posts-section{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.posts-section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.posts-section-title{color:var(--text-secondary);align-items:center;gap:.4rem;margin:0;font-size:1rem;display:flex}.posts-expand-btn{background:var(--bg-ghost);color:var(--color-accent);border:1px solid var(--color-accent);cursor:pointer;border-radius:12px;width:100%;margin-top:.5rem;padding:.6rem 0;font-size:.9rem;font-weight:600;transition:all .2s}.posts-expand-btn:hover{background:var(--bg-ghost-hover);border-color:var(--color-accent-hover);color:var(--color-accent-hover)}.post-preview-empty{text-align:center;color:var(--text-dim);padding:1rem;font-size:.9rem}.comments-section{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.comments-title{color:var(--text-secondary);align-items:center;gap:.4rem;margin:0 0 1rem;font-size:1rem;display:flex}.comments-login-hint{background:var(--bg-light);color:var(--text-subtle);border-radius:10px;margin-bottom:1rem;padding:1rem;font-size:.9rem}.comments-login-hint a{color:var(--color-accent);font-weight:600;text-decoration:none}.comments-login-hint a:hover{text-decoration:underline}.comment-form{margin-bottom:1.2rem}.comment-form textarea,.comment-reply-form textarea{border:1px solid var(--border-default);resize:vertical;box-sizing:border-box;border-radius:10px;outline:none;width:100%;min-height:60px;margin-bottom:.5rem;padding:.8rem;font-family:inherit;font-size:.95rem}.comment-form textarea:focus,.comment-reply-form textarea:focus{border-color:var(--color-accent)}.comment-form button,.comment-reply-form button{background:var(--color-accent);color:var(--text-on-dark);cursor:pointer;border:none;border-radius:8px;padding:.5rem 1.2rem;font-size:.85rem;font-weight:600;transition:background .2s}.comment-form button:hover:not(:disabled),.comment-reply-form button:hover:not(:disabled){background:var(--color-accent-hover)}.comment-form button:disabled,.comment-reply-form button:disabled{background:var(--disabled-bg);cursor:not-allowed}.comment-reply-form{background:var(--bg-light);border-radius:10px;margin-top:.6rem;margin-left:2rem;padding:.8rem}.comments-list{flex-direction:column;gap:.8rem;display:flex}.comment-item{background:var(--bg-light);border-radius:12px;padding:1rem}.comment-reply{background:var(--bg-ghost);margin-top:.6rem;margin-left:2rem}.comment-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.comment-avatar{font-size:1.2rem}.comment-username{color:var(--text-primary);font-size:.95rem;font-weight:700}.comment-date{color:var(--text-secondary);font-size:.8rem}.comment-delete{color:var(--color-danger);cursor:pointer;opacity:.5;background:0 0;border:none;margin-left:auto;padding:.2rem;font-size:.85rem;transition:opacity .2s}.comment-item:hover .comment-delete{opacity:1}.comment-body{color:var(--text-secondary);white-space:pre-wrap;font-size:.95rem;line-height:1.5}.comment-actions{margin-top:.5rem}.comment-reply-btn{color:var(--color-accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;font-weight:600;transition:color .2s}.comment-reply-btn:hover{color:var(--color-accent-hover)}.comment-like-btn{cursor:pointer;background:0 0;border:none;align-items:center;gap:.2rem;padding:0 .5rem 0 0;font-size:.85rem;transition:transform .15s;display:inline-flex}.comment-like-btn:hover:not(:disabled){transform:scale(1.15)}.comment-like-btn:disabled{opacity:.5;cursor:default}.comment-like-btn.liked{filter:none}.like-count{color:var(--text-secondary);font-size:.8rem;font-weight:600}.comment-login-hint{color:var(--text-secondary);font-size:.85rem}.comments-loading,.comments-empty{text-align:center;color:var(--text-dim);padding:2rem;font-size:.9rem}@media (width<=600px){.comment-reply,.comment-reply-form{margin-left:1rem}}.carview-container{max-width:800px;margin:0 auto;padding:2rem}.carview-loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.1rem}.carview-not-found{text-align:center;background:var(--bg-light);border:2px dashed var(--border-default);border-radius:12px;padding:4rem 2rem}.carview-not-found .nf-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.carview-not-found h2{color:var(--text-primary);margin:0 0 .5rem}.carview-not-found p{color:var(--text-secondary);margin:0 0 1.5rem}.back-btn{color:var(--color-accent);cursor:pointer;background:0 0;border:none;margin-bottom:1.5rem;padding:.4rem 0;font-size:1rem;font-weight:600;transition:color .2s}.back-btn:hover{color:var(--color-accent-hover)}.carview-hero{margin-bottom:1.5rem}.carview-image{aspect-ratio:16/9;border-radius:16px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.carview-cover-img{object-fit:cover;width:100%;height:100%}.carview-car-icon{filter:grayscale(.1);font-size:6rem}.carview-content{background:var(--bg-surface);border-radius:16px;padding:2rem;box-shadow:0 2px 12px #0000000f}.carview-name{color:var(--text-heading);margin:0;font-size:2rem}.carview-nickname{color:var(--color-accent);margin:.2rem 0 0;font-size:1.3rem;font-style:italic}.carview-owner{background:var(--bg-stripe);border-radius:20px;align-items:center;gap:.3rem;margin-top:.5rem;padding:.25rem .6rem;display:inline-flex}.carview-owner-avatar{font-size:.85rem}.carview-owner-name{color:var(--text-secondary);font-size:.85rem;font-weight:500}.carview-year{background:var(--bg-ghost);color:var(--color-accent);border-radius:20px;margin-top:.5rem;padding:.25rem .8rem;font-size:.9rem;font-weight:600;display:inline-block}.carview-info-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;display:grid}.carview-info-card{background:var(--bg-light);border-radius:10px;padding:1rem}.carview-info-wide{grid-column:1/-1}.carview-info-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;font-size:.75rem;display:block}.carview-info-value{color:var(--text-primary);word-break:break-all;font-size:1.05rem;font-weight:600;display:block}.carview-vin{letter-spacing:.1em;font-family:SF Mono,Fira Code,monospace;font-size:.9rem}.carview-desc{border-top:1px solid var(--border-light);margin-top:1.5rem;padding-top:1.5rem}.carview-desc h3{color:var(--text-secondary);margin:0 0 .5rem;font-size:1rem}.carview-desc p{color:var(--text-secondary);white-space:pre-wrap;margin:0;line-height:1.6}.carview-notes{border-top:1px solid var(--border-light);margin-top:2rem;padding-top:1.5rem}.carview-notes h3{color:var(--text-secondary);margin:0 0 .5rem;font-size:1rem}.carview-notes p{color:var(--text-secondary);margin:0;line-height:1.6}.carview-meta{text-align:center;color:var(--text-dim);margin-top:1.5rem;font-size:.8rem}@media (width<=600px){.carview-container{max-width:100%;padding:0 .8rem}.carview-info-grid{grid-template-columns:repeat(2,1fr)}.carview-name{font-size:1.5rem}.carview-car-icon{font-size:4rem}}.showroom-container{max-width:1100px;margin:0 auto;padding:2rem}.showroom-header{margin-bottom:2rem}.showroom-header h1{color:var(--text-primary);margin:0;font-size:2rem}.showroom-subtitle{color:var(--text-subtle);margin:.3rem 0 0;font-size:.95rem}.showroom-loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.1rem}.showroom-empty{text-align:center;background:var(--bg-light);border:2px dashed var(--border-default);border-radius:12px;padding:4rem 2rem}.showroom-empty .empty-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.showroom-empty h2{color:var(--text-primary);margin:0 0 .5rem}.showroom-empty p{color:var(--text-secondary);margin:0 0 1.5rem}.showroom-empty .add-car-btn{background:var(--color-accent);color:var(--text-on-dark);border-radius:8px;padding:.8rem 1.5rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.showroom-empty .add-car-btn:hover{background:var(--color-accent-hover)}.showroom-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.showroom-card{background:var(--bg-surface);box-shadow:var(--shadow-card);color:inherit;border-radius:14px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden}.showroom-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.showroom-card-image{aspect-ratio:16/10;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.showroom-card-cover{object-fit:cover;width:100%;height:100%}.showroom-car-icon{filter:grayscale(.1);font-size:3.5rem}.showroom-card-body{padding:1rem 1.1rem}.showroom-card-info{justify-content:space-between;align-items:baseline;display:flex}.showroom-card-name{color:var(--text-heading);margin:0;font-size:1.05rem;font-weight:700}.showroom-card-year{color:var(--text-muted);font-size:.85rem;font-weight:500}.showroom-card-nickname{color:var(--color-accent);margin:.25rem 0 0;font-size:.85rem;font-style:italic}.showroom-card-owner{border-top:1px solid var(--bg-light);align-items:center;gap:.3rem;margin-top:.7rem;padding-top:.6rem;display:flex}.showroom-card-stats{color:var(--text-muted);align-items:center;gap:.8rem;margin-top:.4rem;font-size:.85rem;display:flex}.showroom-card-follow{margin-top:.5rem;display:inline-block}@media (width<=900px){.showroom-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.showroom-container{max-width:100%;padding:0 .8rem}.showroom-grid{grid-template-columns:1fr}}.followed-container{max-width:900px;margin:0 auto;padding:2rem}.followed-header{margin-bottom:2rem}.followed-header h1{color:var(--text-primary);margin:0;font-size:2rem}.followed-subtitle{color:var(--text-subtle);margin:.3rem 0 0;font-size:.95rem}.followed-loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.1rem}.followed-empty{text-align:center;background:var(--bg-light);border:2px dashed var(--border-default);border-radius:12px;padding:4rem 2rem}.followed-empty .empty-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.followed-empty h2{color:var(--text-primary);margin:0 0 .5rem}.followed-empty p{color:var(--text-secondary);margin:0 0 1.5rem}.followed-empty .add-car-btn,.followed-empty a.add-car-btn{background:var(--color-accent);color:var(--text-on-dark);border-radius:8px;padding:.8rem 1.5rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.followed-empty .add-car-btn:hover{background:var(--color-accent-hover)}.followed-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.followed-card{background:var(--bg-surface);box-shadow:var(--shadow-card);color:inherit;border-radius:14px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;position:relative;overflow:hidden}.followed-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.followed-card-image{aspect-ratio:16/10;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.followed-card-cover{object-fit:cover;width:100%;height:100%}.followed-car-icon{filter:grayscale(.1);font-size:3.5rem}.followed-card-body{padding:1rem 1.1rem}.followed-card-info{justify-content:space-between;align-items:baseline;display:flex}.followed-card-name{color:var(--text-heading);margin:0;font-size:1.05rem;font-weight:700}.followed-card-year{color:var(--text-muted);font-size:.85rem;font-weight:500}.followed-card-owner{align-items:center;gap:.3rem;margin-top:.4rem;display:flex}.owner-avatar{font-size:.85rem}.owner-name{color:var(--text-muted);font-size:.8rem}.followed-card-visibility{color:var(--text-secondary);margin-top:.4rem;font-size:.75rem;font-weight:600}.followed-unfollow-btn{border:1px solid var(--border-default);background:var(--bg-hover-row);width:100%;color:var(--text-secondary);cursor:pointer;border-radius:8px;margin-top:.6rem;padding:.4rem 0;font-size:.85rem;font-weight:600;transition:all .2s}.followed-unfollow-btn:hover:not(:disabled){background:var(--bg-delete-ghost);color:var(--color-danger);border-color:var(--color-danger)}.followed-unfollow-btn:disabled{opacity:.5;cursor:default}.follow-btn{border:1px solid var(--border-default);background:var(--bg-light);color:var(--text-secondary);cursor:pointer;border-radius:20px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.follow-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--bg-ghost)}.follow-btn.following{border-color:var(--color-success);color:var(--color-success);background:var(--bg-success-light)}.follow-btn.following:hover:not(:disabled){border-color:var(--color-danger);color:var(--color-danger);background:var(--bg-like)}.follow-btn:disabled{opacity:.5;cursor:default}.follow-btn .follow-count{color:var(--text-muted);background:var(--border-light);text-align:center;border-radius:10px;min-width:1.2em;padding:.1rem .4rem;font-size:.7rem}.follow-btn.following .follow-count{background:var(--bg-success-light);color:var(--color-success)}.follow-btn-mini{padding:.25rem .6rem;font-size:.75rem}@media (width<=900px){.followed-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.followed-container{max-width:100%;padding:0 .8rem}.followed-grid{grid-template-columns:1fr}}.feedback-container{max-width:600px;margin:0 auto;padding:2rem}.feedback-header{margin-bottom:2rem}.feedback-header h1{color:var(--text-primary);margin:0;font-size:2rem}.feedback-subtitle{color:var(--text-subtle);margin:.3rem 0 0;font-size:.95rem}.feedback-form{background:var(--bg-surface);box-shadow:var(--shadow-card);border-radius:14px;padding:1.5rem}.form-group{margin-bottom:1.2rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.form-group .optional{text-transform:none;color:var(--text-dim);font-size:.75rem;font-weight:400}.form-group input,.form-group textarea{border:1px solid var(--border-default);box-sizing:border-box;border-radius:10px;outline:none;width:100%;padding:.7rem .9rem;font-family:inherit;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(var(--color-accent-rgb), .1)}.form-group textarea{resize:vertical;min-height:120px;line-height:1.5}.feedback-submit-btn{background:var(--color-accent);width:100%;color:var(--text-on-dark);cursor:pointer;border:none;border-radius:10px;padding:.8rem;font-size:1rem;font-weight:600;transition:background .2s}.feedback-submit-btn:hover:not(:disabled){background:var(--color-accent-hover)}.feedback-submit-btn:disabled{opacity:.5;cursor:default}.feedback-error{background:var(--bg-error-light);color:var(--color-danger-hover);border-radius:8px;margin-bottom:1rem;padding:.6rem .9rem;font-size:.85rem}.feedback-success{text-align:center;background:var(--bg-light);border:2px solid var(--border-default);border-radius:14px;padding:4rem 2rem}.success-icon{margin-bottom:1rem;font-size:4rem}.feedback-success h2{color:var(--text-primary);margin:0 0 .5rem}.feedback-success p{color:var(--text-secondary);margin:0 0 1.5rem}.feedback-success .feedback-submit-btn{width:auto;padding:.7rem 1.5rem;display:inline-block}@media (width<=600px){.feedback-container{max-width:100%;padding:.8rem}}.moddetail-container{max-width:720px;margin:0 auto;padding:1.5rem}.moddetail-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.3rem;margin-bottom:1rem;font-size:.95rem;transition:color .2s;display:inline-flex}.moddetail-back:hover{color:var(--text-primary)}.moddetail-hero{aspect-ratio:16/9;background:var(--bg-input-readonly);border-radius:16px;width:100%;margin-bottom:1.5rem;position:relative;overflow:hidden}.moddetail-hero img{object-fit:cover;width:100%;height:100%;display:block}.moddetail-hero-placeholder{opacity:.25;background:var(--bg-input-readonly);justify-content:center;align-items:center;width:100%;height:100%;font-size:4rem;display:flex}.moddetail-hero-overlay{color:var(--text-on-dark);cursor:pointer;opacity:0;background:#00000059;justify-content:center;align-items:center;font-size:.9rem;transition:opacity .2s;display:flex;position:absolute;inset:0}.moddetail-hero:hover .moddetail-hero-overlay{opacity:1}.moddetail-info{margin-bottom:1.5rem}.moddetail-car-name{color:var(--text-subtle);margin:0 0 .3rem;font-size:1.1rem}.moddetail-mod-name{color:var(--text-heading);margin:0 0 .5rem;font-size:1.6rem;font-weight:700}.moddetail-type-badge{background:var(--bg-ghost-hover);color:var(--color-accent);text-transform:uppercase;letter-spacing:.03em;border-radius:20px;padding:.25rem .8rem;font-size:.8rem;font-weight:600;display:inline-block}.moddetail-meta{flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.8rem;display:flex}.moddetail-cost{color:var(--color-success);font-size:1.3rem;font-weight:700}.moddetail-date{color:var(--text-secondary);font-size:.85rem}.moddetail-owner-badge{background:var(--bg-warning);color:var(--text-warning);border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.8rem;font-weight:600;display:inline-flex}.moddetail-edit-section{border-top:1px solid var(--border-light);margin-top:1.5rem;padding-top:1.5rem}.moddetail-edit-section h3{color:var(--text-secondary);margin:0 0 1rem;font-size:1rem}.moddetail-form-row{gap:.8rem;margin-bottom:1rem;display:flex}.moddetail-form-row input[type=text],.moddetail-form-row input[type=number],.moddetail-desc-input{border:1px solid var(--border-default);border-radius:10px;outline:none;flex:1;padding:.6rem .9rem;font-family:inherit;font-size:.95rem}.moddetail-desc-input{resize:vertical;width:100%;min-height:80px}.moddetail-form-row input:focus,.moddetail-desc-input:focus{border-color:var(--color-accent)}.moddetail-form-row input[type=number]{flex:.4}.moddetail-image-row{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.moddetail-upload-btn{border:1px dashed var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;border-radius:10px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s;display:inline-flex}.moddetail-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.moddetail-upload-btn.has-image{border-style:solid;border-color:var(--color-accent);color:var(--color-accent)}.moddetail-preview-thumb{border-radius:10px;flex-shrink:0;width:60px;height:60px;overflow:hidden}.moddetail-preview-thumb img{object-fit:cover;width:100%;height:100%}.moddetail-actions{flex-wrap:wrap;justify-content:flex-start;gap:.7rem;display:flex}.moddetail-actions button{cursor:pointer;border:none;border-radius:10px;padding:.5rem 1.2rem;font-size:.9rem;font-weight:600;transition:all .2s}.moddetail-save-btn{background:var(--color-accent);color:var(--text-on-dark)}.moddetail-save-btn:hover{background:var(--color-accent-hover)}.moddetail-save-btn:disabled{background:var(--disabled-bg);cursor:not-allowed}.moddetail-cancel-btn{background:var(--bg-ghost);color:var(--color-accent);border:1px solid var(--color-accent)}.moddetail-cancel-btn:hover{background:var(--bg-ghost-hover);color:var(--color-accent-hover)}.moddetail-delete-btn{background:var(--color-danger);color:var(--text-on-dark);margin-left:auto}.moddetail-delete-btn:hover{background:var(--color-danger-hover)}.moddetail-readonly{border-top:1px solid var(--border-light);margin-top:1.5rem;padding-top:1.5rem}.moddetail-readonly h3{color:var(--text-secondary);margin:0 0 .8rem;font-size:1rem}.moddetail-readonly-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.8rem;display:grid}.moddetail-readonly-item{background:var(--bg-light);border-radius:10px;padding:.8rem 1rem}.moddetail-readonly-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem;font-size:.75rem}.moddetail-readonly-value{color:var(--text-primary);font-size:1rem;font-weight:600}.moddetail-product-link{color:var(--color-accent);word-break:break-all;margin-top:.6rem;font-size:.9rem;text-decoration:none;transition:color .2s;display:inline-block}.moddetail-product-link:hover{color:var(--color-accent-hover);text-decoration:underline}.moddetail-description{background:var(--bg-light);color:var(--text-secondary);white-space:pre-wrap;border-radius:10px;margin-top:.8rem;padding:.8rem 1rem;font-size:.95rem;line-height:1.6}.moddetail-readonly-item-wide{grid-column:1/-1}.moddetail-readonly-desc{color:var(--text-secondary);white-space:pre-wrap;font-size:.95rem;font-weight:400;line-height:1.6}.moddetail-loading,.moddetail-notfound{text-align:center;color:var(--text-subtle);padding:4rem 1rem}.moddetail-notfound h2{color:var(--text-primary);margin-bottom:.5rem}@media (width<=600px){.moddetail-container{max-width:100%;padding:.8rem}.moddetail-form-row{flex-direction:column;gap:.6rem}.moddetail-form-row input[type=number]{flex:1}.moddetail-actions{flex-direction:column}.moddetail-delete-btn{margin-left:0}}.mod-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:1.5rem;display:flex}.mod-detail-title{color:var(--text-heading);align-items:center;gap:.5rem;margin:0;font-size:1.4rem;font-weight:700;display:flex}.view-badge{background:var(--bg-ghost-hover);color:var(--color-accent);text-transform:uppercase;letter-spacing:.03em;border-radius:20px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.mod-detail-actions{flex-wrap:wrap;gap:.6rem;display:flex}.mod-detail-actions button{cursor:pointer;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s}.edit-btn{background:var(--color-accent);color:var(--text-on-dark)}.edit-btn:hover{background:var(--color-accent-hover)}.delete-btn{background:var(--bg-delete-ghost);color:var(--color-danger)}.delete-btn:hover{background:var(--delete-hover-bg)}.save-btn{background:var(--color-accent);color:var(--text-on-dark)}.save-btn:hover{background:var(--color-accent-hover)}.save-btn:disabled{background:var(--disabled-bg);cursor:not-allowed}.cancel-btn{background:var(--bg-ghost);color:var(--color-accent);border:1px solid var(--color-accent)}.cancel-btn:hover{background:var(--bg-ghost-hover);color:var(--color-accent-hover)}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.done-btn{background:var(--color-accent);color:var(--text-on-dark)}.done-btn:hover{background:var(--color-accent-hover)}.done-btn:disabled{background:var(--disabled-bg);cursor:not-allowed}.mod-info-card{background:var(--bg-light);border-radius:12px;margin-bottom:1.5rem;padding:1.2rem}.edit-form .form-group{margin-bottom:1rem}.edit-form .form-group label{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem;font-size:.8rem;display:block}.edit-form .form-group input,.edit-form .form-group textarea{border:1px solid var(--border-default);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:.6rem .8rem;font-family:inherit;font-size:.95rem}.edit-form .form-group input:focus,.edit-form .form-group textarea:focus{border-color:var(--color-accent)}.edit-form .form-group textarea{resize:vertical;min-height:80px;line-height:1.5}.info-grid{grid-template-columns:repeat(2,1fr);gap:.8rem;display:grid}.info-row{border-bottom:1px solid var(--border-light);flex-direction:column;gap:.2rem;padding:.6rem 0;display:flex}.info-row:last-child{border-bottom:none}.info-row-full{grid-column:1/-1}.info-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.info-value{color:var(--text-primary);font-size:1rem;font-weight:600}.info-value a{color:var(--color-accent);text-decoration:none}.info-value a:hover{text-decoration:underline}.notes-text{color:var(--text-secondary);white-space:pre-wrap;margin-top:.2rem;font-weight:400;line-height:1.6}@media (width<=600px){.info-grid{grid-template-columns:1fr}}.notfound-shell{background:var(--text-on-dark);flex-direction:column;width:100vw;height:100vh;font-family:Arial Black,Helvetica Neue,Helvetica,Arial,sans-serif;display:flex;overflow:hidden}.notfound-deco-row{text-align:center;word-break:break-all;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:1rem 1rem .6rem;line-height:1.4;overflow:hidden}.deco-char{letter-spacing:.04em;margin:0 .15rem;font-size:2.6rem;font-weight:900;display:inline-block}.deco-char.d-blue{color:#00f}.deco-char.d-green{color:#0f0}.deco-char.d-red{color:red}.notfound-body{flex:1;justify-content:center;align-items:center;min-height:0;padding:2rem;display:flex;position:relative}.edge-deco{pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:space-between;align-items:center;padding:2rem 0;display:flex;position:absolute;top:0;bottom:0}.edge-left{left:1rem}.edge-right{right:1rem}.edge-digit{font-size:7rem;font-weight:900;line-height:1}.e-red{color:red}.e-green{color:#0f0}.e-blue{color:#00f}.notfound-message{text-align:center;z-index:10;position:relative}.notfound-icon{image-rendering:auto;width:300px;max-width:70vw;height:auto;margin:0 auto .5rem;display:block}.notfound-text{color:var(--text-secondary);margin:0 0 .6rem;font-family:Helvetica,Arial,sans-serif;font-size:1.35rem;font-weight:600}.notfound-sub{color:var(--text-muted);max-width:380px;margin:0 0 1.8rem;font-family:Helvetica,Arial,sans-serif;font-size:.95rem}.notfound-home-btn{background:var(--color-accent);color:var(--text-on-dark);border-radius:8px;padding:.65rem 2rem;font-family:Helvetica,Arial,sans-serif;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-block}.notfound-home-btn:hover{background:var(--color-accent-hover)}.notfound-footer{text-align:right;color:var(--text-secondary);flex-shrink:0;padding:.8rem 1.5rem;font-family:Helvetica,Arial,sans-serif;font-size:.75rem}@media (width<=768px){.deco-char{font-size:1.6rem}.edge-digit{font-size:4rem}.edge-left{left:.3rem}.edge-right{right:.3rem}.notfound-icon{width:220px}.notfound-text{font-size:1.1rem}}@media (width<=480px){.notfound-deco-row{padding:.6rem .3rem .4rem}.deco-char{margin:0 .06rem;font-size:1.2rem}.edge-deco{display:none}.notfound-icon{width:160px}.notfound-text{font-size:1rem}.notfound-footer{text-align:center}}body{margin:0}.app-shell{background:var(--bg-page);min-height:100vh}.app-main{max-width:900px;margin:0 auto;padding:2rem}@media (width<=600px){.app-main{max-width:100%;padding:.8rem}}:root{--color-primary:#15281d;--color-accent:#2d8a56;--color-accent-rgb:45, 138, 86;--color-accent-hover:#236b43;--color-danger:#e74c3c;--color-danger-hover:#c0392b;--color-success:#27ae60;--color-warning:#f59e0b;--bg-page:#f0f3f1;--bg-surface:#fff;--bg-ghost:#f0faf4;--bg-ghost-hover:#e0f5e8;--bg-like:#fff5f5;--bg-light:#f8f9fa;--bg-warning:#fff3cd;--text-warning:#856404;--bg-success-light:#d4edda;--text-success-dark:#2e7d32;--bg-error-light:#fff0f0;--bg-delete-ghost:#ffeaea;--bg-input-readonly:#eaedeb;--bg-stripe:#f5f5f5;--bg-hover-row:#f8f8f8;--border-input:#ced4da;--text-placeholder:#495057;--auth-dark-bg:#282c34;--error-border:#3d1f24;--error-bg:#2c1418;--error-text:#ff6b6b;--disabled-bg:#ccc;--disabled-text:#adb5bd;--success-toast-text:#155724;--success-toast-border:#c3e6cb;--dark-border:#3a3f4a;--alert-danger-bg:#f8d7da;--alert-danger-text:#721c24;--alert-danger-border:#f5c6cb;--delete-hover-bg:#ffd6d6;--logout-border:#555;--text-primary:#333;--text-secondary:#666;--text-muted:#999;--text-dim:#aaa;--text-on-dark:#fff;--text-on-accent:#fff;--text-subtle:#888;--text-heading:#222;--border-default:#ddd;--border-light:#eee;--shadow-card:0 2px 10px #00000012;--shadow-card-hover:0 10px 30px #0000001f;--shadow-header:0 2px 8px #00000026;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:20px}.btn-primary{background:var(--color-accent);color:var(--text-on-accent);border-radius:var(--radius-md);cursor:pointer;border:none;font-weight:600;transition:background .2s}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}.btn-primary:disabled{cursor:not-allowed;background:#ccc}.btn-ghost{background:var(--bg-ghost);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:all .2s}.btn-ghost:hover:not(:disabled){background:var(--bg-ghost-hover);color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-ghost:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:var(--color-danger);color:var(--text-on-dark);border-radius:var(--radius-md);cursor:pointer;border:none;font-weight:600;transition:background .2s}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-like{border:1px solid var(--border-default);border-radius:var(--radius-pill);cursor:pointer;color:var(--text-secondary);background:0 0;align-items:center;gap:.3rem;padding:.3rem .9rem;font-size:.85rem;transition:all .2s;display:inline-flex}.btn-like:hover:not(:disabled),.btn-like.liked{border-color:var(--color-danger);color:var(--color-danger);background:var(--bg-like)}.btn-like:disabled{opacity:.5;cursor:default}.btn-back{color:var(--color-accent);cursor:pointer;background:0 0;border:none;margin-bottom:1.5rem;padding:.4rem 0;font-size:1rem;font-weight:600;transition:color .2s}.btn-back:hover{color:var(--color-accent-hover)}
