*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f5f5f5;color:#1a1a1a;min-height:100vh;}
.page{max-width:680px;margin:0 auto;padding:1.5rem 1rem;}
.card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;padding:1rem 1.25rem;margin-bottom:12px;}
.section-title{font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:10px;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;text-decoration:none;transition:opacity 0.15s;}
.btn:hover{opacity:0.88;}
.btn-primary{background:#185FA5;color:#fff;}
.btn-outline{background:#fff;color:#1a1a1a;border:1px solid #ccc;}
.btn-danger{background:#A32D2D;color:#fff;}
.btn-block{width:100%;justify-content:center;}
.btn:disabled{opacity:0.45;cursor:not-allowed;}
input,textarea,select{width:100%;padding:10px 14px;border-radius:8px;border:1px solid #ccc;font-size:14px;color:#1a1a1a;background:#fff;font-family:inherit;}
input:focus,textarea:focus{outline:none;border-color:#185FA5;box-shadow:0 0 0 3px rgba(24,95,165,0.1);}
textarea{resize:vertical;min-height:80px;}
label{font-size:12px;color:#555;margin-bottom:5px;display:block;font-weight:500;}
.form-group{margin-bottom:14px;}
.tag{display:inline-block;font-size:11px;font-weight:500;padding:3px 10px;border-radius:99px;}
.tag-blue{background:#E6F1FB;color:#0C447C;}
.tag-green{background:#EAF3DE;color:#3B6D11;}
.tag-amber{background:#FAEEDA;color:#854F0B;}
.tag-red{background:#FCEBEB;color:#A32D2D;}
.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px;}
.metric-box{background:#f5f5f5;border-radius:10px;padding:12px;}
.metric-label{font-size:11px;color:#666;margin-bottom:4px;}
.metric-value{font-size:20px;font-weight:700;color:#1a1a1a;}
.metric-sub{font-size:11px;color:#3B6D11;margin-top:2px;}
.bar-wrap{height:6px;background:#eee;border-radius:99px;overflow:hidden;margin-top:5px;}
.bar-fill{height:100%;border-radius:99px;transition:width 0.4s;}
.goals-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;}
.photo-wrap{position:relative;border-radius:10px;overflow:hidden;}
.photo-img{aspect-ratio:3/4;width:100%;object-fit:cover;display:block;background:#eee;}
.photo-month{position:absolute;top:5px;left:5px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;background:rgba(0,0,0,0.55);color:#fff;}
.photo-type-tag{position:absolute;bottom:5px;left:5px;font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:0.5px;}
.photo-like-btn{position:absolute;bottom:5px;right:5px;display:flex;align-items:center;gap:3px;background:rgba(0,0,0,0.55);border-radius:99px;padding:3px 8px;border:none;cursor:pointer;}
.photo-like-btn span{font-size:11px;font-weight:600;color:#fff;}
.delete-photo-btn{position:absolute;top:5px;right:5px;background:rgba(163,45,45,0.85);border:none;border-radius:99px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.add-photo-btn{aspect-ratio:3/4;border:2px dashed #ddd;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;background:transparent;width:100%;color:#888;font-size:11px;font-family:inherit;transition:border-color 0.2s;}
.add-photo-btn:hover{border-color:#185FA5;color:#185FA5;}
.likes-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;background:#f5f5f5;border-radius:12px;margin-bottom:12px;}
.likes-total{font-size:22px;font-weight:700;color:#1a1a1a;}
.likes-label{font-size:13px;color:#666;}
.badge-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 12px;border-radius:10px;border:1px solid #97C459;background:#EAF3DE;}
.badge-icon{font-size:18px;}
.badge-name{font-size:10px;color:#3B6D11;text-align:center;font-weight:500;}
.badges-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.ig-bar{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff;border:1px solid #e5e5e5;border-radius:12px;margin-bottom:12px;}
.ig-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ig-info{flex:1;}
.ig-name{font-size:14px;font-weight:500;color:#1a1a1a;}
.ig-sub{font-size:12px;color:#666;}
.share-bar{display:flex;gap:8px;padding-top:12px;border-top:1px solid #e5e5e5;}
.share-bar .btn{flex:1;}
.dash-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.avatar{width:56px;height:56px;border-radius:50%;background:#378ADD;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#E6F1FB;flex-shrink:0;overflow:hidden;cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 2px #185FA5;}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.header-info h2{font-size:17px;font-weight:700;}
.header-info p{font-size:12px;color:#666;margin-top:2px;}
.header-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
.views-pill{display:flex;align-items:center;gap:5px;background:#f0f0f0;border-radius:99px;padding:5px 12px;border:1px solid #ddd;font-size:12px;}
.views-count{font-weight:700;}
.header-actions{display:flex;gap:6px;}
.dropdown-wrap{position:relative;}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid #ddd;border-radius:12px;min-width:190px;z-index:100;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,0.12);}
.dropdown-menu.open{display:block;}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:#1a1a1a;cursor:pointer;border:none;background:none;width:100%;text-align:left;}
.dropdown-item:hover{background:#f5f5f5;}
.dropdown-item.danger{color:#A32D2D;}
.dropdown-divider{height:1px;background:#eee;}
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;align-items:center;justify-content:center;}
.modal-backdrop.open{display:flex;}
.modal-box{background:#fff;border-radius:16px;padding:1.25rem;width:92%;max-width:400px;max-height:92vh;overflow-y:auto;}
.modal-title{font-size:16px;font-weight:700;margin-bottom:4px;}
.modal-sub{font-size:13px;color:#666;margin-bottom:14px;}
.modal-actions{display:flex;gap:8px;margin-top:14px;}
.report-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:1px solid #e5e5e5;cursor:pointer;background:none;text-align:left;width:100%;margin-bottom:6px;font-size:13px;font-family:inherit;}
.report-option.selected{border-color:#E24B4A;background:#FCEBEB;}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1a1a1a;color:#fff;font-size:13px;padding:10px 20px;border-radius:99px;z-index:999;opacity:0;transition:opacity 0.3s;pointer-events:none;white-space:nowrap;font-weight:500;}
.toast.show{opacity:1;}
.nav-bar{background:#fff;border-bottom:1px solid #e5e5e5;padding:12px 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);}
.nav-brand{font-size:18px;font-weight:800;color:#185FA5;letter-spacing:1px;text-decoration:none;}
.nav-links{display:flex;gap:8px;}
.story-advice{margin-top:10px;padding:10px 14px;background:#f5f5f5;border-radius:0 8px 8px 0;border-left:3px solid #185FA5;}
.advice-label{font-size:11px;font-weight:600;color:#185FA5;margin-bottom:4px;}
.advice-text{font-size:13px;color:#555;line-height:1.6;font-style:italic;}
.loading{text-align:center;padding:3rem 1rem;color:#666;font-size:14px;}
.spinner{width:32px;height:32px;border:3px solid #eee;border-top-color:#185FA5;border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 12px;}
@keyframes spin{to{transform:rotate(360deg);}}
input[type="date"]{font-family:inherit;}
.upload-zone{border:2px dashed #ccc;border-radius:10px;padding:20px;text-align:center;cursor:pointer;transition:all 0.2s;background:#fafafa;}
.upload-zone:hover,.upload-zone.dragover{border-color:#185FA5;background:#E6F1FB;}
.upload-zone input{display:none;}
.upload-preview{width:80px;height:80px;border-radius:8px;object-fit:cover;margin:0 auto 8px;display:block;}
.upload-progress{height:6px;background:#eee;border-radius:99px;overflow:hidden;margin-top:8px;}
.upload-progress-fill{height:100%;background:#185FA5;border-radius:99px;transition:width 0.3s;}

/* Level / XP card */
.level-card{background:linear-gradient(135deg,#0f2942,#185FA5);border-radius:14px;padding:1.25rem;margin-bottom:12px;color:#fff;position:relative;overflow:hidden;}
.level-card-title{font-size:11px;font-weight:600;color:rgba(255,255,255,0.6);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;}
.level-name{font-size:20px;font-weight:800;margin-bottom:2px;}
.level-num{font-size:13px;color:rgba(255,255,255,0.7);margin-bottom:14px;}
.xp-bar-bg{height:8px;background:rgba(255,255,255,0.2);border-radius:99px;overflow:hidden;margin-bottom:6px;}
.xp-bar-fill{height:100%;background:linear-gradient(90deg,#4fc3f7,#29b6f6);border-radius:99px;transition:width 0.6s;}
.xp-label{font-size:11px;color:rgba(255,255,255,0.65);}
.personality-pill{position:absolute;top:14px;right:14px;background:rgba(255,255,255,0.15);border-radius:99px;padding:4px 10px;font-size:11px;color:#fff;font-weight:500;}

/* Status bar */
.status-bar{display:flex;gap:8px;margin-bottom:12px;}
.status-btn{flex:1;padding:10px 6px;border-radius:10px;border:2px solid #e5e5e5;background:#fff;font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:all 0.15s;}
.status-btn.active-skip{border-color:#ccc;background:#f5f5f5;color:#666;}
.status-btn.active-done{border-color:#3B6D11;background:#EAF3DE;color:#27500A;}
.status-btn.active-crush{border-color:#BA7517;background:#FAEEDA;color:#633806;}

/* Goal cards */
.goal-card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;padding:12px;margin-bottom:8px;}
.goal-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.goal-emoji-big{font-size:24px;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;flex-shrink:0;}
.goal-meta{flex:1;min-width:0;}
.goal-card-name{font-size:14px;font-weight:700;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.goal-card-deadline{font-size:11px;font-weight:500;margin-top:2px;}
.goal-card-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.goal-card-pct{font-size:18px;font-weight:800;}
.goal-card-values{font-size:11px;color:#666;}
.update-goal-btn{font-size:11px;color:#185FA5;background:#E6F1FB;border:none;border-radius:6px;padding:4px 10px;cursor:pointer;font-weight:500;}

/* Rep Card */
.rep-card{background:linear-gradient(135deg,#0a1628,#185FA5,#0a2040);border-radius:16px;padding:1.5rem;color:#fff;text-align:center;position:relative;overflow:hidden;}
.rep-card-avatar{width:72px;height:72px;border-radius:50%;border:3px solid rgba(255,255,255,0.3);overflow:hidden;margin:0 auto 12px;background:#378ADD;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;}
.rep-card-name{font-size:20px;font-weight:800;margin-bottom:4px;}
.rep-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0;}
.rep-card-stat{background:rgba(255,255,255,0.1);border-radius:10px;padding:8px 4px;}
.rep-card-stat-val{font-size:16px;font-weight:800;}
.rep-card-stat-label{font-size:9px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px;}
.rep-card-brand{font-size:11px;color:rgba(255,255,255,0.4);margin-top:10px;letter-spacing:2px;}

/* Login page */
.login-bg{min-height:100vh;background:linear-gradient(135deg,#e8f0fb 0%,#f0f4fb 50%,#dbe8f8 100%);display:flex;align-items:center;justify-content:center;padding:1rem;}
.login-outer{background:linear-gradient(145deg,#1e4a8a,#185FA5,#1a5c9e);border-radius:20px;padding:2rem;width:100%;max-width:460px;box-shadow:0 20px 60px rgba(24,95,165,0.3);}
.login-brand{text-align:center;margin-bottom:1.5rem;}
.login-brand h1{font-size:32px;font-weight:900;color:#fff;letter-spacing:2px;}
.login-brand p{font-size:13px;color:rgba(255,255,255,0.6);margin-top:4px;}
.login-inner{background:#fff;border-radius:14px;padding:1.5rem;}
.login-title{font-size:22px;font-weight:800;color:#1a1a1a;margin-bottom:4px;}
.login-sub{font-size:13px;color:#666;margin-bottom:1.25rem;}
.login-field{margin-bottom:14px;}
.login-field label{font-size:12px;font-weight:600;color:#444;margin-bottom:6px;display:block;}
.login-field input{width:100%;padding:12px 14px;border-radius:10px;border:1.5px solid #e0e0e0;font-size:14px;color:#1a1a1a;background:#fafafa;font-family:inherit;transition:border-color 0.2s;}
.login-field input:focus{outline:none;border-color:#185FA5;background:#fff;}
.login-field-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.forgot-link{font-size:12px;color:#185FA5;text-decoration:none;font-weight:500;}
.login-btn{width:100%;padding:13px;background:#185FA5;color:#fff;font-size:15px;font-weight:700;border:none;border-radius:10px;cursor:pointer;margin-top:4px;letter-spacing:0.3px;}
.login-btn:hover{background:#144f8a;}
.login-footer{text-align:center;font-size:13px;color:#666;margin-top:14px;}
.login-footer a{color:#185FA5;font-weight:600;text-decoration:none;}
.login-helper{background:#EBF3FD;border-radius:10px;padding:12px 14px;margin-top:14px;display:flex;align-items:flex-start;gap:10px;border:1px solid #B5D4F4;}
.login-helper-text{font-size:12px;color:#0C447C;line-height:1.5;}
.login-helper-text strong{font-weight:700;}
.login-trouble{text-align:center;font-size:13px;color:rgba(255,255,255,0.7);margin-top:14px;}
.login-trouble a{color:#fff;font-weight:600;}
@media(max-width:500px){.metrics-grid{grid-template-columns:1fr 1fr;}}
