.home-container{min-height:100vh;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);display:flex;flex-direction:column}.home-content{flex:1;max-width:900px;margin:0 auto;width:100%;padding:40px 20px}.home-hero{text-align:center;margin-bottom:40px}.home-hero h1{font-size:36px;font-weight:700;margin-bottom:12px;color:#000}.home-hero p{font-size:18px;color:#666;margin:0}.auth-section{margin-bottom:40px}.auth-card{background:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center}.icon-large{font-size:48px;margin-bottom:16px}.auth-card h2{font-size:24px;margin-bottom:12px;color:#333}.auth-card p{font-size:15px;color:#666;margin-bottom:24px;line-height:1.6}.btn-connect{background-color:#000;color:#fff;font-size:16px;padding:12px 24px;width:100%;margin-bottom:32px}.btn-connect:hover:not(:disabled){background-color:#333}.authenticated-section{margin-bottom:40px}.success-card{background:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center;border-top:4px solid #388e3c}.success-card h2{font-size:24px;margin-bottom:12px;color:#388e3c}.success-card p{font-size:15px;color:#666;margin-bottom:24px}.btn-primary{background-color:#000;color:#fff;font-size:16px;padding:12px 24px;width:100%;margin-bottom:12px}.btn-secondary{background-color:#f5f5f5;color:#333;border:1px solid #ddd;font-size:14px;width:100%}.btn-secondary:hover:not(:disabled){background-color:#efefef}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.info-card{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a;text-align:center}.info-icon{font-size:36px;margin-bottom:12px}.info-card h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#333}.info-card p{font-size:14px;color:#666;line-height:1.6;margin:0}.home-footer{background-color:#0000000d;padding:20px;text-align:center;border-top:1px solid #ddd;font-size:13px;color:#666}.home-footer a{color:#1976d2;text-decoration:none}.home-footer a:hover{text-decoration:underline}@media (max-width: 600px){.home-hero h1{font-size:28px}.home-hero p{font-size:16px}.auth-card,.success-card{padding:24px}.info-grid,.tech-grid{grid-template-columns:1fr}}.error-banner{background-color:#ffebee;border-left:4px solid #d32f2f;padding:12px 16px;margin-bottom:16px;border-radius:4px;animation:slideIn .3s ease-out}.error-banner-content{display:flex;align-items:center;gap:12px;color:#d32f2f;font-size:14px}.error-banner-icon{flex-shrink:0;font-size:16px}.error-banner-message{flex:1}.error-banner-close{flex-shrink:0;background:none;border:none;color:#d32f2f;font-size:16px;padding:0;cursor:pointer;opacity:.7;transition:opacity .2s}.error-banner-close:hover{opacity:1}.oauth-callback-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#f5f5f5;padding:20px}.oauth-callback-card{background:#fff;border-radius:8px;padding:40px;text-align:center;box-shadow:0 2px 8px #0000001a;max-width:400px;width:100%}.loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.oauth-callback-card h2{font-size:20px;margin-bottom:8px;color:#333}.oauth-callback-card p{color:#666;font-size:14px;margin-bottom:0}.error-icon{font-size:48px;margin-bottom:16px}.btn-primary{background-color:#000;color:#fff;margin-top:20px}.btn-primary:hover:not(:disabled){background-color:#333}.form-field{margin-bottom:20px}.form-field-label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:#333}.required-indicator{color:#d32f2f;margin-left:4px}.form-field-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:all .2s}.form-field-input:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #0000001a}.form-field-input.has-error{border-color:#d32f2f}.form-field-input.has-error:focus{box-shadow:0 0 0 2px #d32f2f1a}.helper-text{color:#666;font-size:13px;margin-top:4px}.ad-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:all .2s;box-shadow:0 1px 3px #0000000d}.ad-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#ddd}.ad-card-header{padding:16px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.ad-campaign-name{margin:0;font-size:16px;font-weight:600;color:#333;word-break:break-word;flex:1}.ad-badge{display:inline-block;background-color:#f0f0f0;color:#666;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap;flex-shrink:0}.ad-badge{background-color:#000;color:#fff}.ad-card-body{padding:16px;flex:1}.ad-field{margin-bottom:12px}.ad-field:last-child{margin-bottom:0}.ad-field label{display:block;font-size:12px;font-weight:600;color:#999;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.ad-field-value{margin:0;font-size:14px;color:#333;line-height:1.5}.ad-text-preview{margin:0;font-size:14px;color:#555;line-height:1.5;background-color:#f9f9f9;padding:8px 12px;border-radius:4px;border-left:2px solid #ddd}.ad-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.music-id{font-family:Courier New,monospace;font-size:12px;background-color:#f5f5f5;padding:6px 8px;border-radius:3px;word-break:break-all}.ad-field-meta{margin-top:8px;padding-top:8px;border-top:1px solid #f0f0f0;color:#999}.ad-field-meta small{font-size:12px}.ad-card-footer{padding:12px 16px;border-top:1px solid #f0f0f0;display:flex;gap:8px;background-color:#fafafa}.btn-view,.btn-delete{flex:1;padding:10px;font-size:13px;font-weight:500;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s;background-color:#fff}.btn-view{color:#1976d2;border-color:#1976d2}.btn-view:hover{background-color:#e3f2fd}.btn-delete{color:#d32f2f;border-color:#d32f2f}.btn-delete:hover{background-color:#ffebee}.btn-view:active,.btn-delete:active{transform:scale(.98)}@media (max-width: 600px){.ad-card-header{flex-direction:column;align-items:flex-start}.ad-badge{align-self:flex-start}.ad-field-row{grid-template-columns:1fr}.ad-card-footer{flex-direction:row}}.ad-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ad-preview-modal{background-color:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.ad-preview-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.ad-preview-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.btn-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:4px}.btn-close:hover{background-color:#f5f5f5;color:#333}.ad-preview-body{overflow-y:auto;padding:24px;flex:1}.preview-section{margin-bottom:24px}.preview-section:last-child{margin-bottom:0}.preview-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.preview-field{display:flex;flex-direction:column}.preview-field label{display:block;font-size:12px;font-weight:600;color:#999;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.preview-value{margin:0;font-size:15px;color:#333;line-height:1.6;word-break:break-word}.preview-ad-text{background-color:#f9f9f9;padding:12px 16px;border-radius:6px;border-left:3px solid #000;font-size:14px}.preview-music-id{font-family:Courier New,monospace;font-size:13px;background-color:#f5f5f5;padding:8px 10px;border-radius:4px;word-break:break-all}.preview-timestamp{font-size:13px;color:#999;font-style:italic}.objective-badge{display:inline-block;background-color:#000;color:#fff;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:500;width:fit-content}.ad-preview-footer{padding:16px 24px;border-top:1px solid #e0e0e0;background-color:#fafafa;display:flex;gap:12px;justify-content:flex-end}.btn-close-modal{padding:10px 24px;font-size:14px;font-weight:500;background-color:#fff;color:#333;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .2s}.btn-close-modal:hover{background-color:#f5f5f5;border-color:#999}.btn-close-modal:active{transform:scale(.98)}@media (max-width: 600px){.ad-preview-overlay{padding:8px}.ad-preview-modal{border-radius:8px;max-height:90vh}.ad-preview-body{padding:16px}.preview-row{grid-template-columns:1fr;gap:16px}.preview-section{margin-bottom:16px}.ad-preview-header{padding:16px}.ad-preview-footer{padding:12px 16px}}.create-ad-container{max-width:600px;margin:0 auto;padding:20px;min-height:100vh;background-color:#f5f5f5}.create-ad-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.header-left h1{font-size:24px;margin-bottom:8px;color:#333}.user-info{font-size:13px;color:#666;margin:0}.btn-logout{background-color:#f5f5f5;color:#333;border:1px solid #ddd;padding:8px 12px;font-size:13px;flex-shrink:0}.btn-logout:hover{background-color:#efefef}.create-ad-form{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.form-section{margin-bottom:20px}.form-section-title{display:block;font-weight:600;font-size:14px;color:#333;margin-bottom:12px}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;gap:8px;position:relative}.radio-option input[type=radio]{margin:0;cursor:pointer;width:16px;height:16px}.radio-option label{margin:0;cursor:pointer;font-weight:500;font-size:14px;flex:1}.music-note{font-size:12px;color:#999;display:block;margin-left:24px;margin-top:4px}.radio-details{margin-left:24px;padding:12px;background-color:#fafafa;border-radius:4px;border-left:2px solid #e0e0e0}.btn-upload{background-color:#e3f2fd;color:#1976d2;border:1px solid #1976d2;width:100%;padding:12px;font-weight:500}.btn-upload:hover:not(:disabled){background-color:#bbdefb}.upload-success{background-color:#e8f5e9;color:#388e3c;padding:12px;border-radius:4px;font-size:13px;font-weight:500}.btn-submit{width:100%;padding:12px;background-color:#000;color:#fff;font-weight:600;font-size:15px;margin-top:8px}.btn-submit:hover:not(:disabled){background-color:#333}.btn-submit:disabled{background-color:#ccc;cursor:not-allowed}.success-banner{background-color:#e8f5e9;border-left:4px solid #388e3c;padding:12px 16px;margin-bottom:16px;border-radius:4px;color:#388e3c;font-weight:500;font-size:14px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.info-box{background:#fff;padding:16px;border-radius:8px;border-left:4px solid #1976d2;box-shadow:0 1px 3px #0000001a}.info-box h3{font-size:14px;margin-bottom:12px;color:#333}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{font-size:13px;color:#666;margin-bottom:8px;line-height:1.5}.info-box li:last-child{margin-bottom:0}.info-box strong{color:#333}.created-ads-section{margin-top:32px;background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.created-ads-section h2{margin:0 0 20px;font-size:20px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.ads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}@media (max-width: 768px){.ads-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}}@media (max-width: 480px){.ads-grid{grid-template-columns:1fr}.created-ads-section{padding:16px;margin-top:24px}.created-ads-section h2{margin-bottom:16px;font-size:18px}}body{margin:0;padding:0}#root{display:flex;flex-direction:column;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{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;background-color:#f5f5f5;color:#333}html,body,#root{width:100%;height:100%}button{font-family:inherit;cursor:pointer;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s}button:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{font-family:inherit;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #0000001a}label{display:block;margin-bottom:4px;font-weight:500;font-size:14px}.container{max-width:800px;margin:0 auto;padding:20px}.error-message{color:#d32f2f;font-size:13px;margin-top:4px}.success-message{color:#388e3c;font-size:13px;margin-top:4px}.info-message{color:#1976d2;font-size:13px;margin-top:4px}
