*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --green:#72C139;--green-light:#8DD452;--green-dark:#5A9C2C;
  --bg:#0C140A;--bg2:#141E0F;--bg3:#1E2E17;--card:#182213;
  --text:#F0F7EB;--muted:#7A9170;--border:#263820;
  --red:#E05252;--blue:#5AC8FA;--yellow:#F5C842;
}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display',sans-serif}

/* ===== SCREENS ===== */
.screen{position:absolute;inset:0;display:none;flex-direction:column;background:var(--bg);animation:fadeIn .25s ease}
.screen.active{display:flex}
@keyframes fadeIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* STATUS BAR SAFE AREA */
.safe-top{height:env(safe-area-inset-top,44px);background:inherit;flex-shrink:0}
.safe-bottom{height:env(safe-area-inset-bottom,0);flex-shrink:0}

/* SCROLL */
.scroll-view{flex:1;overflow-y:auto;scrollbar-width:none;padding-bottom:90px}
.scroll-view::-webkit-scrollbar{display:none}

/* ===== SPLASH ===== */
#splash{background:#F0F7E8;justify-content:center;align-items:center;cursor:pointer}
.splash-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 38%,rgba(114,193,57,.12) 0%,transparent 65%)}
.splash-content{text-align:center;z-index:1;animation:slideUp .8s ease .2s both}
.splash-logo-img{width:160px;max-width:50vw;height:auto}
.splash-logo-line1{font-size:56px;font-weight:900;font-style:italic;color:#F0F7EB;line-height:1}
.splash-logo-line2{font-size:56px;font-weight:900;font-style:italic;color:#F0F7EB;line-height:.9;display:flex;align-items:center;justify-content:center}
.splash-logo-line2 .tick{color:var(--green)}
.splash-tagline{font-size:11px;letter-spacing:3px;color:rgba(0,0,0,.4);text-transform:uppercase;margin-top:10px}
.splash-tap{margin-top:60px;font-size:11px;color:rgba(0,0,0,.3);letter-spacing:3px;animation:pulse 2s infinite;text-transform:uppercase}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:.9}}

/* ===== LOGIN ===== */
.login-header{padding:20px 28px 24px;text-align:center}
.login-logo{font-size:22px;font-weight:900;font-style:italic;color:var(--text);letter-spacing:-0.5px}
.login-logo span{color:var(--green)}
.login-sub{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:1px}
.login-body{padding:0 28px;flex:1}
.login-welcome{font-size:28px;font-weight:800;color:var(--text);margin-bottom:6px}
.login-desc{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.6}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:7px}
.form-input{width:100%;background:var(--bg3);border:1.5px solid var(--border);border-radius:13px;padding:14px 16px;font-size:16px;color:var(--text);outline:none;transition:border-color .2s;-webkit-appearance:none}
.form-input:focus{border-color:var(--green)}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--green),var(--green-light));border:none;border-radius:14px;padding:16px;font-size:16px;font-weight:800;color:white;cursor:pointer;margin-top:6px;box-shadow:0 8px 24px rgba(114,193,57,.3);letter-spacing:.2px;-webkit-appearance:none}
.btn-primary:active{transform:scale(.98)}
.login-footer{padding:16px 28px 32px;text-align:center}
.login-help{font-size:13px;color:var(--muted)}
.login-help-link{color:var(--green);font-weight:600}
.login-error{background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.2);border-radius:10px;padding:10px 14px;font-size:13px;color:var(--red);margin-top:12px;display:none}

/* ===== LOGIN — DESKTOP CARD ===== */
@media (min-width: 640px) {
  #login.active{
    display:flex!important;
    align-items:center;
    justify-content:center;
    background:var(--bg);
  }
  #login .safe-top{ display:none }
  #login .login-header,
  #login .login-body,
  #login .login-footer{
    padding-left:0;
    padding-right:0;
  }
  #login::after{
    content:'';
    position:absolute;
    inset:0;
    background:radial-gradient(ellipse at 50% 30%, rgba(114,193,57,.08) 0%, transparent 70%);
    pointer-events:none;
  }
  #login > *:not(.safe-top){
    position:relative;
    z-index:1;
  }
  #login{
    flex-direction:column;
  }
  #login .login-header{
    width:420px;
    max-width:92vw;
    background:var(--card);
    border:1px solid var(--border);
    border-radius:24px 24px 0 0;
    box-shadow:0 20px 60px rgba(0,0,0,.08);
    padding:28px 36px 20px;
  }
  #login .login-body{
    width:420px;
    max-width:92vw;
    background:var(--card);
    border-left:1px solid var(--border);
    border-right:1px solid var(--border);
    padding:0 36px;
  }
  #login .login-footer{
    width:420px;
    max-width:92vw;
    background:var(--card);
    border:1px solid var(--border);
    border-top:none;
    border-radius:0 0 24px 24px;
    box-shadow:0 20px 60px rgba(0,0,0,.08);
    padding:16px 36px 28px;
  }
}

/* ===== HOME ===== */
.home-header{padding:16px 20px 20px;background:var(--bg)}
.home-greeting{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:3px}
.home-name{font-size:26px;font-weight:800;color:var(--text)}
.home-name span{color:var(--green)}

/* TRIP CARD */
@keyframes tripFloat{0%,100%{transform:translateY(0) scale(1);box-shadow:0 4px 20px rgba(114,193,57,.1)}50%{transform:translateY(-5px) scale(1.012);box-shadow:0 12px 32px rgba(114,193,57,.22)}}
.trip-card{margin:0 16px 20px;background:linear-gradient(135deg,var(--bg3),var(--card));border:1.5px solid rgba(114,193,57,.3);border-radius:22px;overflow:hidden;position:relative;animation:tripFloat 3.5s ease-in-out infinite}
.trip-card-inner{padding:20px;position:relative;z-index:1}
.trip-card-deco{position:absolute;right:-8px;bottom:-8px;font-size:80px;opacity:.05}
.trip-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(114,193,57,.15);border:1px solid rgba(114,193,57,.3);border-radius:20px;padding:4px 10px;font-size:10px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.trip-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:4px}
.trip-dates{font-size:12px;color:var(--muted);margin-bottom:16px}
.trip-countdown{display:flex;gap:10px}
.cd-item{background:rgba(0,0,0,.2);border-radius:11px;padding:10px 12px;text-align:center;flex:1}
.cd-num{font-size:22px;font-weight:900;color:var(--green);display:block;line-height:1}
.cd-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:3px;display:block}

/* ROUTE */
.route-strip{margin:0 16px 20px;background:var(--card);border-radius:16px;padding:16px;border:1px solid var(--border)}
.section-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px}
.route-stops{display:flex;align-items:center;overflow-x:auto;scrollbar-width:none}
.route-stops::-webkit-scrollbar{display:none}
.route-stop{display:flex;flex-direction:column;align-items:center;min-width:56px}
.rdot{width:8px;height:8px;border-radius:50%;background:var(--muted);margin-bottom:5px;flex-shrink:0}
.rdot.active{background:var(--green);box-shadow:0 0 8px rgba(114,193,57,.6)}
.rdot.done{background:var(--green-dark)}
.rname{font-size:10px;color:var(--muted);text-align:center;font-weight:600}
.rname.active{color:var(--green)}
.rline{flex:1;height:2px;background:var(--border);margin-bottom:18px;min-width:14px}
.rline.done{background:var(--green-dark)}

/* QUICK ACTIONS */
.quick-actions{padding:0 16px;margin-bottom:20px}
.actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.action-card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:16px;cursor:pointer;transition:transform .15s,border-color .2s;position:relative;overflow:hidden}
.action-card:active{transform:scale(.97)}
.action-card:hover{border-color:rgba(114,193,57,.3)}
.action-card.disabled{opacity:.38;pointer-events:none}
.ac-icon{width:40px;height:40px;border-radius:12px;background:rgba(114,193,57,.1);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.ac-icon svg{width:20px;height:20px}
.ac-title{font-size:14px;font-weight:700;color:var(--text)}
.ac-sub{font-size:11px;color:var(--muted);margin-top:2px}
.soon-badge{position:absolute;top:10px;right:10px;background:var(--border);color:var(--muted);font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px;text-transform:uppercase}

/* RECENT UPDATE */
.recent-section{padding:0 16px;margin-bottom:20px}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.see-all{font-size:12px;color:var(--green);font-weight:600;cursor:pointer}
.update-preview{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;gap:12px;align-items:flex-start;cursor:pointer}
.up-icon{width:38px;height:38px;background:rgba(114,193,57,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.up-icon svg{width:18px;height:18px}
.up-content{flex:1;min-width:0}
.up-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.up-text{font-size:12px;color:var(--muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.up-time{font-size:11px;color:var(--green);margin-top:5px;font-weight:600}

/* ===== PAGE HEADER ===== */
.page-header{padding:16px 16px 14px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.back-btn{width:36px;height:36px;background:var(--card);border:1px solid var(--border);border-radius:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.back-btn svg{width:18px;height:18px}
.page-title{font-size:20px;font-weight:800;color:var(--text)}
.page-sub{font-size:12px;color:var(--muted);margin-top:1px}

/* ===== UPDATES ===== */
.update-item{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:10px;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;transition:transform .2s,border-color .2s,box-shadow .2s}
.update-item:active{border-color:rgba(114,193,57,.3)}
@keyframes holdPulse{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(114,193,57,.35);border-color:rgba(114,193,57,.3)}60%{transform:scale(.974);box-shadow:0 0 0 8px rgba(114,193,57,.12);border-color:rgba(114,193,57,.7)}100%{transform:scale(.974);box-shadow:0 0 0 8px rgba(114,193,57,.12);border-color:rgba(114,193,57,.7)}}
.update-item.holding{animation:holdPulse .55s ease-out forwards;border-color:rgba(114,193,57,.7)}
.ui-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.tag{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}
.tag-important{background:rgba(224,82,82,.12);color:var(--red)}
.tag-info{background:rgba(114,193,57,.12);color:var(--green)}
.tag-schedule{background:rgba(90,200,250,.12);color:var(--blue)}
.tag-tip{background:rgba(245,200,66,.12);color:var(--yellow)}
.ui-time{font-size:11px;color:var(--muted)}
.ui-unread{display:flex;align-items:center;gap:6px}
.unread-dot{width:7px;height:7px;background:var(--green);border-radius:50%;box-shadow:0 0 5px rgba(114,193,57,.6)}
.ui-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}
.ui-body{font-size:12px;color:var(--muted);line-height:1.6}

/* ===== ITINERARY ===== */
.day-block{margin-bottom:16px;padding:0 16px}
.day-header-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.day-pill{min-width:48px;height:48px;border-radius:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;padding:0 6px}
.pill-active{background:var(--green)}
.pill-future{background:var(--bg3);border:1px solid var(--border)}
.day-pill-label{font-size:9px;font-weight:800;line-height:1;text-transform:uppercase;letter-spacing:.5px}
.day-pill-num{font-size:16px;font-weight:900;line-height:1.1}
.pill-active .day-pill-label,.pill-active .day-pill-num{color:white}
.pill-future .day-pill-label,.pill-future .day-pill-num{color:var(--muted)}
.day-info{flex:1}
.day-loc{font-size:15px;font-weight:700;color:var(--text)}
.day-date{font-size:11px;color:var(--muted);margin-top:2px}
.today-pill{font-size:10px;background:rgba(114,193,57,.12);color:var(--green);padding:3px 8px;border-radius:6px;font-weight:700}
.day-acts{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.act-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border)}
.act-row:last-child{border-bottom:none}
.act-time{width:44px;flex-shrink:0;text-align:right;font-size:11px;font-weight:700;color:var(--green)}
.act-icon{width:32px;height:32px;background:var(--bg3);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px}
.act-name{font-size:13px;font-weight:600;color:var(--text)}
.act-detail{font-size:11px;color:var(--muted);margin-top:1px}

/* ===== INFO ===== */
.info-card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin:0 16px 14px}
.info-card-title{padding:12px 16px 10px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}
.info-card-title svg{width:13px;height:13px}
.info-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);color:inherit}
.info-row:last-child{border-bottom:none}
.info-row:active{background:rgba(114,193,57,.06)}
a.info-row{cursor:pointer;transition:background .15s}
a.info-row:hover{background:rgba(114,193,57,.06)}
.ir-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px}
.ig{background:rgba(114,193,57,.1)}.ib{background:rgba(90,200,250,.1)}.ir{background:rgba(224,82,82,.1)}.iy{background:rgba(245,200,66,.1)}.ip{background:rgba(175,82,222,.1)}
.ir-content{flex:1;min-width:0}
.ir-title{font-size:14px;font-weight:600;color:var(--text)}
.ir-sub{font-size:11px;color:var(--muted);margin-top:2px}
.ir-status{font-size:16px}
.chevron{color:var(--muted)}

/* ===== INSTAGRAM-STYLE FEED ===== */
.ig-screen-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;flex-shrink:0;border-bottom:1px solid var(--border)}
.ig-wordmark{font-size:22px;font-weight:900;font-style:italic;color:var(--text);letter-spacing:-.5px}
.ig-wordmark span{color:var(--green)}
.ig-header-icons{display:flex;gap:16px;align-items:center}
.ig-header-icon{color:var(--text);cursor:pointer}

/* Stories / Trip card row */
.ig-trip-row{padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.ig-trip-card-mini{background:linear-gradient(135deg,var(--bg3),var(--card));border:1.5px solid rgba(114,193,57,.3);border-radius:18px;padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;overflow:hidden;position:relative}
.ig-trip-card-mini:active{opacity:.9}
.ig-trip-card-deco{position:absolute;right:-4px;bottom:-6px;font-size:56px;opacity:.07;pointer-events:none}
.ig-trip-avatar-ring{width:52px;height:52px;border-radius:50%;padding:2.5px;background:linear-gradient(135deg,var(--green),var(--green-light));flex-shrink:0}
.ig-trip-avatar-inner{width:100%;height:100%;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid var(--bg)}
.ig-trip-info{flex:1;min-width:0}
.ig-trip-name{font-size:13px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ig-trip-sub{font-size:11px;color:var(--muted);margin-top:2px}
.ig-trip-countdown{text-align:right;flex-shrink:0}
.ig-trip-days{font-size:22px;font-weight:900;color:var(--green);line-height:1}
.ig-trip-days-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;text-align:center}

/* Instagram Post */
.ig-post{border-bottom:1px solid var(--border);background:var(--bg2)}
.ig-post-header{display:flex;align-items:center;gap:10px;padding:10px 12px 10px}
.ig-lw-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg);overflow:hidden;flex-shrink:0;border:1.5px solid rgba(114,193,57,.3);display:flex;align-items:center;justify-content:center}
.ig-lw-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.ig-post-meta{flex:1;min-width:0}
.ig-post-username{font-size:13px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:5px;line-height:1.2}
.ig-verified-badge{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:var(--green);color:white;font-size:9px;font-weight:900;flex-shrink:0}
.ig-post-tag-label{font-size:11px;color:var(--muted);margin-top:1px}
.ig-post-more{color:var(--muted);font-size:22px;line-height:1;cursor:pointer;padding:0 4px;flex-shrink:0}
.ig-post-time-top{font-size:11px;color:var(--muted);flex-shrink:0}

/* Post image */
.ig-post-image{width:100%;display:block;max-height:420px;object-fit:cover;cursor:zoom-in}
.ig-post-no-image{padding:0 12px 4px}

/* Actions bar */
.ig-actions-bar{display:flex;align-items:center;padding:10px 12px 6px;gap:6px}
.ig-react-area{display:flex;align-items:center;gap:6px;flex:1;flex-wrap:wrap}
.ig-hold-hint{font-size:11px;color:var(--muted);font-style:italic}
.ig-bookmark-btn{margin-left:auto;color:var(--muted);flex-shrink:0}

/* Reactions summary row */
.ig-reactions-row{padding:2px 12px 6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ig-reactions-who{font-size:13px;color:var(--text);line-height:1.4}
.ig-reactions-who strong{font-weight:700}

/* Caption */
.ig-caption{padding:2px 12px 4px;font-size:13.5px;color:var(--text);line-height:1.55}
.ig-caption-handle{font-weight:800}
.ig-caption-title{font-weight:700}
.ig-caption-body{color:var(--muted)}

/* Timestamp */
.ig-timestamp{padding:2px 12px 14px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* Tag pill inside post */
.ig-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}
.ig-tag-important{background:rgba(224,82,82,.12);color:var(--red)}
.ig-tag-info{background:rgba(114,193,57,.12);color:var(--green)}
.ig-tag-schedule{background:rgba(90,200,250,.12);color:var(--blue)}
.ig-tag-tip{background:rgba(245,200,66,.12);color:var(--yellow)}

/* PDF attachment in post */
.ig-pdf-attach{display:inline-flex;align-items:center;gap:7px;margin:6px 12px;padding:10px 14px;background:var(--bg3);border-radius:12px;font-size:12px;font-weight:600;color:var(--text);text-decoration:none;border:1px solid var(--border)}

/* ===== BOTTOM NAV ===== */
.bottom-nav{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-around;padding:10px 12px calc(env(safe-area-inset-bottom,0px) + 10px);background:transparent;z-index:50;pointer-events:none;direction:ltr}
.bottom-nav::before{content:'';position:absolute;inset:0;background:var(--bg);opacity:.85;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);pointer-events:none}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:10px 18px;border-radius:20px;min-width:60px;position:relative;pointer-events:all;transition:transform .15s}
.nav-item:active{transform:scale(.92)}
.nav-item svg{width:22px;height:22px;stroke:var(--muted);transition:stroke .2s,transform .2s}
.nav-item.active svg{stroke:var(--green);transform:scale(1.08)}
.nav-label{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:.3px;transition:color .2s}
.nav-item.active .nav-label{color:var(--green)}
.nav-item.active::before{content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green)}
/* UNREAD BADGE on Updates tab */
.nav-unread-badge{position:absolute;top:4px;right:8px;min-width:17px;height:17px;border-radius:9px;background:#E53935;color:#fff;font-size:10px;font-weight:800;display:none;align-items:center;justify-content:center;padding:0 4px;line-height:1;box-shadow:0 1px 4px rgba(229,57,53,.5);pointer-events:none;z-index:10}
.nav-unread-badge.show{display:flex}

/* LOADING */
.loading{display:flex;align-items:center;justify-content:center;flex:1;flex-direction:column;gap:12px}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:13px;color:var(--muted)}

/* IMAGE LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:999;display:none;align-items:center;justify-content:center;flex-direction:column;padding:20px;cursor:zoom-out}
.lightbox.open{display:flex;animation:fadeIn .2s ease}
.lightbox img{max-width:100%;max-height:85vh;border-radius:12px;object-fit:contain}
.lightbox-close{position:absolute;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:white;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.update-img{width:100%;border-radius:12px;margin-top:10px;max-height:220px;object-fit:cover;cursor:zoom-in;transition:opacity .15s}
.update-img:active{opacity:.85}

/* ===== REACTIONS ===== */
.reaction-picker-overlay{position:fixed;inset:0;z-index:850;display:none}
.reaction-picker-overlay.open{display:block}
.reaction-picker-bg{position:absolute;inset:0}
.reaction-picker-bubble{position:fixed;background:var(--card);border:1.5px solid var(--border);border-radius:60px;padding:10px 16px;display:flex;gap:4px;box-shadow:0 12px 40px rgba(0,0,0,.28);z-index:851;animation:bubbleIn .22s cubic-bezier(.34,1.56,.64,1) both}
@keyframes bubbleIn{from{transform:scale(.5) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.rp-btn{width:54px;height:54px;border:none;background:none;font-size:30px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s;-webkit-appearance:none}
.rp-btn:active{transform:scale(1.35)}
.rp-btn.selected{background:rgba(114,193,57,.15);transform:scale(1.2)}
.reaction-bar{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.reaction-chip{background:var(--bg3);border:1.5px solid var(--border);border-radius:20px;padding:5px 11px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-weight:700;transition:all .15s;-webkit-appearance:none;color:var(--text)}
.reaction-chip span{font-size:12px;color:var(--muted)}
.reaction-chip.mine{background:rgba(114,193,57,.12);border-color:rgba(114,193,57,.5);color:var(--green)}
.reaction-chip.mine span{color:var(--green)}
.reaction-chip:active{transform:scale(.94)}

/* ===== REACTORS SHEET ===== */
.reactors-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:700;display:none;align-items:flex-end}
.reactors-overlay.open{display:flex;animation:fadeO .2s}
.reactors-sheet{width:100%;background:var(--card);border-radius:24px 24px 0 0;padding:16px 20px calc(env(safe-area-inset-bottom,0px) + 24px);border-top:1px solid var(--border);max-height:70vh;overflow-y:auto;animation:sheetIn .3s cubic-bezier(.25,.8,.25,1)}
.reactors-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 14px}
.reactors-title{font-size:13px;font-weight:800;color:var(--text);text-align:center;margin-bottom:14px}
.reactor-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.reactor-row:last-child{border-bottom:none}
.reactor-avatar{width:36px;height:36px;border-radius:50%;background:rgba(114,193,57,.15);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:var(--green);flex-shrink:0}
.reactor-name{font-size:14px;color:var(--text);font-weight:600;flex:1}
.reactor-emoji{font-size:20px}

/* ===== LW PROFILE SCREEN ===== */
.lwp-hero{display:flex;flex-direction:column;align-items:center;padding:28px 20px 16px;gap:12px}
.lwp-photo{width:86px;height:86px;border-radius:50%;overflow:hidden;border:2.5px solid rgba(114,193,57,.4);background:var(--bg3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lwp-photo img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.lwp-photo-placeholder{font-size:32px}
.lwp-name-row{display:flex;align-items:center;gap:7px}
.lwp-name{font-size:22px;font-weight:900;color:var(--text)}
.lwp-desc{font-size:14px;color:var(--muted);text-align:center;line-height:1.6;white-space:pre-line;padding:0 12px}
.lwp-handle{font-size:13px;color:var(--green);font-weight:600}
.lwp-contact-btn{display:inline-flex;align-items:center;gap:8px;margin-top:4px;padding:10px 24px;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green-light));color:white;font-size:14px;font-weight:800;text-decoration:none;cursor:pointer;border:none;-webkit-appearance:none}
.lwp-divider{height:1px;background:var(--border);margin:4px 0}

/* ===== PROFILE ===== */
.profile-avatar-btn{width:36px;height:36px;border-radius:50%;background:rgba(114,193,57,.15);border:2px solid rgba(114,193,57,.35);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900;color:var(--green);cursor:pointer;flex-shrink:0;margin-left:auto}
.home-header-row{display:flex;align-items:center;padding:16px 20px 4px}
.profile-hero{display:flex;flex-direction:column;align-items:center;padding:28px 20px 16px;gap:8px}
.profile-big-avatar{width:76px;height:76px;border-radius:50%;background:rgba(114,193,57,.12);border:2.5px solid rgba(114,193,57,.4);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:var(--green)}
.profile-full-name{font-size:22px;font-weight:800;color:var(--text)}
.profile-username{font-size:13px;color:var(--muted)}
.profile-info-card{background:var(--card);border:1px solid var(--border);border-radius:16px;margin:0 16px 14px;overflow:hidden}
.profile-row{display:flex;align-items:center;padding:13px 16px;border-bottom:1px solid var(--border);gap:10px}
.profile-row:last-child{border-bottom:none}
.pr-label{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;width:90px;flex-shrink:0}
.pr-value{font-size:14px;color:var(--text);font-weight:600;flex:1}
.pr-edit{font-size:12px;color:var(--green);font-weight:700;cursor:pointer;padding:2px 8px;border:1px solid rgba(114,193,57,.3);border-radius:8px}
.profile-section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:2px;padding:4px 16px 8px;margin-top:8px}
.profile-gender-grid{display:flex;gap:8px;padding:0 16px 16px}
.gender-opt{flex:1;padding:10px;border:1.5px solid var(--border);border-radius:12px;text-align:center;cursor:pointer;font-size:13px;font-weight:700;color:var(--muted);transition:all .15s}
.gender-opt.sel{border-color:var(--green);background:rgba(114,193,57,.1);color:var(--green)}
.profile-name-input{width:100%;background:var(--bg3);border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;font-size:15px;color:var(--text);outline:none;margin:0 16px;width:calc(100% - 32px);-webkit-appearance:none}
.profile-name-input:focus{border-color:var(--green)}
.profile-save-btn{margin:16px 16px 0;background:linear-gradient(135deg,var(--green),var(--green-light));border:none;border-radius:13px;padding:14px;font-size:15px;font-weight:800;color:white;cursor:pointer;width:calc(100% - 32px);-webkit-appearance:none;display:block}
.profile-logout-btn{margin:10px 16px 0;background:rgba(224,82,82,.08);border:1.5px solid rgba(224,82,82,.2);border-radius:13px;padding:13px;font-size:14px;font-weight:700;color:var(--red);cursor:pointer;width:calc(100% - 32px);-webkit-appearance:none;display:block}

/* HAMBURGER MENU BUTTON */
.top-controls{position:absolute;top:calc(env(safe-area-inset-top,0px) + 8px);left:12px;z-index:100;display:flex}
.ctrl-btn{height:34px;width:34px;border-radius:11px;border:1.5px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-appearance:none}
.ctrl-btn:active{border-color:var(--green);background:rgba(114,193,57,.08)}

/* ===== LEFT DRAWER ===== */
.drawer-overlay{position:fixed;inset:0;z-index:400;display:none;background:rgba(0,0,0,0);transition:background .3s}
.drawer-overlay.open{display:block;background:rgba(0,0,0,.55)}
.drawer{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--card);z-index:401;transform:translateX(-100%);transition:transform .3s cubic-bezier(.25,.8,.25,1);display:flex;flex-direction:column;border-right:1px solid var(--border)}
.drawer-overlay.open .drawer{transform:translateX(0)}
.drawer-safe{height:calc(env(safe-area-inset-top,0px) + 20px)}
.drawer-profile-sec{display:flex;align-items:center;gap:14px;padding:16px 20px 18px;cursor:pointer;border-bottom:1px solid var(--border)}
.drawer-profile-sec:active{background:rgba(114,193,57,.05)}
.drawer-avatar{width:48px;height:48px;border-radius:50%;background:rgba(114,193,57,.12);border:2px solid rgba(114,193,57,.3);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:var(--green);flex-shrink:0}
.drawer-name{font-size:15px;font-weight:800;color:var(--text);line-height:1.2}
.drawer-sub{font-size:12px;color:var(--green);margin-top:3px;font-weight:600}
.drawer-section{padding:18px 20px}
.drawer-sec-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:14px}
.drawer-mode-row{display:flex;align-items:center;gap:12px}
.drawer-mode-label{font-size:15px;font-weight:600;color:var(--text);flex:1;display:flex;align-items:center;gap:10px}
.toggle-track{width:46px;height:26px;border-radius:13px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.toggle-track.on{background:var(--green)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:white;box-shadow:0 1px 4px rgba(0,0,0,.25);transition:transform .2s}
.toggle-track.on .toggle-thumb{transform:translateX(20px)}
.drawer-lang-grid{display:flex;gap:8px;margin-top:4px}
.drawer-lang-pill{flex:1;padding:10px 4px;border-radius:11px;border:1.5px solid var(--border);text-align:center;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .15px;-webkit-appearance:none;background:none}
.drawer-lang-pill.active{border-color:var(--green);background:rgba(114,193,57,.1);color:var(--green)}
.drawer-lang-pill:active{transform:scale(.95)}
.drawer-spacer{flex:1}
.drawer-logout{margin:0 16px 8px;padding:14px 16px;border-radius:13px;border:1.5px solid rgba(224,82,82,.2);background:rgba(224,82,82,.06);color:var(--red);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:10px}
.drawer-logout:active{background:rgba(224,82,82,.14)}
.drawer-bottom-safe{height:calc(env(safe-area-inset-bottom,0px) + 12px)}

@keyframes fadeO{from{opacity:0}to{opacity:1}}
@keyframes sheetIn{from{transform:translateY(100%)}to{transform:translateY(0)}}
