:root{--portal-bg: #faf9f7;--portal-sidebar-bg: #f0eeeb;--portal-accent: #d4a84b;--portal-accent-hover: #b8923f;--portal-card-radius: 12px;--portal-shadow: 0 2px 8px rgba(0, 0, 0, .06)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;background-color:var(--portal-bg)}#app{min-height:100vh}.portal-layout{display:flex;flex-direction:column;min-height:100vh}.portal-topbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;width:100%;padding:1rem 1.5rem;background:var(--portal-sidebar-bg);border-bottom:1px solid rgba(0,0,0,.08)}.portal-topbar-left{display:flex;align-items:center;gap:1.5rem;flex:1;min-width:0}.portal-topbar-brand{font-size:1.25rem;font-weight:600;color:#333;flex-shrink:0}.portal-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none}.portal-tab{padding:.5rem .75rem;border:none;background:transparent;color:#444;font-size:.95rem;font-family:inherit;cursor:pointer;border-radius:6px;border-bottom:2px solid transparent;transition:background-color .2s,color .2s,border-color .2s}.portal-tab:hover{background:#0000000f;color:#222}.portal-tab.active{color:#1a1a1a;font-weight:500;border-bottom-color:var(--portal-accent)}.portal-topbar-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.portal-topbar-actions .portal-user-email{margin:0;font-size:.8rem;color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.portal-main{flex:1;overflow:auto;background:var(--portal-bg);padding:1.5rem 2rem}.portal-main-inner{max-width:1200px;margin:0 auto}.portal-section{display:none}.portal-section.active{display:block}.portal-account-section{margin-top:0;padding-top:0;border-top:none}header:not(.portal-topbar){margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #ddd}header:not(.portal-topbar) h1{margin-bottom:.5rem;color:#333}#message-container{display:none;margin-bottom:1rem;padding:1rem;border-radius:4px;border:1px solid}.form-section{background:#fff;padding:1.5rem;margin-bottom:1.5rem;border-radius:var(--portal-card-radius);box-shadow:var(--portal-shadow)}.form-section h3{margin-bottom:1rem;color:var(--portal-accent);border-bottom:2px solid var(--portal-accent);padding-bottom:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-group label:after{content:""}.template-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:0}.template-picker-card{display:flex;flex-direction:column;align-items:center;padding:.5rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.template-picker-card:hover{border-color:var(--portal-accent);box-shadow:0 2px 8px #d4a84b33}.template-picker-card.template-card-selected{border-color:var(--portal-accent);box-shadow:0 0 0 3px #d4a84b4d}.template-picker-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px;background:#f0f0f0;min-height:100px}.template-picker-name{margin-top:.5rem;font-size:.9rem;font-weight:500;color:#333}input[type=text],input[type=email],input[type=tel],textarea,select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}input[type=text]:focus,input[type=email]:focus,input[type=tel]:focus,textarea:focus,select:focus{outline:none;border-color:var(--portal-accent);box-shadow:0 0 0 3px #d4a84b33}textarea{resize:vertical;min-height:80px}button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-family:inherit;cursor:pointer;transition:background-color .2s,transform .1s}button:hover:not(:disabled){transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--portal-accent);color:#1a1a1a}.btn-primary:hover:not(:disabled){background-color:var(--portal-accent-hover)}.btn-secondary{background-color:#6c757d;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-remove{background-color:#dc3545;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-remove:hover:not(:disabled){background-color:#c82333}.pic-file-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.btn-pic-choose{padding:.35rem .75rem;font-size:.875rem;border:1px solid #ccc;background:#fff;color:#333;border-radius:4px;cursor:pointer;font-family:inherit}.btn-pic-choose:hover:not(:disabled){background:#f5f5f5;border-color:#999}.array-item{margin-bottom:.5rem}.array-item input,.array-item textarea{margin-bottom:0}#login-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}#email-form,#otp-form{margin-top:1rem}#email-error,#otp-error{margin-top:1rem;padding:.75rem;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px}#update-form-container{background:#fff;padding:2rem;border-radius:var(--portal-card-radius);box-shadow:var(--portal-shadow)}#delete-account-btn{margin-top:.5rem}@media(max-width:768px){.portal-topbar{padding:.75rem 1rem;gap:.75rem}.portal-topbar-left{flex-wrap:wrap}.portal-tabs{overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2px}.portal-tab{flex-shrink:0;white-space:nowrap}.portal-topbar-actions .portal-user-email{max-width:120px}.portal-main{padding:1rem}.portal-main-inner{max-width:none}body{font-size:.9rem}.form-section{padding:1rem}.form-section h3{font-size:1.1rem}input[type=text],input[type=email],input[type=tel],textarea,select{font-size:.9rem;padding:.6rem}button{padding:.6rem 1.2rem;font-size:.9rem}.array-item>div{grid-template-columns:1fr!important}.array-item>div>button{width:100%}}@media(max-width:480px){.portal-main{padding:3rem .75rem 1rem}.form-section{padding:.75rem}}.loading{opacity:.6;pointer-events:none}.message-success{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.message-error{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
