*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --green-50:#E1F5EE;--green-100:#9FE1CB;--green-400:#1D9E75;--green-600:#0F6E56;--green-800:#085041;
  --blue-50:#E6F1FB;--blue-400:#378ADD;--blue-800:#0C447C;
  --amber-50:#FAEEDA;--amber-400:#BA7517;--amber-800:#633806;
  --bg:#fff;--bg-secondary:#f7f7f5;--bg-tertiary:#f1f0ec;
  --text:#1a1a1a;--text-secondary:#666;--text-tertiary:#999;
  --border:rgba(0,0,0,0.1);--border-md:rgba(0,0,0,0.18);
  --radius-sm:6px;--radius-md:8px;--radius-lg:12px;
  --sans:'DM Sans',system-ui,sans-serif;--mono:'DM Mono',monospace;
}
@media(prefers-color-scheme:dark){
  :root{
    --bg:#1a1a18;--bg-secondary:#222220;--bg-tertiary:#2a2a28;
    --text:#e8e6e0;--text-secondary:#999;--text-tertiary:#666;
    --border:rgba(255,255,255,0.1);--border-md:rgba(255,255,255,0.18);
    --green-50:#04342C;--green-100:#085041;--green-800:#9FE1CB;
    --blue-50:#042C53;--blue-800:#B5D4F4;
    --amber-50:#412402;--amber-800:#FAC775;
  }
}
html,body{height:100%;font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;}

/* ---- inputs ---- */
input,select,textarea{
  background:var(--bg);color:var(--text);border:0.5px solid var(--border-md);
  border-radius:var(--radius-sm);padding:8px 10px;font-family:var(--sans);font-size:13px;
  outline:none;transition:border-color 0.15s;width:100%;
}
input:focus,select:focus,textarea:focus{border-color:var(--green-400);}
textarea{resize:vertical;min-height:72px;line-height:1.5;}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;}

/* ---- custom select (consistent dropdown UI) ---- */
.cselect{position:relative;min-width:0;}
.cselect select{position:absolute;inset:0;opacity:0;pointer-events:none;}
.cselect-btn{
  width:100%;
  min-width:0;
  text-align:left;
  background:var(--bg);
  color:var(--text);
  border:0.5px solid var(--border-md);
  border-radius:var(--radius-sm);
  padding:8px 34px 8px 10px;
  font-family:var(--sans);
  font-size:13px;
  cursor:pointer;
  transition:border-color 0.15s, background 0.1s;
  position:relative;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cselect-btn:focus{outline:none;border-color:var(--green-400);}
.cselect-btn:after{
  content:'';
  position:absolute;
  right:10px;
  top:50%;
  width:10px;
  height:6px;
  transform:translateY(-50%);
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
}
.cselect-btn.disabled{opacity:.55;cursor:not-allowed;background:var(--bg-secondary);}
.cselect-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  max-height:260px;
  overflow:auto;
  background:var(--bg);
  border:0.5px solid var(--border);
  border-radius:12px;
  box-shadow:0 18px 60px rgba(0,0,0,0.18);
  z-index:60;
  padding:6px;
}
.cselect-item{
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  font-size:12px;
  color:var(--text);
}
.cselect-group{
  padding:8px 10px;
  font-size:10px;
  font-weight:650;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--text);
  cursor:default;
  user-select:none;
}
.cselect-item:hover{background:var(--bg-secondary);}
.cselect-item.active{background:var(--bg-tertiary);}
.cselect-item.muted{opacity:.6;cursor:default;}

/* ---- date picker (flatpickr) ---- */
.flatpickr-calendar{
  border-radius:12px;
  border:0.5px solid var(--border);
  box-shadow:0 14px 42px rgba(0,0,0,0.12);
  font-family:var(--sans);
  font-size:12px;
  line-height:1.35;
  padding:8px 8px 10px;
  box-sizing:border-box;
  width:auto;
  min-width:0;
  max-width:calc(100vw - 24px);
}
/* compact day grid: 7 × 32px = 224px */
.flatpickr-days,.dayContainer{width:224px!important;min-width:224px!important;max-width:224px!important;}
.flatpickr-day{max-width:32px!important;width:32px!important;height:30px!important;line-height:30px!important;font-size:12px;border-radius:6px;text-align:center;}
.flatpickr-months{margin:0 0 2px;}
.flatpickr-weekdays{margin:0;font-size:11px;}
span.flatpickr-weekday{height:26px;line-height:26px;}
.flatpickr-innerContainer{padding:0;display:flex;justify-content:center;}
.flatpickr-rContainer{display:flex;flex-direction:column;align-items:center;}
.flatpickr-days{margin:0;}
.flatpickr-current-month,.flatpickr-current-month input.cur-year,.flatpickr-current-month .flatpickr-monthDropdown-months{font-size:12px;font-weight:500;}
.flatpickr-time input,.flatpickr-time .flatpickr-am-pm{font-size:12px;}
.flatpickr-calendar .numInputWrapper span.arrowUp:after,.flatpickr-calendar .numInputWrapper span.arrowDown:after{border-width:4px;}
.flatpickr-calendar,.flatpickr-time{background:var(--bg);color:var(--text);}
.flatpickr-months .flatpickr-month{color:var(--text);}
.flatpickr-current-month .flatpickr-monthDropdown-months,.flatpickr-current-month input.cur-year{color:var(--text);}
.flatpickr-weekdays{background:var(--bg);}
span.flatpickr-weekday{color:var(--text-secondary);}
.flatpickr-day:hover{background:var(--bg-secondary);}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange{background:var(--green-600);border-color:var(--green-600);color:#fff;}
.flatpickr-day.inRange{background:var(--green-50);border-color:transparent;color:var(--text);}
.flatpickr-day.today{border-color:var(--green-400);}
.flatpickr-input[readonly]{background:var(--bg);cursor:text;}
/* manual range inputs - sits between month nav and day grid */
.fp-manual-range{display:flex;align-items:center;gap:6px;padding:6px 0 8px;border-bottom:1px solid var(--border);margin-bottom:6px;}
.fp-manual-range input{flex:1;min-width:0;font-size:11px;font-family:inherit;border:1px solid var(--border);border-radius:6px;padding:4px 7px;background:var(--bg);color:var(--text);outline:none;}
.fp-manual-range input:focus{border-color:#1d4ed8;box-shadow:0 0 0 2px rgba(29,78,216,.1);}
.fp-mr-sep{font-size:12px;color:var(--text-secondary);flex-shrink:0;}

/* ---- buttons ---- */
.btn{font-family:var(--sans);font-size:13px;font-weight:500;padding:8px 18px;border-radius:var(--radius-md);cursor:pointer;border:0.5px solid var(--border-md);background:transparent;color:var(--text);transition:background 0.1s;}
.btn:hover{background:var(--bg-secondary);}
.btn-primary{background:var(--green-600);border-color:var(--green-600);color:#fff;}
.btn-primary:hover{background:var(--green-800);border-color:var(--green-800);}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed;}

/* ---- screens ---- */
.screen{display:none;}
.screen.active{display:block;}

/* ---- onboarding ---- */
.onboarding{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg-tertiary);}
.onboard-card{width:100%;max-width:480px;background:var(--bg);border:0.5px solid var(--border);border-radius:16px;padding:40px;}
.onboard-logos{display:flex;align-items:center;justify-content:center;gap:5px;margin:0 auto 24px;max-width:100%;}
.onboard-logos .logo-box{width:170px;height:39px;display:flex;align-items:center;justify-content:flex-start;}
.onboard-logos .logo-box2{width:135px;height:39px;display:flex;align-items:center;justify-content:flex-start;}
.onboard-logos img{max-height:44px;max-width:100%;width:auto;height:auto;display:block;object-fit:contain;}
.onboard-logos img.kse-logo{max-height:30px; margin-left: 20px;}
.onboard-logos .divider{width:1px;height:28px;background:var(--border);opacity:0.9;flex:0 0 auto;}
.onboard-title{font-size:24px;font-weight:500;color:var(--text);letter-spacing:-0.4px;margin-bottom:20px;text-align:center;}
.onboard-sub{font-size:13px;color:var(--text-secondary);line-height:1.7;margin-bottom:32px; text-align: center;}
.onboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.onboard-field label{display:block;font-size:12px;font-weight:500;color:var(--text);margin-bottom:5px;}
.onboard-field label .req{color:#D85A30;}
.onboard-field .subfield{margin-top:10px;}
.hidden{display:none !important;}
.onboard-footer{margin-top:28px;display:flex;justify-content:flex-end;}
.consent-box{margin-top:14px;padding:12px 12px;border-radius:12px;background:var(--bg-secondary);border:0.5px solid var(--border);display:flex;gap:10px;align-items:flex-start;}
.consent-box input{width:16px;height:16px;margin-top:2px;}
.consent-text{font-size:12px;color:var(--text-secondary);line-height:1.55;}
.consent-text a{color:var(--green-600);text-decoration:none;}
.consent-text a:hover{text-decoration:underline;}
.ob-err{display:none;font-size:12px;color:#A32D2D;background:#FCEBEB;border:0.5px solid #F7C1C1;border-radius:var(--radius-md);padding:8px 12px;margin-top:16px;}
.ob-err.show{display:block;}

/* ---- app shell ---- */
.app{display:grid;grid-template-rows:52px 1fr;height:100vh;}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:0.5px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10;}
.topbar-left{display:flex;align-items:center;gap:10px;}
.logo-mark{width:24px;height:24px;border-radius:6px;background:var(--green-600);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.logo-mark svg{width:13px;height:13px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.app-name{font-size:13px;font-weight:500;color:var(--text);}
.app-year{font-size:11px;color:var(--text-secondary);font-family:var(--mono);background:var(--bg-secondary);border:0.5px solid var(--border);padding:2px 8px;border-radius:4px;}
.user-chip{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);transition:background 0.1s;}
.user-chip:hover{background:var(--bg-secondary);}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--green-50);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--green-800);flex-shrink:0;}
.user-text{font-size:12px;color:var(--text-secondary);}
.user-text .uname{font-weight:500;color:var(--text);}

/* ---- main layout ---- */
.main{display:grid;grid-template-columns:220px minmax(0,1fr);overflow:hidden;height:calc(100vh - 52px);}
.sidebar{border-right:0.5px solid var(--border);padding:2px 0;overflow-y:auto;background:var(--bg);}
.scope-head{padding:10px 16px 10px;display:flex;align-items:center;gap:8px;}
.scope-tag{font-size:14px;font-weight:500;padding:2px 7px;border-radius:4px;white-space:nowrap;}
.s1-tag{background:var(--green-50);color:var(--green-800);}
.s2-tag{background:var(--blue-50);color:var(--blue-800);}
.s3-tag{background:var(--amber-50);color:var(--amber-800);}
.nav-item{display:flex;align-items:center;gap:8px;padding:7px 16px 7px 18px;font-size:12.5px;color:var(--text-secondary);cursor:pointer;border-left:2px solid transparent;transition:background 0.1s;}
.nav-item:hover{background:var(--bg-secondary);}
.nav-item.active{font-weight:500;}
.nav-item.active .nav-dot{background:currentColor;border-color:currentColor;}
.nav-item.active.scope-1{color:var(--green-600);background:var(--green-50);border-left-color:var(--green-400);}
.nav-item.active.scope-1 .nav-num{color:var(--green-400);}
.nav-item.active.scope-2{color:var(--blue-800);background:var(--blue-50);border-left-color:var(--blue-400);}
.nav-item.active.scope-2 .nav-num{color:var(--blue-400);}
.nav-item.active.scope-3{color:var(--amber-800);background:var(--amber-50);border-left-color:var(--amber-400);}
.nav-item.active.scope-3 .nav-num{color:var(--amber-400);}
.nav-num{font-size:11px;font-family:var(--mono);color:var(--text-tertiary);min-width:24px;flex-shrink:0;}
.nav-label{flex:1;line-height:1.3;}
.nav-dot{width:6px;height:6px;border-radius:50%;border:1px solid var(--border-md);flex-shrink:0;}
.nav-dot.done{background:var(--green-400);border-color:var(--green-400);}

/* ---- sidebar: saved panel ---- */
.saved-panel{margin:10px 12px 12px;border:0.5px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);padding:12px;}
.saved-panel.active{border-color:var(--border-md);background:var(--bg-tertiary);}
.saved-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.saved-title{font-size:11px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-secondary);}
.saved-count{font-size:11px;font-family:var(--mono);color:var(--text-secondary);background:var(--bg);border:0.5px solid var(--border);padding:2px 7px;border-radius:999px;}
.saved-list{display:flex;flex-direction:column;gap:6px;}
.saved-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;background:var(--bg);border:0.5px solid var(--border);cursor:pointer;transition:background 0.1s,border-color 0.1s;}
.saved-item:hover{background:var(--bg-tertiary);border-color:var(--border-md);}
.saved-item .sid{font-size:11px;font-family:var(--mono);color:var(--text-tertiary);min-width:28px;}
.saved-item .slabel{font-size:12px;color:var(--text);line-height:1.2;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.saved-item .pill{font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;border:0.5px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);}
.saved-empty{font-size:12px;color:var(--text-secondary);line-height:1.5;padding:8px 10px;border-radius:10px;background:var(--bg);border:0.5px dashed var(--border);}

/* ---- content: saved list ---- */
.saved-content-head{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.saved-content-meta{font-size:12px;color:var(--text-secondary);line-height:1.5; margin-bottom: 10px;}
.saved-table{width:100%;border-collapse:separate;border-spacing:0 8px;margin-top:12px;}
.saved-table th{font-size:10px;font-weight:650;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-secondary);text-align:left;padding:0 10px;}
.saved-row{background:var(--bg);border:0.5px solid var(--border);border-radius:12px;cursor:pointer;transition:background 0.1s,border-color 0.1s;}
.saved-row:hover{background:var(--bg-secondary);border-color:var(--border-md);}
.saved-row td{padding:10px 12px;font-size:12px;color:var(--text);border-top:0.5px solid transparent;border-bottom:0.5px solid transparent;}
.saved-row .mono{font-family:var(--mono);font-size:11px;color:var(--text-secondary);}
.saved-row .muted{color:var(--text-secondary);}
.status-pill{display:inline-flex;flex-direction:column;gap:2px;padding:6px 10px;border-radius:12px;border:0.5px solid var(--border);background:var(--bg-secondary);font-size:11px;line-height:1.1;min-width:110px;}
.status-pill .sub{font-family:var(--mono);font-size:10px;opacity:0.75;}
.status-pill.ok{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.08);color:var(--text);}
.status-pill.warn{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.10);color:var(--text);}
.status-pill.pending{border-color:rgba(148,163,184,.45);background:rgba(148,163,184,.10);color:var(--text);}
.row-actions{display:flex;justify-content:flex-end;}
.trash-btn{width:30px;height:30px;border-radius:10px;border:0.5px solid var(--border);background:var(--bg-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.trash-btn:hover{background:#FCEBEB;border-color:#F7C1C1;color:#791F1F;}
.trash-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* ---- modal (floating window) ---- */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.35);}
.modal-window{
  position:relative;z-index:1;
  width:min(760px, calc(100vw - 40px));
  max-width:100%;
  min-width:0;
  max-height:min(82vh, 760px);
  display:flex;flex-direction:column;
  overflow:hidden; /* keep rounded corners even with scrollbars */
  background:var(--bg);
  border:0.5px solid var(--border);
  border-radius:16px;
  box-shadow:0 18px 60px rgba(0,0,0,0.25);
}
/* 3.1 düzenleme: ana içerik kadar geniş olması yeterli; yatay kaydırma çıkmasın */
#edit-modal .modal-window{
  width:min(600px, calc(100vw - 32px));
}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:0.5px solid var(--border);background:var(--bg);}
.modal-title{font-size:14px;font-weight:600;color:var(--text);}
.modal-sub{font-size:12px;color:var(--text-secondary);margin-top:2px;line-height:1.5;}
.modal-actions{display:flex;gap:8px;align-items:center;}
.icon-btn{width:34px;height:34px;border-radius:10px;border:0.5px solid var(--border);background:var(--bg-secondary);cursor:pointer;}
.icon-btn:hover{background:var(--bg-tertiary);}
.modal-body{
  padding:18px 20px;
  flex:1 1 auto;
  min-width:0;
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.modal-flash{margin-bottom:12px;padding:10px 12px;border-radius:12px;font-size:12px;display:flex;align-items:center;gap:8px;border:0.5px solid transparent;}
.modal-flash.ok{background:var(--green-50);color:var(--green-800);border-color:var(--green-100);}
.modal-flash.err{background:#FCEBEB;color:#791F1F;border-color:#F7C1C1;}
.modal-window.slim{width:min(420px, calc(100vw - 40px));max-height:unset;overflow:visible;display:block;}
.modal-window.slim .modal-head{border-bottom:none;align-items:center;border-radius:16px;}
.modal-window.slim .modal-actions{align-self:stretch;display:flex;align-items:flex-start;}
.modal-window.slim .icon-btn{margin-top:2px;}
.success-badge{width:44px;height:44px;border-radius:14px;background:var(--green-50);border:0.5px solid var(--green-100);display:flex;align-items:center;justify-content:center;color:var(--green-800);flex:0 0 auto;}
.success-badge svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.success-row{display:flex;align-items:center;gap:12px;}
.success-text{flex:1;}
.success-title{font-size:14px;font-weight:650;color:var(--text);margin-bottom:2px;}
.success-sub{font-size:12px;color:var(--text-secondary);line-height:1.5;}
.kv-table{width:100%;border-collapse:separate;border-spacing:0 8px;}
.kv-table td{vertical-align:top;}
.kv-k{width:220px;font-size:12px;font-weight:500;color:var(--text-secondary);padding:10px 12px;background:var(--bg-secondary);border:0.5px solid var(--border);border-right:none;border-radius:12px 0 0 12px;}
.kv-v{font-size:12px;color:var(--text);padding:10px 12px;background:var(--bg);border:0.5px solid var(--border);border-left:none;border-radius:0 12px 12px 0;}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:0.5px solid var(--border);background:var(--bg);}
.modal-window.slim .modal-footer{border-radius:0 0 16px 16px;}
.save-feedback-badge{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
.save-feedback-badge svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.save-feedback-badge.ok{background:var(--green-50);border:0.5px solid var(--green-100);color:var(--green-800);}
.save-feedback-badge.err{background:#FCEBEB;border:0.5px solid #F7C1C1;color:#791F1F;}
.save-feedback-badge.warn{background:#FEF9EC;border:0.5px solid #F6E08A;color:#7A5200;}
.save-feedback-badge.loading{background:var(--bg-secondary);border:0.5px solid var(--border);color:var(--text-secondary);}
.btn-danger{background:#CC2B2B;color:#fff;border:none;}
.btn-danger:hover{background:#a82222;}
.save-feedback-badge.loading svg{animation:save-feedback-spin 0.85s linear infinite;}
@keyframes save-feedback-spin{to{transform:rotate(360deg);}}
.save-feedback-window.is-loading .save-feedback-footer,
.save-feedback-window.is-loading .save-feedback-actions{display:none;}

/* ---- content ---- */
.content{padding:36px 40px;overflow-y:auto;overflow-x:hidden;background:var(--bg-tertiary);min-width:0;}
.cat-eyebrow{margin-bottom:15px;display:flex;align-items:center;}
.cat-title{font-size:22px;font-weight:500;color:var(--text);letter-spacing:-0.4px;margin-bottom:6px;}
.cat-desc{font-size:13px;color:var(--text-secondary);line-height:1.7;margin-bottom:28px;}
.cat-desc ul,.cat-desc ol{padding-left:20px;margin:6px 0 10px;}
.cat-desc li{margin-bottom:3px;}
.form-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;}
.form-section-title{font-size:10px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px;padding-bottom:10px;border-bottom:0.5px solid var(--border);}
.form-card[data-f35-spend-card="1"] .form-section-title{margin-bottom:10px;}
.form-subsection-title{font-size:12px;font-weight:600;color:var(--text);margin:14px 0 12px;padding:0;border:none;text-transform:none;letter-spacing:0;display:flex;align-items:center;flex-wrap:wrap;gap:6px;line-height:1.3;}
.form-subsection-title .tt{margin-left:0;}
.f33-tw-toggle.field{margin-bottom:12px;}
.f33-tw-toggle > label{display:flex!important;flex-direction:row;align-items:flex-start;gap:10px;cursor:pointer;font-weight:500;margin-bottom:0;line-height:1.45;}
.f33-tw-toggle > label input[type="checkbox"]{margin-top:0;flex-shrink:0;width:16px;height:16px;}
.f33-tw-toggle .f33-tw-copy{flex:1;min-width:0;}
.field{margin-bottom:20px;}
.field:last-child{margin-bottom:0;}
.field label{display:block;font-size:12px;font-weight:500;color:var(--text);margin-bottom:5px;}
.field label .req{color:#D85A30;margin-left:1px;}
.field label .hint{font-weight:400;color:var(--text-secondary);margin-left:6px;}
.tt{
  position:relative;
  display:inline-flex;
  align-items:center;
  margin-left:6px;
  vertical-align:middle;
}
.tt .tt-i{
  width:14px;height:14px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:9px;line-height:1;
  color:var(--text-secondary);
  background:var(--bg-secondary);
  border:0.5px solid var(--border);
  cursor:help;
  flex-shrink:0;
}
.tt .tt-i:focus-visible{
  outline:2px solid var(--green-400);
  outline-offset:2px;
}
.tt::after{display:none;}
.ghg-label-tooltip{
  position:fixed;
  z-index:10000;
  max-width:min(300px, calc(100vw - 24px));
  max-height:220px;
  overflow:auto;
  overflow-wrap:anywhere;
  word-wrap:break-word;
  background:var(--bg);
  border:0.5px solid var(--border);
  border-radius:12px;
  padding:9px 11px;
  font-size:11px;
  font-weight:400;
  line-height:1.45;
  color:var(--text);
  box-shadow:0 18px 60px rgba(0,0,0,0.18);
  pointer-events:none;
  white-space:normal;
  text-transform:none;
  letter-spacing:normal;
}
.ghg-label-tooltip.hidden{display:none;}
.grid-2 .field > label,
.grid-3 .field > label,
.grid-4 .field > label,
.grid-5 .field > label{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:0;
  line-height:1.2;
}
.field label sub,
.field label sup{line-height:0;}
.field-ghost{visibility:hidden;}
.dtree{display:flex;flex-direction:column;gap:12px;margin-top:10px;font-size:12px;}
.dtree-desc{
  font-size:11.5px;
  color:var(--text-secondary);
  line-height:1.6;
  margin:10px 0 0;
  padding:8px 10px;
  border-radius:12px;
  background:var(--bg-secondary);
  border:0.5px solid var(--border);
}
.dtree .field label{font-size:11.5px;margin-bottom:8px;}
.dtree-row{display:flex;flex-direction:column;gap:8px;}
.dtree .field-help{font-size:11px;color:var(--text-secondary);line-height:1.5;margin-top:6px;}
.dtree-result{display:flex;justify-content:flex-start;margin-top:0;}
.dtree-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border-radius:999px;border:0.5px solid var(--border);background:var(--bg-secondary);font-size:11.5px;color:var(--text);}
.dtree-pill.ok{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.08);}
.dtree-pill.warn{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.10);}
.dtree-pill.pending{border-color:rgba(148,163,184,.45);background:rgba(148,163,184,.10);}

/* ---- autocomplete (custom dropdown) ---- */
.ac-wrap{position:relative;min-width:0;}
.ac-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  max-height:260px;
  overflow:auto;
  background:var(--bg);
  border:0.5px solid var(--border);
  border-radius:12px;
  box-shadow:0 18px 60px rgba(0,0,0,0.18);
  z-index:50;
  padding:6px;
}
.ac-item{
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  font-size:12px;
  color:var(--text);
}
.ac-item:hover{background:var(--bg-secondary);}
.ac-item.active{background:var(--bg-tertiary);}
.grid-1{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;padding-bottom:20px;}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.grid-4{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;}
.grid-5{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;}
.f33-commute-chain-disabled{opacity:0.55;}
.grid-1 > *,.grid-2 > *,.grid-3 > *,.grid-4 > *,.grid-5 > *{min-width:0;}
.upload-zone{border:0.5px dashed var(--border-md);border-radius:var(--radius-md);padding:24px;text-align:center;cursor:pointer;background:var(--bg-secondary);transition:border-color 0.15s;}
.upload-zone:hover,.upload-zone.drag{border-color:var(--green-400);}
.upload-zone p{font-size:12px;color:var(--text-secondary);margin-top:6px;}
.upload-zone .link{color:var(--green-600);}
.file-list{margin-top:10px;display:flex;flex-direction:column;gap:6px;}
.file-item{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:0.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;}
.file-item .fname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);}
.file-item .fsize{color:var(--text-secondary);font-size:11px;font-family:var(--mono);white-space:nowrap;}
.file-item .rm{cursor:pointer;color:var(--text-secondary);font-size:16px;line-height:1;flex-shrink:0;}
.file-item .rm:hover{color:#A32D2D;}
.form-footer{display:flex;justify-content:flex-end;align-items:center;background:transparent;border:none;border-radius:0;padding:0;margin-top:16px;}
.footer-status{font-size:12px;color:var(--text-secondary);}
.footer-status.saved{color:var(--green-600);font-weight:500;}
.btn-group{display:flex;gap:8px;}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:320px;color:var(--text-secondary);text-align:center;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:40px;}
.empty-state svg{opacity:0.3;margin-bottom:12px;}
.empty-state p{font-size:13px;line-height:1.6;}
.empty-code{font-family:var(--mono);font-size:11px;background:var(--bg-secondary);border:0.5px solid var(--border);border-radius:var(--radius-sm);padding:2px 7px;color:var(--text-secondary);margin-top:4px;display:inline-block;}

