/* ============================================================
   Oz Brands Internal — QA Operations app styles
   Built on the Oz Brands brand tokens
   ============================================================ */
:root{
  --marigold:#FBA50A; --orange:#F77F12; --ember:#F4571B; --ember-red:#E83A22; --deep-red:#D62A16;
  --grad-sunrise:linear-gradient(125deg,#FBB12B 0%,#F7820E 42%,#EE491C 78%,#E0301A 100%);
  --ink:#25282F; --ink-2:#3A3E47; --slate:#5B6470; --mist:#939AA4;
  --line:#E6E1D8; --line-soft:#EFEBE3; --paper:#FAF7F1; --card:#FFFFFF; --cloud:#F3EFE8;
  --euca:#1F7A5B; --euca-soft:#E4F0EA;
  --display:'Archivo',system-ui,-apple-system,Segoe UI,sans-serif;
  --body:'Public Sans',system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --radius:14px; --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(37,40,47,.05),0 2px 8px rgba(37,40,47,.05);
  --shadow:0 4px 12px rgba(37,40,47,.06),0 18px 44px rgba(37,40,47,.08);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);letter-spacing:-.02em;line-height:1.1;margin:0}
a{color:var(--ember-red);text-decoration:none}
img{max-width:100%;display:block}
input,select,textarea,button{font-family:inherit;font-size:16px}
code{font-family:var(--mono);font-size:.85em}

/* buttons */
.btn{font-family:var(--display);font-weight:700;font-size:15px;border:0;border-radius:10px;padding:11px 18px;min-height:44px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .12s,box-shadow .2s,background .2s,border-color .2s,color .2s;letter-spacing:-.01em;-webkit-tap-highlight-color:transparent}
.btn:hover{transform:translateY(-1px)}
.btn:disabled{opacity:.6;cursor:default;transform:none}
.btn-primary{background:var(--grad-sunrise);color:#fff;box-shadow:0 6px 16px rgba(238,73,28,.3)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn-block{width:100%;justify-content:center}
.btn-xs{padding:6px 11px;font-size:13px;border-radius:8px;min-height:34px}
.lnk{color:var(--ember-red);font-weight:600}
.muted{color:var(--slate)}
.back{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--slate);margin-bottom:14px}
.back:hover{color:var(--ink)}

/* fields */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field-label{font-size:13px;font-weight:600;color:var(--ink-2)}
.field-hint{font-size:12px;color:var(--mist)}
input[type=text],input[type=password],input[type=number],input[type=date],select,textarea{
  width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;background:var(--card);color:var(--ink);outline:none;transition:border .15s,box-shadow .15s}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(247,130,18,.16)}

/* pills */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.03em;padding:5px 11px;border-radius:100px;font-weight:500;text-transform:capitalize}
.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.pill-euca{background:var(--euca-soft);color:var(--euca)}
.pill-orange{background:#FFF0DF;color:#B65A04}
.pill-red{background:#FDECEA;color:var(--deep-red)}
.pill-ink{background:var(--cloud);color:var(--ink-2)}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:linear-gradient(160deg,rgba(247,130,18,.10),transparent 55%),var(--paper)}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:34px 30px;width:min(100%,400px);text-align:center}
.login-logo{margin:0 auto 14px}
.login-title{font-size:26px;font-weight:800}
.login-sub{color:var(--slate);font-size:13px;margin:4px 0 22px}
.login-card .field{text-align:left}
.login-error{color:var(--deep-red);font-size:13px;min-height:18px;margin:2px 0 10px;text-align:left}
.login-legal{margin:16px 0 0;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--mist);text-align:center}
.demo-note{margin-top:14px;padding:12px 14px;background:var(--euca-soft);border:1px solid #cfe5da;border-radius:10px;font-size:12px;color:#23513f;text-align:left;line-height:1.6}

/* modal */
.modal-ov{position:fixed;inset:0;z-index:160;background:rgba(20,22,26,.55);display:grid;place-items:center;padding:18px;animation:fade .15s ease}
.modal{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);width:min(100%,440px);max-height:90vh;overflow:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 6px}
.modal-head h3{font-size:18px}
.modal-x{background:none;border:0;font-size:18px;color:var(--slate);cursor:pointer;line-height:1}
.modal form{padding:6px 20px 20px}

/* department workspace placeholder */
.workspace-empty{padding:44px 24px}
.ws-icon{font-size:42px;margin-bottom:10px}
.workspace-empty h3{font-family:var(--display);font-size:20px;color:var(--ink);margin-bottom:6px}

/* ===== APP SHELL ===== */
.app-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:10px clamp(14px,4vw,30px);padding-top:calc(10px + env(safe-area-inset-top,0px));
  background:rgba(250,247,241,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.app-brand{display:flex;align-items:center;gap:10px;color:var(--ink)}
.app-brand-text{display:flex;flex-direction:column;line-height:1.05}
.app-brand-text strong{font-family:var(--display);font-weight:800;font-size:15px}
.app-brand-text small{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}
.app-nav{display:flex;gap:4px;margin-right:auto;flex-wrap:wrap}
.app-nav a{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--slate);padding:7px 11px;border-radius:8px}
.app-nav a:hover{background:var(--cloud);color:var(--ink)}
.app-nav a.active{color:var(--orange);background:#FFF0DF}
.app-user{display:flex;align-items:center;gap:10px}
.app-user .who{font-size:12px;color:var(--slate)}
.app-main{max-width:1100px;margin:0 auto;padding:clamp(18px,4vw,34px) clamp(14px,4vw,30px) 80px}

/* section heads */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);font-weight:600;display:flex;align-items:center;gap:10px;margin:0 0 8px}
.kicker::before{content:"";width:22px;height:2px;background:var(--grad-sunrise)}
.sec-head{margin-bottom:22px}
.sec-title-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sec-title-row h2{font-size:clamp(24px,4vw,34px);font-weight:800}
.sec-actions{display:flex;gap:8px;flex-wrap:wrap}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:26px 0 14px}
.row-between h3{font-size:18px;font-weight:700}

/* stats */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0 8px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.stat-n{font-family:var(--display);font-weight:800;font-size:30px;line-height:1}
.stat-l{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin-top:6px}

/* trips */
.trip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.trip-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .2s;position:relative;overflow:hidden}
.trip-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad-sunrise)}
.trip-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.trip-region{font-family:var(--display);font-weight:800;font-size:19px}
.trip-date{font-family:var(--mono);font-size:12px;color:var(--slate);margin-top:3px}
.trip-foot{margin-top:14px;font-size:13px;color:var(--ink-2)}

/* lodgement cards */
.lodge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.lodge-card{display:flex;gap:0;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);color:var(--ink);transition:transform .15s,box-shadow .2s}
.lodge-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.lodge-thumb{position:relative;height:140px;background:var(--cloud);display:grid;place-items:center;font-size:34px;overflow:hidden}
.lodge-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lodge-body{padding:14px 15px}
.lodge-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.lodge-top strong{font-family:var(--display);font-size:16px}
.lodge-farm{color:var(--slate);font-size:13px;margin:2px 0 8px}
.lodge-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px}
.lodge-meta .by{color:var(--mist)}
.lodge-card-body{display:flex;flex-direction:column;color:var(--ink)}
.lodge-actions{display:flex;gap:18px;padding:2px 15px 14px;margin-top:auto}
.lnk.sm{font-size:13px}

/* type badge */
.type-badge{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:6px;font-weight:600;background:var(--cloud);color:var(--ink-2)}
.type-badge.t-indica{background:#efe7f6;color:#6b4aa0}
.type-badge.t-sativa{background:#FFF0DF;color:#B65A04}
.type-badge.t-hybrid{background:var(--euca-soft);color:var(--euca)}

/* stars + chips */
.stars{display:inline-flex;gap:3px}
.star{background:none;border:0;cursor:pointer;font-size:26px;line-height:1;color:var(--orange);padding:0}
.star.on{color:var(--ember)}
.stars-view{color:var(--ember);letter-spacing:1px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{background:var(--card);border:1.5px solid var(--line);border-radius:100px;padding:6px 12px;font-size:13px;cursor:pointer;color:var(--ink-2)}
.chip.on{background:#FFF0DF;border-color:var(--orange);color:#B65A04;font-weight:600}
.chip.add{border-style:dashed;color:var(--slate)}
.chips.read .chip.read{cursor:default}
.chip.read.euca{background:var(--euca-soft);border-color:#cfe5da;color:var(--euca)}
.chip.read.red{background:#FDECEA;border-color:#f3cdc8;color:var(--deep-red)}

/* segmented */
.segmented{display:inline-flex;border:1.5px solid var(--line);border-radius:10px;overflow:hidden;background:var(--card)}
.segmented.sm{transform:none}
.seg{background:none;border:0;padding:9px 15px;font-size:14px;cursor:pointer;color:var(--ink-2);font-weight:600}
.seg+.seg{border-left:1.5px solid var(--line)}
.seg.on{background:var(--ink);color:#fff}
.seg.seg-shortlist.on{background:var(--euca)}
.seg.seg-maybe.on{background:var(--orange)}
.seg.seg-reject.on{background:var(--deep-red)}

/* forms */
.lodge-form,.narrow{max-width:680px;margin:0 auto}
.lodge-form h2{font-size:24px;margin-bottom:18px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.form-block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin:14px 0;box-shadow:var(--shadow-sm)}
.form-block h4{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.form-actions{position:sticky;bottom:0;padding:14px 0;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));background:linear-gradient(transparent,var(--paper) 30%)}
.form-actions .btn{width:100%;justify-content:center}
.photo-strip{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.photo-btns{display:flex;gap:10px;flex-wrap:wrap}
.photo-tile{width:80px;height:80px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.photo-tile img{width:100%;height:100%;object-fit:cover}

/* detail */
.detail{max-width:760px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.detail-hero{position:relative;height:260px;background:var(--cloud);display:grid;place-items:center;font-size:64px;overflow:hidden}
.detail-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 22px 0}
.detail-head h2{font-size:26px;font-weight:800}
.detail-farm{color:var(--slate);font-size:14px;margin-top:2px}
.detail-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 22px}
.kv{font-family:var(--mono);font-size:12px;background:var(--cloud);color:var(--ink-2);padding:4px 9px;border-radius:7px}
.bar{display:flex;align-items:center;gap:12px;padding:6px 22px}
.bar-l{width:140px;font-size:13px;color:var(--ink-2)}
.bar-track{flex:1;height:8px;background:var(--cloud);border-radius:6px;overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--grad-sunrise)}
.bar-v{font-family:var(--mono);font-size:12px;color:var(--slate);width:34px;text-align:right}
.tagrow{display:flex;gap:12px;align-items:flex-start;padding:8px 22px}
.tagrow-l{width:80px;flex:none;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--mist);padding-top:6px}
.note{padding:10px 22px}
.note h4{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--mist);margin-bottom:4px}
.note p{margin:0;color:var(--ink-2)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 22px}
.gallery img{aspect-ratio:1;object-fit:cover;border-radius:8px}
.zoomable{cursor:zoom-in}

/* image lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,22,26,.92);display:grid;place-items:center;padding:18px;cursor:zoom-out;animation:fade .15s ease}
.lightbox img{max-width:96vw;max-height:90vh;object-fit:contain;border-radius:10px;box-shadow:var(--shadow);cursor:default}
.lightbox-close{position:fixed;top:calc(14px + env(safe-area-inset-top,0px));right:16px;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.16);color:#fff;font-size:18px;cursor:pointer}
.lightbox-close:hover{background:rgba(255,255,255,.28)}
@keyframes fade{from{opacity:0}to{opacity:1}}
.detail-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:18px 22px;border-top:1px solid var(--line);margin-top:8px}
.admin-verdict{display:flex;align-items:center;gap:10px;margin-left:auto;flex-wrap:wrap}
.admin-verdict .k{font-size:12px;color:var(--slate)}

/* filter bar + tables */
.filter-bar{display:flex;gap:10px;margin:8px 0 16px;flex-wrap:wrap}
.filter-bar select{width:auto;min-width:150px}
.group-h{font-size:16px;margin:24px 0 10px;font-weight:700}
table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
th{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);background:var(--cloud)}
td{padding:12px 14px;border-bottom:1px solid var(--line-soft);font-size:14px;vertical-align:middle}
tr:last-child td{border-bottom:0}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}

/* misc */
.empty{background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);padding:28px;text-align:center;color:var(--slate)}
.loading{display:flex;align-items:center;gap:12px;color:var(--slate);padding:30px 0}
.spin{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--orange);border-radius:50%;animation:sp 0.8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.toast{position:fixed;left:50%;bottom:24px;translate:-50% 20px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s;z-index:100}
.toast.show{opacity:1;translate:-50% 0}
.toast.ok{background:var(--euca)}.toast.warn{background:var(--deep-red)}

/* ranking */
.lodge-thumb{position:relative}
.rank-badge{position:absolute;top:8px;left:8px;background:var(--ink);color:#fff;font-family:var(--display);font-weight:800;font-size:13px;padding:3px 9px;border-radius:8px;box-shadow:var(--shadow-sm)}
.rank-list{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.rank-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow-sm);cursor:grab}
.rank-row.dragging{opacity:.5}
.rank-num{font-family:var(--display);font-weight:800;font-size:18px;width:30px;text-align:center;color:var(--orange);flex:none}
.rank-body{flex:1;min-width:0}
.rank-name{display:flex;align-items:center;gap:8px}
.rank-name strong{font-family:var(--display);font-size:16px}
.rank-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;margin-top:3px}
.rank-meta .by{color:var(--mist)}
.rank-move{display:flex;flex-direction:column;gap:4px;flex:none}
.mv{background:var(--cloud);border:1px solid var(--line);border-radius:7px;width:36px;height:28px;cursor:pointer;font-size:11px;color:var(--ink-2);line-height:1}
.mv:disabled{opacity:.35;cursor:default}
.rank-thumb{position:relative;width:54px;height:54px;border-radius:9px;overflow:hidden;flex:none;background:var(--cloud);display:grid;place-items:center;font-size:22px}
.rank-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rank-tags{font-size:12px;color:var(--slate);margin-top:4px}
.rank-note{font-size:12.5px;color:var(--ink-2);margin-top:4px;font-style:italic}
.rank-meta .mini{font-family:var(--mono);font-size:10.5px;background:var(--cloud);color:var(--ink-2);padding:2px 7px;border-radius:6px}

/* australian market */
.market{padding:10px 22px}
.market h4{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--mist);margin-bottom:6px}
.market-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.market p{margin:0;color:var(--ink-2)}

/* finalise task callout */
.task-callout{background:#FFF0DF;border:1px solid #f6d9b0;border-radius:var(--radius);padding:14px 16px;margin:16px 0}
.task-head{font-family:var(--display);font-weight:800;font-size:15px;color:#B65A04;margin-bottom:6px}
.task-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 0;font-size:14px}
.task-row+.task-row{border-top:1px solid #f6d9b0}

/* admin cross-trip finalise */
.section-lead-left{color:var(--slate);max-width:72ch;margin:2px 0 6px}
.trip-fin-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:24px 0 8px;font-family:var(--display);font-weight:700;font-size:16px}
.trip-fin-head .muted{font-family:var(--body);font-weight:400;font-size:13px}
.market-cell{display:inline-flex;gap:6px;flex-wrap:wrap}
.finalise-tbl td .pill{font-size:10px}
.rank-num.sm{font-size:14px;width:auto}

/* responsive */
@media(max-width:760px){
  .finalise-tbl,.users-tbl{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
}
@media(max-width:640px){
  .app-header{gap:10px 12px;padding-bottom:8px}
  .app-user{margin-left:auto}
  .app-user .who{display:none}
  /* nav becomes a tidy horizontal scroll strip under the brand */
  .app-nav{order:3;width:100%;margin:2px -2px 0;padding:2px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .app-nav::-webkit-scrollbar{display:none}
  .app-nav a{flex:none}
  .app-main{padding-left:16px;padding-right:16px;padding-bottom:60px}
  .sec-title-row{align-items:flex-start}
  .sec-title-row h2{font-size:24px}
  .sec-actions{width:100%}
  .sec-actions .btn{flex:1}
  .form-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .stat{padding:14px}
  .stat-n{font-size:26px}
  .detail-hero{height:200px}
  .detail-head,.detail-meta,.bar,.tagrow,.note,.market,.gallery,.detail-actions{padding-left:16px;padding-right:16px}
  .bar-l{width:96px;font-size:12px}
  .contact-card{padding:1.5rem}
  .detail-actions{flex-direction:column;align-items:stretch}
  .detail-actions .btn{width:100%}
  .admin-verdict{margin-left:0;width:100%;justify-content:space-between}
  .rank-thumb{width:46px;height:46px}
}
@media(max-width:380px){
  .stat-row{grid-template-columns:1fr}
  .app-brand-text small{display:none}
}

/* print (finalise -> PDF) */
@media print{
  .app-header,.sec-actions,.filter-bar,.back,.detail-actions{display:none!important}
  body{background:#fff}
  table{box-shadow:none}
}
