/* ============================================================
   Plant Growth Journal — Premium CSS
   PlantCare.dotiam.com  |  pj- prefix
   Deep Blue theme — #1e3a5f → #60a5fa
   ============================================================ */
@font-face { font-family: 'Inter'; font-display: swap; }

:root {
    --pj-blue:      #2563eb;
    --pj-blue-d:    #1e3a5f;
    --pj-blue-l:    #60a5fa;
    --pj-blue-ll:   #93c5fd;
    --pj-bg:        #eff6ff;
    --pj-border:    #bfdbfe;
    --pj-border-d:  #93c5fd;
    --pj-text:      #1f2937;
    --pj-muted:     #6b7280;
    --pj-surface:   #ffffff;
    --pj-card:      #f8fbff;
    /* Health colors */
    --pj-excellent: #7c3aed;
    --pj-good:      #16a34a;
    --pj-fair:      #d97706;
    --pj-poor:      #dc2626;
    --pj-critical:  #7f1d1d;
    --pj-radius:    12px;
    --pj-radius-lg: 18px;
    --pj-shadow:    0 2px 16px rgba(37,99,235,.10);
    --pj-shadow-lg: 0 8px 40px rgba(37,99,235,.16);
    --pj-font:      'Inter', -apple-system, sans-serif;
}
*, *::before, *::after { box-sizing: border-box; }

/* Breadcrumb */
.pi-breadcrumb { background:#fff; border-bottom:1px solid var(--pj-border); padding:10px 0; }
.pi-bc-inner   { max-width:1200px; margin:0 auto; padding:0 20px; display:flex; align-items:center; gap:8px; font-size:.8rem; font-family:var(--pj-font); }
.pi-bc-inner a { color:var(--pj-blue); font-weight:500; text-decoration:none; }
.pi-bc-sep     { color:var(--pj-muted); }

/* Hero */
.pj-hero { padding:52px 20px 60px; text-align:center; position:relative; overflow:hidden; }
.pj-hero::before { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); pointer-events:none; }
.pj-hero-inner  { position:relative; max-width:760px; margin:0 auto; }
.pj-hero-tag    { display:inline-block; background:rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.35); color:#fff; border-radius:30px; padding:5px 18px; font-size:.74rem; font-weight:700; letter-spacing:.5px; margin-bottom:16px; font-family:var(--pj-font); }
.pj-hero-h1     { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.2); line-height:1.15; margin:0 0 6px; font-family:var(--pj-font); }
.pj-hero-h1-hi  { display:block; font-size:clamp(.95rem,2.5vw,1.25rem); font-weight:600; opacity:.88; margin-top:6px; }
.pj-hero-sub    { font-size:clamp(.88rem,2vw,1rem); color:rgba(255,255,255,.92); margin:14px 0 4px; line-height:1.6; }
.pj-hero-sub-hi { font-size:.82rem; color:rgba(255,255,255,.78); margin:0 0 18px; }
.pj-hero-badges { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pj-hero-badges span { background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.3); color:#fff; border-radius:20px; padding:5px 14px; font-size:.75rem; font-weight:600; }

/* Tool Section */
.pj-tool-section { background:var(--pj-bg); padding:24px 0 48px; }
.pj-container    { max-width:1100px; margin:0 auto; padding:0 20px; }

/* Top Bar */
.pj-top-bar   { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:20px; flex-wrap:wrap; }
.pj-top-left  { display:flex; align-items:center; gap:12px; }
.pj-journal-count,.pj-entry-count { background:#fff; border:1.5px solid var(--pj-border); border-radius:20px; padding:5px 14px; font-size:.78rem; font-weight:700; color:var(--pj-blue-d); font-family:var(--pj-font); }
.pj-top-right { display:flex; gap:8px; flex-wrap:wrap; }

/* Buttons */
.pj-btn { display:flex; align-items:center; gap:6px; padding:8px 16px; border-radius:var(--pj-radius); border:1.5px solid; font-size:.8rem; font-weight:700; cursor:pointer; transition:all .2s; font-family:var(--pj-font); white-space:nowrap; }
.pj-btn-add    { background:linear-gradient(135deg,var(--pj-blue-d),var(--pj-blue)); color:#fff; border-color:transparent; box-shadow:0 3px 12px rgba(37,99,235,.35); }
.pj-btn-add:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(37,99,235,.5); }
.pj-btn-export { background:#fff; color:var(--pj-blue-d); border-color:var(--pj-border-d); }
.pj-btn-export:hover,.pj-btn-import:hover { border-color:var(--pj-blue); color:var(--pj-blue); }
.pj-btn-import { background:#fff; color:var(--pj-blue-d); border-color:var(--pj-border-d); }

/* Empty State */
.pj-empty { background:#fff; border:2px dashed var(--pj-border-d); border-radius:var(--pj-radius-lg); padding:48px 32px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:12px; }
.pj-empty-anim { position:relative; width:100px; height:100px; margin-bottom:8px; }
.pj-empty-ring { position:absolute; border-radius:50%; border:2px solid rgba(37,99,235,.18); animation:pjPulse 2.5s ease-out infinite; }
.pj-empty-ring.r1{inset:0;animation-delay:0s}
.pj-empty-ring.r2{inset:-12px;animation-delay:.7s}
.pj-empty-ring.r3{inset:-24px;animation-delay:1.4s}
@keyframes pjPulse{0%{opacity:.7;transform:scale(.85)}100%{opacity:0;transform:scale(1.3)}}
.pj-empty-center { position:absolute; inset:12px; background:linear-gradient(135deg,var(--pj-blue-d),var(--pj-blue)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:2.2rem; box-shadow:0 6px 20px rgba(37,99,235,.4); }
.pj-empty h2    { font-size:1.3rem; font-weight:800; color:var(--pj-blue-d); margin:0; font-family:var(--pj-font); }
.pj-empty h3    { font-size:1rem; font-weight:700; color:var(--pj-blue); margin:4px 0 0; }
.pj-empty p     { font-size:.86rem; color:var(--pj-muted); max-width:420px; line-height:1.6; margin:0; font-family:var(--pj-font); }
.pj-empty-hi    { font-size:.78rem!important; }
.pj-empty-btn   { background:linear-gradient(135deg,var(--pj-blue-d),var(--pj-blue)); color:#fff; border:none; border-radius:var(--pj-radius); padding:14px 28px; font-size:.92rem; font-weight:800; cursor:pointer; transition:all .2s; font-family:var(--pj-font); box-shadow:0 4px 18px rgba(37,99,235,.4); margin-top:4px; }
.pj-empty-btn:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(37,99,235,.55); }
.pj-empty-features { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:8px; }
.pj-ef-item     { display:flex; align-items:center; gap:5px; background:var(--pj-bg); border:1px solid var(--pj-border); border-radius:20px; padding:5px 12px; font-size:.72rem; font-weight:600; color:var(--pj-text); font-family:var(--pj-font); }

/* Plants Wrap */
.pj-plants-wrap { display:flex; flex-direction:column; gap:16px; }

/* Plant Tabs */
.pj-plant-tabs { display:flex; gap:8px; flex-wrap:wrap; overflow-x:auto; padding-bottom:4px; }
.pj-plant-tab  { display:flex; align-items:center; gap:7px; padding:8px 16px; background:#fff; border:2px solid var(--pj-border); border-radius:30px; cursor:pointer; transition:all .2s; font-family:var(--pj-font); font-size:.82rem; font-weight:600; color:var(--pj-muted); white-space:nowrap; flex-shrink:0; }
.pj-plant-tab:hover { border-color:var(--pj-border-d); color:var(--pj-text); }
.pj-plant-tab.active { border-color:var(--pj-blue); background:rgba(37,99,235,.08); color:var(--pj-blue-d); box-shadow:0 0 0 3px rgba(37,99,235,.1); }
.pj-plant-tab-emoji { font-size:1.1rem; }
.pj-plant-tab-count { font-size:.65rem; background:var(--pj-bg); border-radius:10px; padding:1px 6px; }
.pj-tab-add-btn { display:flex; align-items:center; gap:5px; padding:8px 14px; background:transparent; border:2px dashed var(--pj-border-d); border-radius:30px; cursor:pointer; font-family:var(--pj-font); font-size:.82rem; font-weight:600; color:var(--pj-blue); transition:all .2s; white-space:nowrap; }
.pj-tab-add-btn:hover { border-color:var(--pj-blue); background:rgba(37,99,235,.05); }

/* Plant View */
.pj-plant-view { background:#fff; border:1px solid var(--pj-border); border-radius:var(--pj-radius-lg); overflow:hidden; box-shadow:var(--pj-shadow); }

/* Plant Header */
.pj-plant-header { padding:18px 20px 14px; border-bottom:1px solid var(--pj-border); background:linear-gradient(135deg,rgba(30,58,95,.05),rgba(96,165,250,.02)); display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.pj-ph-emoji     { font-size:3rem; flex-shrink:0; }
.pj-ph-info      { flex:1; min-width:0; }
.pj-ph-name      { font-size:1.4rem; font-weight:900; color:var(--pj-text); font-family:var(--pj-font); }
.pj-ph-name-hi   { font-size:.85rem; color:var(--pj-muted); }
.pj-ph-meta      { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.pj-ph-tag       { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:20px; font-size:.7rem; font-weight:700; background:rgba(37,99,235,.08); color:var(--pj-blue-d); border:1px solid rgba(37,99,235,.2); font-family:var(--pj-font); }
.pj-ph-actions   { display:flex; gap:8px; flex-shrink:0; }
.pj-ph-action    { background:none; border:1.5px solid var(--pj-border-d); border-radius:var(--pj-radius); padding:7px 12px; font-size:.75rem; font-weight:600; cursor:pointer; transition:all .2s; font-family:var(--pj-font); color:var(--pj-muted); }
.pj-ph-action:hover { border-color:var(--pj-blue); color:var(--pj-blue-d); }
.pj-ph-action.danger:hover { border-color:#dc2626; color:#991b1b; }

/* Stats Row */
.pj-stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; padding:14px 20px; border-bottom:1px solid var(--pj-border); background:var(--pj-bg); }
@media(max-width:600px){ .pj-stats-row{grid-template-columns:repeat(2,1fr);} }
.pj-stat-card   { background:#fff; border:1.5px solid var(--pj-border); border-radius:var(--pj-radius); padding:12px; text-align:center; }
.pj-stat-icon   { font-size:1.5rem; display:block; margin-bottom:4px; }
.pj-stat-label  { font-size:.6rem; font-weight:800; color:var(--pj-blue); text-transform:uppercase; letter-spacing:.6px; font-family:var(--pj-font); }
.pj-stat-val    { font-size:1rem; font-weight:900; color:var(--pj-blue-d); font-family:var(--pj-font); line-height:1.2; margin-top:2px; }

/* Add Entry Bar */
.pj-add-entry-bar { display:flex; gap:8px; padding:14px 20px; border-bottom:1px solid var(--pj-border); }
.pj-add-entry-btn { flex:1; display:flex; align-items:center; justify-content:center; gap:8px; padding:12px; background:linear-gradient(135deg,var(--pj-blue-d),var(--pj-blue)); color:#fff; border:none; border-radius:var(--pj-radius); font-size:.88rem; font-weight:800; cursor:pointer; transition:all .2s; font-family:var(--pj-font); box-shadow:0 3px 12px rgba(37,99,235,.3); }
.pj-add-entry-btn:hover { transform:translateY(-1px); box-shadow:0 5px 18px rgba(37,99,235,.45); }
.pj-view-toggle { display:flex; align-items:center; gap:6px; padding:12px 16px; background:#fff; border:1.5px solid var(--pj-border-d); border-radius:var(--pj-radius); font-size:.8rem; font-weight:700; cursor:pointer; transition:all .2s; font-family:var(--pj-font); color:var(--pj-blue-d); white-space:nowrap; }
.pj-view-toggle:hover { border-color:var(--pj-blue); }

/* ── TIMELINE VIEW ── */
.pj-timeline { padding:20px; display:flex; flex-direction:column; gap:0; }
.pj-tl-item  { display:flex; gap:16px; position:relative; }
.pj-tl-item:not(:last-child)::before { content:''; position:absolute; left:19px; top:38px; bottom:-4px; width:2px; background:var(--pj-border); }
.pj-tl-dot   { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; border:2.5px solid #fff; box-shadow:0 2px 8px rgba(37,99,235,.25); z-index:1; margin-top:4px; }
.pj-tl-dot.excellent { background:linear-gradient(135deg,#5b21b6,#8b5cf6); }
.pj-tl-dot.good      { background:linear-gradient(135deg,#15803d,#4ade80); }
.pj-tl-dot.fair      { background:linear-gradient(135deg,#92400e,#fbbf24); }
.pj-tl-dot.poor      { background:linear-gradient(135deg,#991b1b,#f87171); }
.pj-tl-dot.critical  { background:linear-gradient(135deg,#7f1d1d,#dc2626); animation:pjBlink 1.5s ease-in-out infinite; }
@keyframes pjBlink{0%,100%{opacity:1}50%{opacity:.5}}
.pj-tl-card  { flex:1; background:#fff; border:1.5px solid var(--pj-border); border-radius:var(--pj-radius); padding:14px; margin-bottom:14px; cursor:pointer; transition:all .2s; }
.pj-tl-card:hover { border-color:var(--pj-border-d); box-shadow:var(--pj-shadow); transform:translateY(-1px); }
.pj-tl-date  { font-size:.72rem; font-weight:800; color:var(--pj-blue); text-transform:uppercase; letter-spacing:.6px; margin-bottom:6px; font-family:var(--pj-font); }
.pj-tl-top   { display:flex; align-items:flex-start; gap:10px; flex-wrap:wrap; margin-bottom:8px; }
.pj-tl-health{ display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:20px; font-size:.7rem; font-weight:700; font-family:var(--pj-font); }
.pj-tl-ms    { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:20px; font-size:.7rem; font-weight:700; background:rgba(37,99,235,.08); color:var(--pj-blue-d); border:1px solid rgba(37,99,235,.2); font-family:var(--pj-font); }
.pj-tl-height{ font-size:.7rem; font-weight:700; color:var(--pj-muted); font-family:var(--pj-font); }
.pj-tl-photo { width:100%; max-height:200px; object-fit:cover; border-radius:8px; margin-bottom:8px; display:block; }
.pj-tl-notes { font-size:.84rem; color:#374151; line-height:1.6; font-family:var(--pj-font); }
.pj-tl-notes.truncated { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ── GRID VIEW ── */
.pj-grid-view { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; padding:20px; }
.pj-grid-card { background:#fff; border:1.5px solid var(--pj-border); border-radius:var(--pj-radius); overflow:hidden; cursor:pointer; transition:all .2s; }
.pj-grid-card:hover { border-color:var(--pj-border-d); box-shadow:var(--pj-shadow); transform:translateY(-2px); }
.pj-gc-photo { width:100%; height:140px; object-fit:cover; display:block; }
.pj-gc-no-photo { width:100%; height:140px; background:linear-gradient(135deg,var(--pj-bg),var(--pj-border)); display:flex; align-items:center; justify-content:center; font-size:3rem; }
.pj-gc-body  { padding:12px; }
.pj-gc-date  { font-size:.68rem; font-weight:800; color:var(--pj-blue); text-transform:uppercase; letter-spacing:.6px; margin-bottom:5px; font-family:var(--pj-font); }
.pj-gc-health{ display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:20px; font-size:.65rem; font-weight:700; margin-bottom:6px; font-family:var(--pj-font); }
.pj-gc-notes { font-size:.78rem; color:#374151; line-height:1.5; font-family:var(--pj-font); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* Health badge colors */
.pj-h-excellent { background:rgba(124,58,237,.1); color:#5b21b6; border:1px solid rgba(124,58,237,.25); }
.pj-h-good      { background:rgba(22,163,74,.1);  color:#065f46; border:1px solid rgba(22,163,74,.25); }
.pj-h-fair      { background:rgba(217,119,6,.1);  color:#92400e; border:1px solid rgba(217,119,6,.25); }
.pj-h-poor      { background:rgba(220,38,38,.1);  color:#991b1b; border:1px solid rgba(220,38,38,.25); }
.pj-h-critical  { background:rgba(127,29,19,.12); color:#7f1d1d; border:1px solid rgba(127,29,19,.3); animation:pjBlink 1.5s ease-in-out infinite; }

/* No entries */
.pj-no-entries { padding:32px; text-align:center; color:var(--pj-muted); font-family:var(--pj-font); }
.pj-no-entries-icon { font-size:2.5rem; display:block; margin-bottom:8px; opacity:.4; }

/* ── MODALS ── */
.pj-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:1000; display:flex; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(4px); animation:pjFadeIn .2s ease; }
@keyframes pjFadeIn{from{opacity:0}to{opacity:1}}
.pj-modal { background:#fff; border-radius:var(--pj-radius-lg); width:100%; max-width:500px; max-height:90vh; display:flex; flex-direction:column; box-shadow:0 20px 60px rgba(0,0,0,.3); animation:pjSlideUp .25s ease; overflow:hidden; }
.pj-modal-lg { max-width:620px; }
@keyframes pjSlideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.pj-modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px 14px; border-bottom:1px solid var(--pj-border); background:linear-gradient(135deg,rgba(30,58,95,.05),rgba(96,165,250,.02)); flex-shrink:0; }
.pj-modal-title  { font-size:1rem; font-weight:800; color:var(--pj-blue-d); font-family:var(--pj-font); }
.pj-modal-close  { background:none; border:none; font-size:1.1rem; cursor:pointer; color:var(--pj-muted); padding:4px 8px; border-radius:6px; transition:all .2s; }
.pj-modal-close:hover { background:rgba(220,38,38,.08); color:#dc2626; }
.pj-modal-body   { padding:18px 20px; overflow-y:auto; flex:1; display:flex; flex-direction:column; gap:14px; }
.pj-modal-footer { padding:14px 20px; border-top:1px solid var(--pj-border); display:flex; gap:8px; justify-content:flex-end; flex-shrink:0; }
.pj-mfooter-cancel { background:#fff; color:var(--pj-muted); border:1.5px solid var(--pj-border-d); border-radius:var(--pj-radius); padding:10px 18px; font-size:.84rem; font-weight:600; cursor:pointer; font-family:var(--pj-font); transition:all .2s; }
.pj-mfooter-cancel:hover { border-color:var(--pj-muted); color:var(--pj-text); }
.pj-mfooter-save   { background:linear-gradient(135deg,var(--pj-blue-d),var(--pj-blue)); color:#fff; border:none; border-radius:var(--pj-radius); padding:10px 22px; font-size:.84rem; font-weight:800; cursor:pointer; font-family:var(--pj-font); transition:all .2s; box-shadow:0 3px 12px rgba(37,99,235,.35); }
.pj-mfooter-save:hover { transform:translateY(-1px); box-shadow:0 5px 18px rgba(37,99,235,.5); }
.pj-mfooter-danger { background:#fff; color:#dc2626; border:1.5px solid #fca5a5; border-radius:var(--pj-radius); padding:10px 16px; font-size:.82rem; font-weight:700; cursor:pointer; font-family:var(--pj-font); transition:all .2s; margin-right:auto; }
.pj-mfooter-danger:hover { background:rgba(220,38,38,.08); border-color:#dc2626; }

/* Modal form fields */
.pj-mfield   { display:flex; flex-direction:column; gap:6px; }
.pj-mlabel   { font-size:.8rem; font-weight:700; color:var(--pj-text); font-family:var(--pj-font); display:flex; align-items:center; gap:5px; }
.pj-req { color:#dc2626; font-size:.75rem; }
.pj-opt { font-weight:400; color:var(--pj-muted); font-size:.7rem; }
.pj-minput   { width:100%; padding:10px 13px; border:1.5px solid var(--pj-border-d); border-radius:var(--pj-radius); font-size:.88rem; color:var(--pj-text); background:var(--pj-card); outline:none; font-family:var(--pj-font); transition:border-color .2s; }
.pj-minput:focus { border-color:var(--pj-blue); box-shadow:0 0 0 3px rgba(37,99,235,.1); }
.pj-mtextarea { width:100%; padding:10px 13px; border:1.5px solid var(--pj-border-d); border-radius:var(--pj-radius); font-size:.86rem; color:var(--pj-text); background:var(--pj-card); outline:none; font-family:var(--pj-font); transition:border-color .2s; resize:vertical; line-height:1.6; }
.pj-mtextarea:focus { border-color:var(--pj-blue); box-shadow:0 0 0 3px rgba(37,99,235,.1); }

/* Emoji grid */
.pj-emoji-grid { display:grid; grid-template-columns:repeat(10,1fr); gap:5px; }
.pj-emoji-btn  { padding:6px; border-radius:8px; border:2px solid transparent; background:var(--pj-bg); cursor:pointer; font-size:1.2rem; transition:all .15s; }
.pj-emoji-btn:hover { background:#fff; border-color:var(--pj-border-d); }
.pj-emoji-btn.active { border-color:var(--pj-blue); background:rgba(37,99,235,.08); }

/* Location buttons */
.pj-location-btns { display:flex; flex-wrap:wrap; gap:6px; }
.pj-loc-btn { padding:7px 14px; border-radius:20px; border:1.5px solid var(--pj-border); background:var(--pj-card); cursor:pointer; font-size:.76rem; font-weight:700; color:var(--pj-muted); transition:all .2s; font-family:var(--pj-font); }
.pj-loc-btn:hover { border-color:var(--pj-border-d); }
.pj-loc-btn.active { border-color:var(--pj-blue); background:rgba(37,99,235,.08); color:var(--pj-blue-d); }

/* Health buttons */
.pj-health-btns { display:flex; flex-wrap:wrap; gap:6px; }
.pj-health-btn  { padding:7px 12px; border-radius:20px; border:2px solid var(--pj-border); background:var(--pj-card); cursor:pointer; font-size:.76rem; font-weight:700; color:var(--pj-muted); transition:all .2s; font-family:var(--pj-font); }
.pj-health-btn.active[data-health="excellent"]{ border-color:#7c3aed; background:rgba(124,58,237,.08); color:#5b21b6; }
.pj-health-btn.active[data-health="good"]     { border-color:#16a34a; background:rgba(22,163,74,.08); color:#065f46; }
.pj-health-btn.active[data-health="fair"]     { border-color:#d97706; background:rgba(217,119,6,.08); color:#92400e; }
.pj-health-btn.active[data-health="poor"]     { border-color:#dc2626; background:rgba(220,38,38,.08); color:#991b1b; }
.pj-health-btn.active[data-health="critical"] { border-color:#7f1d1d; background:rgba(127,29,19,.08); color:#7f1d1d; }

/* Height row */
.pj-height-row  { display:flex; gap:8px; }
.pj-height-input{ flex:1; }
.pj-height-unit { width:90px; flex-shrink:0; }

/* Milestone chips */
.pj-milestone-chips { display:flex; flex-wrap:wrap; gap:5px; }
.pj-ms-chip { background:var(--pj-bg); border:1.5px solid var(--pj-border-d); border-radius:20px; padding:5px 12px; font-size:.72rem; font-weight:600; color:var(--pj-text); cursor:pointer; transition:all .2s; font-family:var(--pj-font); }
.pj-ms-chip:hover { border-color:var(--pj-blue); color:var(--pj-blue-d); background:#e0f2fe; }

/* Photo area */
.pj-photo-area  { border:2px dashed var(--pj-border-d); border-radius:var(--pj-radius); min-height:120px; cursor:pointer; display:flex; align-items:center; justify-content:center; overflow:hidden; transition:all .2s; position:relative; }
.pj-photo-area:hover { border-color:var(--pj-blue); background:rgba(37,99,235,.02); }
.pj-photo-empty { display:flex; flex-direction:column; align-items:center; gap:8px; padding:20px; }
.pj-photo-icon  { font-size:2rem; opacity:.4; }
.pj-photo-text  { font-size:.82rem; color:var(--pj-muted); font-family:var(--pj-font); }
.pj-photo-area img { width:100%; max-height:220px; object-fit:cover; display:block; }
.pj-photo-clear { background:none; border:none; color:#dc2626; cursor:pointer; font-size:.76rem; font-weight:600; padding:4px 0; font-family:var(--pj-font); }

/* SEO */
.pj-seo-section { background:#fff; padding:56px 0; border-top:1px solid var(--pj-border); content-visibility:auto; contain-intrinsic-size:0 600px; }
.pj-seo-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:768px){ .pj-seo-grid{grid-template-columns:1fr;} }
.pj-seo-card    { border-radius:var(--pj-radius); padding:24px; }
.pj-seo-card.en { background:var(--pj-bg); border:1px solid var(--pj-border); }
.pj-seo-card.hi { background:#fff8f1; border:1px solid #fed7aa; }
.pj-seo-card h2 { font-size:1.1rem; font-weight:800; color:var(--pj-blue-d); margin:0 0 10px; line-height:1.4; font-family:var(--pj-font); }
.pj-seo-card.hi h2 { color:#9a3412; }
.pj-seo-card p  { font-size:.875rem; color:#374151; line-height:1.8; margin:0; font-family:var(--pj-font); }
.pi-disclaimer  { background:#fffbeb; border:1px solid #fde68a; border-radius:var(--pj-radius); padding:14px 18px; font-size:.82rem; color:#92400e; line-height:1.6; margin:20px 0 28px; }

@media(max-width:480px){
    .pj-top-bar     { flex-direction:column; align-items:flex-start; }
    .pj-emoji-grid  { grid-template-columns:repeat(7,1fr); }
    .pj-seo-section { padding:36px 0; }
}