/* DesignMind — styles.css
   Extracted from designmind-v10 (35).html
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#F7F4EF;--bg2:#EDE8DF;--white:#FDFCFA;
  --ink:#1C1A17;--ink2:#2E2B26;
  --muted:#8C8479;--muted2:#B5AFA6;
  --border:rgba(28,26,23,.10);--border2:rgba(28,26,23,.18);
  --gold:#B8884A;--gold-lt:#D4AA72;--gold-bg:rgba(184,136,74,.08);
  --sage:#5E7260;--sage-bg:rgba(94,114,96,.08);
  --rust:#A84D3A;--rust-bg:rgba(168,77,58,.08);
  --blue:#3A6B8A;--blue-bg:rgba(58,107,138,.08);
  --r:12px;--sh:0 2px 20px rgba(28,26,23,.07);--shl:0 8px 40px rgba(28,26,23,.13);
}
body{background:var(--bg);color:var(--ink);font-family:'Outfit',sans-serif;font-weight:300;min-height:100vh;overflow-x:hidden;}

/* ── AUTH SCREEN ─────────────────────────────────────────── */
#s-home{display:none;position:fixed;inset:0;z-index:9999;overflow-y:auto;background:linear-gradient(145deg,#1C1A17 0%,#2E2B26 50%,#1C1A17 100%);}
#s-home.on{display:flex;flex-direction:column;}
.hp-hero{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px;min-height:100%;position:relative;}
.hp-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(184,136,74,.12) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(94,114,96,.08) 0%,transparent 50%);pointer-events:none;}
.hp-layout{display:flex;width:100%;max-width:860px;border-radius:20px;overflow:visible;box-shadow:0 32px 100px rgba(0,0,0,.55);position:relative;z-index:1;}
.hp-right{flex:1;background:#FDFCFA;display:flex;flex-direction:column;min-width:0;border-radius:0 20px 20px 0;overflow:hidden;position:relative;max-height:88vh;}
.hp-left{flex:0 0 320px;background:linear-gradient(160deg,#2E2B26 0%,#1C1A17 100%);padding:40px 36px;display:flex;flex-direction:column;justify-content:space-between;}
.hp-left-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px;}
.hp-left-dot{width:9px;height:9px;border-radius:50%;background:var(--gold);flex-shrink:0;}
.hp-left-name{font-family:'Fraunces',serif;font-size:1.3rem;color:#F7F4EF;font-weight:300;}
.hp-left-tagline{font-family:'Fraunces',serif;font-size:1.75rem;font-weight:300;color:#F7F4EF;line-height:1.25;letter-spacing:-.5px;margin-bottom:14px;}
.hp-left-tagline em{color:var(--gold);font-style:italic;}
.hp-left-sub{font-size:.74rem;color:rgba(247,244,239,.42);line-height:1.7;margin-bottom:24px;}
.hp-features{display:flex;flex-direction:column;gap:9px;}
.hp-feat{display:flex;align-items:center;gap:9px;font-size:.7rem;color:rgba(247,244,239,.5);}
.hp-feat-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.7;flex-shrink:0;}
.hp-tabs{display:flex;border-bottom:1px solid var(--border);}
.hp-tab{flex:1;padding:14px 10px;font-size:.77rem;font-weight:500;text-align:center;cursor:pointer;color:var(--muted);transition:all .2s;background:transparent;border:none;font-family:'Outfit',sans-serif;letter-spacing:.3px;}
.hp-tab.on{color:var(--ink);border-bottom:2px solid var(--gold);background:rgba(184,136,74,.03);}
.hp-body{padding:22px 26px 18px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.hp-title{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:300;margin-bottom:3px;color:var(--ink);}
.hp-sub{font-size:.7rem;color:var(--muted);margin-bottom:18px;line-height:1.6;}
.hp-section-label{font-size:.58rem;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;margin:14px 0 9px;padding-bottom:5px;border-bottom:1px solid var(--border);}
.hp-footer{padding:10px 26px 14px;border-top:1px solid var(--border);text-align:center;font-size:.62rem;color:var(--muted2);line-height:1.6;}
.hp-divider{text-align:center;color:var(--muted2);font-size:.66rem;margin:11px 0;position:relative;}
.hp-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);}
.hp-divider span{background:#FDFCFA;padding:0 10px;position:relative;}
.fi-wrap{position:relative;margin-bottom:12px;}
.fi-wrap .fl{font-size:.6rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px;}
.fi-wrap .fi{transition:border-color .2s,box-shadow .2s;}
.fi-wrap .fi:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,136,74,.12);}
.pwd-strength{height:3px;border-radius:2px;margin-top:4px;transition:all .3s;background:var(--border);width:0;}
.pwd-strength.weak{background:#A84D3A;width:33%;}
.pwd-strength.medium{background:#B8884A;width:66%;}
.pwd-strength.strong{background:#5E7260;width:100%;}
.fi-icon-wrap{position:relative;}
.fi-icon-wrap .fi{padding-right:38px;}
.fi-icon-wrap .fi-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted2);font-size:.75rem;padding:4px;}
.phone-row{display:flex;gap:7px;align-items:center;}
.phone-cc{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 9px;font-size:.76rem;color:var(--muted);font-family:'Outfit',sans-serif;white-space:nowrap;flex-shrink:0;}
.hp-submit{width:100%;padding:11px;border:none;border-radius:10px;background:var(--ink);color:var(--bg);font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.3px;margin-top:4px;}
.hp-submit:hover:not(:disabled){background:#3D2B1F;transform:translateY(-1px);box-shadow:0 6px 20px rgba(28,26,23,.2);}
.hp-submit.green{background:#5E7260;}
.hp-submit.green:hover:not(:disabled){background:#4A5A4C;}
.hp-submit:disabled{opacity:.5;cursor:not-allowed;}
.hp-inline-err{font-size:.67rem;color:#A84D3A;margin-top:4px;display:none;}
.hp-inline-err.show{display:block;}
.hp-hp-trap{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none;}
.hp-hp-trap input{width:1px;height:1px;border:none;padding:0;margin:0;}
@media(max-width:700px){
  .hp-layout{flex-direction:column;border-radius:0;box-shadow:none;min-height:100vh;}
  .hp-left{display:none;}
  .hp-right{min-height:100vh;border-radius:0;}
  .hp-body{padding:18px 20px 14px;max-height:none;}
  .hp-footer{padding:8px 20px 14px;}
}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:rgba(247,244,239,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 48px;height:64px;display:flex;align-items:center;justify-content:space-between;}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;}
.logo-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);}
.logo-name{font-family:'Fraunces',serif;font-size:1.35rem;color:var(--ink);font-weight:400;letter-spacing:-.5px;}
.logo-tag{font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:var(--muted);}
.nav-links{display:flex;gap:6px;list-style:none;}
.nlink{font-size:.82rem;color:var(--muted);padding:6px 14px;border-radius:100px;cursor:pointer;transition:all .2s;}
.nlink:hover{color:var(--ink);background:var(--bg2);}
.nlink.active{color:var(--gold);background:var(--gold-bg);font-weight:500;}
.nav-av{width:34px;height:34px;border-radius:50%;background:var(--ink2);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:500;cursor:pointer;}

/* PAGE */
.page{max-width:1280px;margin:0 auto;padding:44px 48px;}
.scr{display:none;}

/* ── PRINT STYLES ── */
@media print{
  body > *:not(.page){display:none!important;}
  .page{display:block!important;}
  .scr{display:none!important;}
  .scr.on{display:block!important;}
  .nav,#bottomNav,.home-widgets,.s-head .btn,.s-head .btn-ghost,
  .boq-toolbar,.boq-main-tabs,#boq-proj-sel,.boq-ai-btn,
  .boq-act-btns,.boq-drag-handle,.ord-pill,
  .search-wrap,.stats,.proj-filter-pill,
  button[onclick*="goHome"],button[onclick*="openBOQ"],
  .pd-quick-btns,#sp4wf,.wf{display:none!important;}
  #s-boq{padding:0!important;}
  .boq-summary{grid-template-columns:repeat(4,1fr)!important;}
  .boq-tbl-wrap{overflow:visible!important;}
  table{width:100%!important;font-size:9pt!important;border-collapse:collapse!important;}
  th,td{border:1px solid #ddd!important;padding:4px 6px!important;}
  thead{background:#1C1A17!important;color:white!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;}
  .misc-row{background:#f9f6f2!important;}
  .total-row td{font-weight:bold!important;border-top:2px solid #333!important;}
  .boq-section-group{page-break-inside:avoid;}
  #boq-sub{font-size:11pt!important;font-weight:600!important;margin-bottom:8px!important;}
  @page{margin:15mm;size:A4 landscape;}
}
.scr.on{display:block;animation:fadeup .35s cubic-bezier(.22,1,.36,1);}
@keyframes fadeup{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}

/* ── HOME WIDGETS ROW ── */
.home-widgets{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;}
@media(max-width:900px){.home-widgets{grid-template-columns:1fr;}}
.hw-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--sh);}
.hw-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;border-bottom:1px solid var(--border);}
.hw-title{font-family:'Fraunces',serif;font-size:1rem;font-weight:300;color:var(--ink);}
.hw-title em{color:var(--gold);font-style:italic;}
.hw-body{padding:14px 18px;}
.exp-entries{max-height:220px;overflow-y:auto;margin-bottom:10px;}
.exp-entry{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.exp-entry:last-child{border-bottom:none;}
.exp-badge{font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:100px;flex-shrink:0;margin-top:2px;text-transform:uppercase;letter-spacing:.5px;}
.exp-badge.income{background:rgba(94,114,96,.12);color:#5E7260;}
.exp-badge.expense{background:rgba(168,77,58,.1);color:#A84D3A;}
.exp-note{font-size:.78rem;color:var(--ink);flex:1;line-height:1.5;}
.exp-amt{font-family:'Fraunces',serif;font-size:.9rem;font-weight:400;flex-shrink:0;}
.exp-amt.income{color:#5E7260;}
.exp-amt.expense{color:#A84D3A;}
.exp-date{font-size:.62rem;color:var(--muted2);margin-top:2px;}
.exp-add-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.exp-summary{display:flex;gap:12px;padding:8px 0 4px;border-top:1px solid var(--border);margin-top:6px;}
.exp-sum-item{font-size:.7rem;color:var(--muted);}
.exp-sum-item strong{font-family:'Fraunces',serif;font-size:.9rem;font-weight:400;}
.gtd-list{max-height:220px;overflow-y:auto;margin-bottom:10px;}
.gtd-item{display:flex;align-items:flex-start;gap:9px;padding:8px 0;border-bottom:1px solid var(--border);}
.gtd-item:last-child{border-bottom:none;}
.gtd-cb{width:18px;height:18px;border-radius:5px;border:2px solid var(--border);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;transition:all .15s;margin-top:1px;}
.gtd-cb.done{background:var(--sage);border-color:var(--sage);color:white;}
.gtd-text{flex:1;font-size:.78rem;color:var(--ink);line-height:1.5;}
.gtd-text.done{text-decoration:line-through;color:var(--muted2);}
.gtd-meta{font-size:.62rem;color:var(--muted);margin-top:2px;}
.gtd-proj-tag{display:inline-block;background:var(--gold-bg);color:var(--gold);font-size:.58rem;font-weight:600;padding:1px 6px;border-radius:100px;margin-top:2px;}
.gtd-due-warn{color:#A84D3A;font-weight:600;}
.gtd-due-today{color:#B8884A;font-weight:600;}

/* PROJECTS */
.s-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:30px;}
.s-title{font-family:'Fraunces',serif;font-size:2.5rem;font-weight:300;letter-spacing:-1px;line-height:1.1;}
.s-title em{font-style:italic;color:var(--gold);}
.s-sub{font-size:.84rem;color:var(--muted);margin-top:4px;}
.stats{display:flex;gap:11px;margin-bottom:24px;flex-wrap:wrap;}
.stat{background:var(--white);border:1px solid var(--border);border-radius:100px;padding:8px 16px;display:flex;align-items:center;gap:8px;font-size:.77rem;color:var(--muted);box-shadow:var(--sh);}
.stat strong{font-family:'Fraunces',serif;font-size:1rem;color:var(--ink);font-weight:400;}
.sdot{width:6px;height:6px;border-radius:50%;}
.search-wrap{position:relative;margin-bottom:22px;}
.search-inp{width:100%;max-width:340px;background:var(--white);border:1px solid var(--border);border-radius:100px;padding:9px 15px 9px 36px;font-family:'Outfit',sans-serif;font-size:.82rem;color:var(--ink);outline:none;transition:all .2s;box-shadow:var(--sh);}
.search-inp:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,136,74,.1);}
.search-inp::placeholder{color:var(--muted2);}
.search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted2);font-size:.83rem;}
.proj-filter-pill{background:var(--white);border:1px solid var(--border);border-radius:100px;padding:6px 14px;font-size:.72rem;color:var(--muted);cursor:pointer;transition:all .18s;font-family:'Outfit',sans-serif;white-space:nowrap;}
.proj-filter-pill:hover{border-color:var(--gold);color:var(--gold);}
.proj-filter-pill.on{background:var(--ink);border-color:var(--ink);color:var(--bg);font-weight:500;}
.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:17px;}
.pc{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:all .28s cubic-bezier(.22,1,.36,1);box-shadow:var(--sh);}
.pc:hover{transform:translateY(-4px);box-shadow:var(--shl);border-color:var(--border2);}
.pc-ban{height:86px;display:flex;align-items:center;padding:0 20px;position:relative;overflow:hidden;}
.pc-ban::before{content:'';position:absolute;inset:0;opacity:.93;}
.b-flat::before{background:linear-gradient(135deg,#D4AA72,#B8884A);}
.b-villa::before{background:linear-gradient(135deg,#7A9E7C,#5E7260);}
.b-office::before{background:linear-gradient(135deg,#6B9AB8,#3A6B8A);}
.b-commercial::before{background:linear-gradient(135deg,#9A7EC4,#7059A0);}
.b-other::before{background:linear-gradient(135deg,#A0A0A0,#6A6A6A);}
.pc-ico{font-size:1.9rem;position:relative;z-index:1;}
.pc-type{position:relative;z-index:1;margin-left:10px;color:rgba(255,255,255,.85);font-size:.62rem;letter-spacing:3px;text-transform:uppercase;font-weight:500;}
.pc-body{padding:15px 19px 17px;}
.pc-name{font-family:'Fraunces',serif;font-size:1.12rem;font-weight:400;color:var(--ink);margin-bottom:2px;letter-spacing:-.3px;}
.pc-det{font-size:.7rem;color:var(--muted);margin-bottom:11px;}
.pc-pt{display:flex;justify-content:space-between;font-size:.66rem;color:var(--muted);margin-bottom:5px;}
.pc-ph{font-weight:500;color:var(--ink2);}
.ptr{height:4px;background:var(--bg2);border-radius:10px;overflow:hidden;}
.ptf{height:100%;border-radius:10px;}
.pf-gold{background:linear-gradient(90deg,var(--gold),var(--gold-lt));}
.pf-sage{background:linear-gradient(90deg,#5E7260,#7A9E7C);}
.pf-blue{background:linear-gradient(90deg,#3A6B8A,#6B9AB8);}
.pf-rust{background:linear-gradient(90deg,#A84D3A,#C47A6B);}
.pc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:11px;}
.ppill{font-size:.58rem;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:100px;font-weight:500;}
.pp-gold{background:var(--gold-bg);color:var(--gold);}
.pp-sage{background:var(--sage-bg);color:var(--sage);}
.pp-blue{background:var(--blue-bg);color:var(--blue);}
.pp-rust{background:var(--rust-bg);color:var(--rust);}
.carr{width:24px;height:24px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.68rem;color:var(--muted);transition:all .3s;}
.pc:hover .carr{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.add-card{background:transparent;border:2px dashed var(--border2);border-radius:var(--r);min-height:190px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .28s;flex-direction:column;gap:8px;}
.add-card:hover{border-color:var(--gold);background:var(--gold-bg);}
.aci{width:41px;height:41px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .28s;}
.add-card:hover .aci{background:var(--gold);border-color:var(--gold);}
.act{font-size:.8rem;color:var(--muted);transition:color .28s;}
.add-card:hover .act{color:var(--gold);}

/* BUTTONS */
.btn{background:var(--ink);border:none;color:var(--bg);font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:500;padding:10px 22px;border-radius:100px;cursor:pointer;transition:all .22s;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;}
.btn:hover{background:var(--gold);transform:translateY(-1px);box-shadow:var(--shl);}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:'Outfit',sans-serif;font-size:.82rem;padding:10px 19px;border-radius:100px;cursor:pointer;transition:all .2s;}
.btn-ghost:hover{border-color:var(--border2);color:var(--ink);}
.btn-sm{padding:7px 15px;font-size:.74rem;}
.btn-outline{background:transparent;border:1.5px solid var(--gold);color:var(--gold);font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:500;padding:8px 18px;border-radius:100px;cursor:pointer;transition:all .2s;}
.btn-outline:hover{background:var(--gold);color:white;}

/* MODAL */
.ovl{position:fixed;inset:0;background:rgba(28,26,23,.52);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .28s;}
.ovl.open{opacity:1;pointer-events:all;}
.modal{background:var(--white);border-radius:20px;width:100%;max-width:480px;box-shadow:0 24px 80px rgba(28,26,23,.2);transform:translateY(18px) scale(.97);transition:transform .32s cubic-bezier(.22,1,.36,1);overflow:hidden;}
.ovl.open .modal{transform:none;}
.mh{padding:23px 27px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;}
.mt{font-family:'Fraunces',serif;font-size:1.38rem;font-weight:400;letter-spacing:-.5px;}
.ms{font-size:.74rem;color:var(--muted);margin-top:3px;}
.mx{width:27px;height:27px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--muted);transition:all .2s;}
.mx:hover{background:var(--ink);color:var(--bg);}
.mb{padding:21px 27px;}
.mf{padding:14px 27px 21px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;}
.fl{display:block;font-size:.67rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.fi{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-family:'Outfit',sans-serif;font-size:.85rem;color:var(--ink);outline:none;transition:all .2s;}
.fi:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,136,74,.1);}
.fi::placeholder{color:var(--muted2);}
.fg{margin-bottom:16px;}
.prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.po{border:1.5px solid var(--border);border-radius:9px;padding:11px 7px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg);}
.po:hover,.po.sel{border-color:var(--gold);background:var(--gold-bg);}
.po.sel{box-shadow:0 0 0 2px rgba(184,136,74,.14);}
.po-ico{font-size:1.55rem;margin-bottom:4px;display:block;}
.po-name{font-size:.7rem;font-weight:500;color:var(--ink2);}
.po-sub{font-size:.6rem;color:var(--muted);margin-top:1px;}

/* WIZARD */
.wiz{max-width:960px;margin:0 auto;}
.bc{display:flex;align-items:center;gap:7px;font-size:.74rem;color:var(--muted);margin-bottom:24px;}
.bcl{cursor:pointer;transition:color .2s;}.bcl:hover{color:var(--gold);}
.bcs{color:var(--muted2);}.bcc{color:var(--ink);font-weight:500;}
.stepper{display:flex;align-items:flex-start;margin-bottom:38px;position:relative;}
.stepper::before{content:'';position:absolute;top:16px;left:17px;right:17px;height:1px;background:var(--border2);z-index:0;}
.step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;position:relative;z-index:1;}
.sc{width:32px;height:32px;border-radius:50%;border:2px solid var(--border2);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:.76rem;color:var(--muted);font-weight:500;transition:all .35s;}
.step.on .sc{border-color:var(--gold);background:var(--gold);color:white;box-shadow:0 0 0 4px rgba(184,136,74,.13);}
.step.done .sc{border-color:var(--sage);background:var(--sage);color:white;}
.sl{font-size:.61rem;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);text-align:center;max-width:72px;line-height:1.3;transition:color .3s;}
.step.on .sl{color:var(--gold);font-weight:500;}
.step.done .sl{color:var(--sage);}
.sp{display:none;}.sp.on{display:block;animation:fadeup .28s cubic-bezier(.22,1,.36,1);}
.wh{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:300;letter-spacing:-.7px;margin-bottom:6px;}
.wh em{font-style:italic;color:var(--gold);}
.wd{font-size:.84rem;color:var(--muted);line-height:1.7;margin-bottom:24px;max-width:540px;}
.uz{border:2px dashed var(--border2);border-radius:13px;padding:44px 32px;text-align:center;cursor:pointer;transition:all .28s;background:var(--white);position:relative;overflow:hidden;}
.uz:hover,.uz.drag{border-color:var(--gold);background:var(--gold-bg);}
.uz input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.uz-ico{font-size:2.4rem;margin-bottom:10px;display:block;opacity:.4;transition:all .28s;}
.uz:hover .uz-ico,.uz.drag .uz-ico{opacity:1;transform:scale(1.07);}
.uz-t{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:300;margin-bottom:5px;}
.uz-s{font-size:.78rem;color:var(--muted);margin-bottom:12px;line-height:1.5;}
.fmts{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;}
.ftag{background:var(--bg2);border:1px solid var(--border);color:var(--muted);font-size:.58rem;letter-spacing:1.5px;text-transform:uppercase;padding:3px 9px;border-radius:100px;}
.up-prev{margin-top:15px;background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.uphd{padding:11px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.up-fi{width:32px;height:32px;border-radius:7px;background:var(--gold-bg);border:1px solid rgba(184,136,74,.2);display:flex;align-items:center;justify-content:center;font-size:.85rem;}
.up-inf{flex:1;}
.up-fn{font-size:.8rem;font-weight:500;color:var(--ink);}
.up-fm{font-size:.65rem;color:var(--muted);margin-top:2px;}
.up-rm{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:.78rem;transition:color .2s;}
.up-rm:hover{color:var(--rust);}
.bp-img{width:100%;max-height:260px;object-fit:contain;padding:12px;background:var(--bg2);}
.bp-msg{padding:15px;text-align:center;font-size:.78rem;color:var(--muted);background:var(--bg2);}
.skip-row{display:flex;align-items:center;gap:11px;margin-top:18px;}
.skip-d{flex:1;height:1px;background:var(--border);}
.skip-t{font-size:.71rem;color:var(--muted2);}
.scope-tip{background:linear-gradient(135deg,var(--gold-bg),rgba(94,114,96,.05));border:1px solid rgba(184,136,74,.2);border-radius:11px;padding:15px 19px;margin-bottom:20px;display:flex;gap:12px;align-items:flex-start;}
.stn-ico{font-size:1.25rem;flex-shrink:0;}
.stn-title{font-size:.83rem;font-weight:500;color:var(--ink);margin-bottom:3px;}
.stn-desc{font-size:.76rem;color:var(--muted);line-height:1.55;}
.stn-btns{display:flex;gap:8px;margin-top:9px;}
.rg{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:12px;}
.rc{background:var(--white);border:1.5px solid var(--border);border-radius:10px;overflow:hidden;transition:all .2s;}
.rc.ren{border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,136,74,.11);}
.rc.exp{opacity:.55;}
.rc-hd{padding:11px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.rc-ico{width:28px;height:28px;border-radius:6px;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;}
.rc-num{font-size:.59rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.rc-body{padding:11px 13px;display:flex;flex-direction:column;gap:8px;}
.rlbl{font-size:.61rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:2px;display:block;}
.ri{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 9px;font-family:'Outfit',sans-serif;font-size:.78rem;color:var(--ink);outline:none;transition:all .2s;}
.ri:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,136,74,.1);}
.ri::placeholder{color:var(--muted2);}
.rdims{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:4px;}
.rx{font-size:.75rem;color:var(--muted);text-align:center;}
.rc-ft{padding:8px 13px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.rtog{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.73rem;font-weight:500;user-select:none;}
.rtbox{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:.58rem;transition:all .2s;color:transparent;flex-shrink:0;}
.rtog.chk .rtbox{background:var(--gold);border-color:var(--gold);color:white;}
.rtlbl{color:var(--muted);transition:color .2s;}
.rtog.chk .rtlbl{color:var(--gold);}
.add-room-btn{background:transparent;border:1.5px dashed var(--border2);border-radius:10px;width:100%;padding:16px;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;color:var(--muted);font-family:'Outfit',sans-serif;font-size:.78rem;transition:all .2s;margin-top:10px;}
.add-room-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}

/* BRIEF */
.btabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:22px;}
.btab{padding:9px 20px;font-family:'Outfit',sans-serif;font-size:.82rem;color:var(--muted);background:none;border:none;cursor:pointer;transition:color .2s;border-bottom:2px solid transparent;margin-bottom:-1px;}
.btab:hover{color:var(--ink);}
.btab.on{color:var(--gold);border-bottom-color:var(--gold);font-weight:500;}
.bpan{display:none;}.bpan.on{display:block;animation:fadeup .28s ease;}
.bg2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.bs{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.bs.full{grid-column:1/-1;}
.bsh{padding:11px 15px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.bshi{width:25px;height:25px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.78rem;}
.bsht{font-size:.77rem;font-weight:500;color:var(--ink);}
.bsb{padding:13px 15px;display:flex;flex-direction:column;gap:10px;}
.bfl{font-size:.63rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:3px;display:block;}
.bfi,.bft,.bfs{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:8px 11px;font-family:'Outfit',sans-serif;font-size:.79rem;color:var(--ink);outline:none;transition:all .2s;}
.bfi:focus,.bft:focus,.bfs:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,136,74,.1);}
.bfi::placeholder,.bft::placeholder{color:var(--muted2);}
.bft{resize:vertical;min-height:68px;line-height:1.6;}
.bfs{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%238C8479' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;background-size:12px;cursor:pointer;}
.bfr{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.schips{display:flex;flex-wrap:wrap;gap:5px;}
.schip{background:var(--bg);border:1.5px solid var(--border);border-radius:100px;padding:4px 11px;font-size:.7rem;color:var(--muted);cursor:pointer;transition:all .18s;}
.schip:hover{border-color:var(--gold-lt);color:var(--gold);}
.schip.on{background:var(--gold-bg);border-color:var(--gold);color:var(--gold);font-weight:500;}
.rbc{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:12px;}
.rbch{padding:13px 16px;background:var(--bg2);display:flex;align-items:center;gap:9px;cursor:pointer;user-select:none;}
.rbch:hover{background:var(--bg);}
.rbc-emo{font-size:.95rem;}
.rbc-nm{font-family:'Fraunces',serif;font-size:.92rem;font-weight:400;flex:1;}
.rbc-sz{font-size:.67rem;color:var(--muted);background:var(--white);border:1px solid var(--border);padding:2px 7px;border-radius:100px;}
.rbc-tag{font-size:.57rem;letter-spacing:.8px;text-transform:uppercase;background:var(--gold-bg);color:var(--gold);border:1px solid rgba(184,136,74,.2);padding:2px 8px;border-radius:100px;}
.rbc-arr{color:var(--muted);font-size:.7rem;transition:transform .22s;margin-left:4px;}
.rbc-arr.open{transform:rotate(180deg);}
.rbc-body{display:none;padding:18px 17px;border-top:1px solid var(--border);}
.rbc-body.open{display:block;animation:fadeup .22s ease;}
.rf-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:13px;}
.rf-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:13px;}
.rf-1{margin-bottom:13px;}
.rfield label{display:block;font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:4px;}
.wf{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-top:28px;border-top:1px solid var(--border);}
.wf-l{font-size:.73rem;color:var(--muted);}
.wf-r{display:flex;gap:9px;}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:600;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .28s;}
.lb.open{opacity:1;pointer-events:all;}
.lb img{max-width:90vw;max-height:86vh;border-radius:8px;object-fit:contain;}
.lb-x{position:absolute;top:18px;right:22px;background:rgba(255,255,255,.1);border:none;color:white;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lb-x:hover{background:rgba(255,255,255,.2);}
.lb-caption{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.6);color:rgba(255,255,255,.8);padding:6px 16px;border-radius:100px;font-size:.73rem;white-space:nowrap;}

/* TOAST */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--ink2);color:var(--bg);padding:9px 18px;border-radius:100px;font-size:.76rem;opacity:0;transition:all .35s cubic-bezier(.22,1,.36,1);z-index:500;white-space:nowrap;box-shadow:var(--shl);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* MOBILE UI */
@media(min-width:769px) and (max-width:1000px){
  .nav{padding:0 20px;}
  .nav-links{gap:2px;}
  .nlink{font-size:.74rem;padding:5px 9px;}
  .logo-tag{display:none;}
}
@media(max-width:900px){
  .page{padding:20px 16px;}
  .nav{padding:0 16px;height:58px;}
  .bg2{grid-template-columns:1fr;}
  .rg{grid-template-columns:1fr 1fr;}
  .rf-grid{grid-template-columns:1fr 1fr;}
  .bfr{grid-template-columns:1fr;}
  .prof-grid{grid-template-columns:1fr;}
  .port-hero{padding:22px 18px;}
  #pg{grid-template-columns:1fr 1fr!important;}
  .boq-tbl-wrap{overflow-x:auto;}
  .boq-toolbar{flex-wrap:wrap;gap:8px;}
  .boq-main-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .boq-summary{grid-template-columns:repeat(2,1fr)!important;}
  #boq-proj-sel{width:100%!important;min-width:unset!important;}
}
@media(max-width:600px){
  .nav-links{display:none!important;}
  .s-head{flex-direction:column;align-items:flex-start;gap:10px;}
  .boq-act{width:32px!important;height:32px!important;font-size:.8rem!important;}
  .ph2-modal{max-width:100%;border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh;}
  .ph2-ovl{align-items:flex-end;padding:0;}
  .snag-grid{grid-template-columns:1fr!important;}
}
@media(max-width:580px){
  #renders-filters{grid-template-columns:1fr 1fr!important;}
  .logo-tag{display:none;}
  #pg{grid-template-columns:1fr!important;}
  .rg{grid-template-columns:1fr;}
  .stepper::before{display:none;}
  .sl{display:none;}
  .prop-grid{grid-template-columns:repeat(2,1fr);}
  .rf-grid,.rf-2{grid-template-columns:1fr;}
  .s-title{font-size:1.5rem;}
  .scr.on{padding-bottom:90px!important;}
  .page{padding-bottom:100px!important;}
  .fav-grid{grid-template-columns:repeat(2,1fr);}
  .port-proj-grid{grid-template-columns:1fr!important;}
  .lib-source-tabs{overflow-x:auto;padding-bottom:4px;flex-wrap:nowrap;}
  .lib-stab{white-space:nowrap;flex-shrink:0;}
}

/* BOTTOM NAV */
#bottomNav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:400;
  background:rgba(247,244,239,.97);backdrop-filter:blur(20px);
  border-top:1px solid var(--border);
  padding:8px 0 env(safe-area-inset-bottom,8px);
  box-shadow:0 -4px 20px rgba(28,26,23,.08);
}
@media(max-width:600px){
  #bottomNav.visible{display:flex!important;flex-direction:column;}
}
.bottom-nav-items{display:flex;justify-content:space-around;align-items:center;width:100%;}
.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 8px;cursor:pointer;border-radius:10px;transition:all .18s;min-width:52px;border:none;background:none;font-family:'Outfit',sans-serif;}
.bn-item.active .bn-icon{background:var(--ink);color:var(--bg);}
.bn-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .18s;background:transparent;}
.bn-label{font-size:.55rem;color:var(--muted);font-weight:500;letter-spacing:.3px;transition:color .18s;}
.bn-item.active .bn-label{color:var(--ink);}

/* PHASE 2: CLIENT RENDERS */
.ph2-ovl{position:fixed;inset:0;background:rgba(28,26,23,.55);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .28s;}
.ph2-ovl.open{opacity:1;pointer-events:all;}
.ph2-modal{background:#FDFCFA;border-radius:20px;width:100%;max-width:520px;box-shadow:0 24px 80px rgba(28,26,23,.2);transform:translateY(18px) scale(.97);transition:transform .32s cubic-bezier(.22,1,.36,1);overflow:hidden;max-height:90vh;overflow-y:auto;}
.ph2-ovl.open .ph2-modal{transform:none;}
.ph2-mh{padding:20px 24px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:#FDFCFA;z-index:1;}
.ph2-mt{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:400;letter-spacing:-.4px;}
.ph2-ms{font-size:.73rem;color:var(--muted);margin-top:3px;}
.ph2-mx{width:27px;height:27px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--muted);flex-shrink:0;transition:all .2s;}
.ph2-mx:hover{background:var(--ink);color:var(--bg);}
.ph2-mb{padding:18px 24px;}
.ph2-mf{padding:13px 24px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;background:#FDFCFA;}
.rh-sec{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:14px;box-shadow:0 2px 20px rgba(28,26,23,.07);}
.rh-sch{padding:13px 17px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);background:var(--bg2);cursor:pointer;user-select:none;}
.rh-sch-ico{width:30px;height:30px;border-radius:7px;background:#FDFCFA;display:flex;align-items:center;justify-content:center;font-size:.9rem;border:1px solid var(--border);flex-shrink:0;}
.rh-sch-title{font-family:'Fraunces',serif;font-size:.98rem;font-weight:400;flex:1;}
.rh-sch-meta{font-size:.68rem;color:var(--muted);}
.rh-sch-arr{color:var(--muted2);font-size:.7rem;transition:transform .2s;flex-shrink:0;}
.rh-sch.open .rh-sch-arr{transform:rotate(180deg);}
.rh-scb{padding:14px 17px;display:none;}
.rh-scb.open{display:block;}
.rh-uz{border:2px dashed var(--border2);border-radius:9px;padding:22px 16px;text-align:center;cursor:pointer;transition:all .22s;position:relative;background:var(--bg);}
.rh-uz:hover,.rh-uz.drag{border-color:var(--gold);background:var(--gold-bg);}
.rh-uz input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.rh-igrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px;margin-top:12px;}
.rh-item{position:relative;border-radius:9px;overflow:hidden;border:2px solid var(--border);background:var(--bg2);cursor:pointer;transition:all .22s;aspect-ratio:4/3;}
.rh-item:hover{border-color:var(--gold);box-shadow:0 8px 30px rgba(28,26,23,.13);}
.rh-item.approved{border-color:#5E7260;}
.rh-item.changes{border-color:#A84D3A;}
.rh-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s;}
.rh-item:hover img{transform:scale(1.04);}
.rh-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,26,23,.72) 0%,transparent 50%);opacity:0;transition:opacity .22s;}
.rh-item:hover .rh-ov{opacity:1;}
.rh-acts{position:absolute;bottom:7px;left:7px;right:7px;display:flex;gap:4px;transform:translateY(7px);opacity:0;transition:all .22s;}
.rh-item:hover .rh-acts{transform:none;opacity:1;}
.rha{flex:1;padding:5px 3px;border:none;border-radius:5px;font-family:'Outfit',sans-serif;font-size:.6rem;font-weight:600;cursor:pointer;transition:all .16s;display:flex;align-items:center;justify-content:center;gap:2px;white-space:nowrap;}
.rha-app{background:#5E7260;color:white;}.rha-app:hover{background:#4a5c4c;}
.rha-chg{background:#A84D3A;color:white;}.rha-chg:hover{background:#8a3d2e;}
.rha-ann{background:rgba(255,255,255,.9);color:var(--ink);}.rha-ann:hover{background:white;}
.rha-del{background:rgba(168,77,58,.8);color:white;}.rha-del:hover{background:#A84D3A;}
.rh-cmt-dot{position:absolute;top:6px;left:6px;width:18px;height:18px;border-radius:50%;background:#B8884A;color:white;font-size:.55rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px rgba(0,0,0,.3);}
.rh-status{position:absolute;top:6px;right:6px;}
.rh-stag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:100px;font-size:.58rem;font-weight:600;}
.rh-st-app{background:#5E7260;color:white;}
.rh-st-chg{background:#A84D3A;color:white;}
.rh-secnav{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:20px;}
.rh-snpill{background:#FDFCFA;border:1.5px solid var(--border);border-radius:100px;padding:6px 14px;font-size:.76rem;color:var(--muted);cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:5px;}
.rh-snpill:hover{border-color:var(--gold);color:var(--gold);}
.rh-snpill.on{border-color:var(--gold);background:var(--gold-bg);color:var(--gold);font-weight:500;}
.rh-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:22px;}
.rh-scard{background:#FDFCFA;border:1px solid var(--border);border-radius:11px;padding:14px;text-align:center;box-shadow:0 2px 20px rgba(28,26,23,.07);}
.rh-snum{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:300;line-height:1;}
.rh-slbl{font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:3px;}
.rh-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px;overflow-x:auto;}
.rh-tab{padding:10px 20px;font-family:'Outfit',sans-serif;font-size:.81rem;color:var(--muted);background:none;border:none;cursor:pointer;transition:all .18s;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;display:flex;align-items:center;gap:5px;}
.rh-tab:hover{color:var(--ink);}
.rh-tab.on{color:var(--gold);border-bottom-color:var(--gold);font-weight:500;}
.rh-tab .tc{background:var(--gold-bg);color:var(--gold);padding:1px 6px;border-radius:100px;font-size:.6rem;font-weight:600;}
.rh-tab.on .tc{background:var(--gold);color:white;}
.rh-pane{display:none;}.rh-pane.on{display:block;animation:fadeup .22s ease;}
.ann-wrap{display:grid;grid-template-columns:1fr 320px;min-height:440px;}
.ann-img-wrap{position:relative;background:#111;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:0 0 0 20px;}
.ann-img-wrap img{max-width:100%;max-height:480px;object-fit:contain;}
.ann-canvas{position:absolute;inset:0;}
.ann-sidebar{border-left:1px solid var(--border);display:flex;flex-direction:column;}
.ann-sh{padding:13px 15px;border-bottom:1px solid var(--border);font-size:.77rem;font-weight:500;}
.ann-cmts{flex:1;overflow-y:auto;padding:10px;}
.cmt-item{background:var(--bg2);border-radius:7px;padding:9px 11px;margin-bottom:7px;font-size:.74rem;border-left:3px solid var(--border);}
.cmt-item.designer{border-left-color:#B8884A;}
.cmt-item.client{border-left-color:#3A6B8A;}
.cmt-au{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px;}
.cmt-txt{color:var(--ink2);line-height:1.5;}
.cmt-time{font-size:.59rem;color:var(--muted2);margin-top:2px;}
.cmt-pin{display:inline-flex;align-items:center;gap:3px;background:var(--gold-bg);color:var(--gold);border-radius:100px;padding:2px 7px;font-size:.58rem;margin-bottom:4px;}
.ann-inp-area{padding:11px;border-top:1px solid var(--border);}
.ann-ta{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 9px;font-family:'Outfit',sans-serif;font-size:.76rem;color:var(--ink);outline:none;resize:none;min-height:50px;transition:border .18s;}
.ann-ta:focus{border-color:#B8884A;}
.ann-mode-row{display:flex;gap:5px;margin-bottom:7px;}
.ann-mode-btn{flex:1;padding:5px 7px;border:1.5px solid var(--border);border-radius:100px;font-size:.65rem;font-weight:500;cursor:pointer;transition:all .18s;background:var(--bg);text-align:center;}
.ann-mode-btn.on{border-color:#B8884A;background:var(--gold-bg);color:#B8884A;}
.cp-igrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:13px;}
.cp-item{border-radius:11px;overflow:hidden;border:2px solid var(--border);background:#FDFCFA;transition:all .25s;box-shadow:0 2px 20px rgba(28,26,23,.07);}
.cp-item:hover{transform:translateY(-3px);box-shadow:0 8px 40px rgba(28,26,23,.13);}
.cp-item.approved{border-color:#5E7260;}
.cp-item.changes{border-color:#A84D3A;}
.cp-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;cursor:pointer;}
.cp-body{padding:10px 12px;}
.cp-acts{display:flex;gap:5px;margin-top:9px;}
.cp-act{flex:1;padding:6px 5px;border:none;border-radius:7px;font-family:'Outfit',sans-serif;font-size:.7rem;font-weight:500;cursor:pointer;transition:all .18s;text-align:center;}
.cp-app{background:rgba(94,114,96,.1);color:#5E7260;border:1.5px solid rgba(94,114,96,.22);}
.cp-app:hover,.cp-app.on{background:#5E7260;color:white;}
.cp-chg{background:rgba(168,77,58,.08);color:#A84D3A;border:1.5px solid rgba(168,77,58,.2);}
.cp-chg:hover,.cp-chg.on{background:#A84D3A;color:white;}
.cp-chg-form{margin-top:9px;display:none;}
.cp-chg-form.open{display:block;}
.cp-ta{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 9px;font-family:'Outfit',sans-serif;font-size:.74rem;color:var(--ink);outline:none;resize:vertical;min-height:56px;transition:border .18s;}
.cp-ta:focus{border-color:#A84D3A;}
.share-box{background:linear-gradient(135deg,var(--ink2),#2A1F2E);border-radius:13px;padding:20px 22px;color:#F7F4EF;margin-bottom:20px;}
.secpill{display:inline-flex;align-items:center;gap:5px;background:var(--bg2);border:1px solid var(--border);border-radius:100px;padding:3px 9px 3px 5px;font-size:.7rem;color:var(--ink2);margin:2px;}
.secpill button{background:none;border:none;cursor:pointer;color:var(--muted2);font-size:.62rem;padding:0 1px;transition:color .14s;line-height:1;}
.secpill button:hover{color:#A84D3A;}
@media(max-width:860px){.ann-wrap{grid-template-columns:1fr;}.ann-sidebar{border-left:none;border-top:1px solid var(--border);}.rh-igrid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));}.cp-igrid{grid-template-columns:1fr 1fr;}}
@media(max-width:500px){.cp-igrid{grid-template-columns:1fr;}}

/* PHASE 3: BOQ */
.boq-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px;}
.boq-seg{display:flex;background:var(--bg2);border:1px solid var(--border);border-radius:100px;padding:3px;gap:2px;}
.boq-seg-btn{padding:6px 16px;border:none;border-radius:100px;font-family:'Outfit',sans-serif;font-size:.77rem;cursor:pointer;transition:all .18s;background:transparent;color:var(--muted);}
.boq-seg-btn.on{background:#FDFCFA;color:var(--ink);font-weight:500;box-shadow:0 1px 6px rgba(28,26,23,.1);}
.boq-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:11px;margin-bottom:24px;}
.boq-sum-card{background:#FDFCFA;border:1px solid var(--border);border-radius:12px;padding:15px;box-shadow:0 2px 16px rgba(28,26,23,.06);}
.boq-sum-num{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:300;line-height:1.1;}
.boq-sum-lbl{font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:3px;}
.boq-sum-sub{font-size:.7rem;color:var(--muted);margin-top:2px;}
.boq-room-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0;overflow-x:auto;flex-wrap:nowrap;}
.boq-rtab{padding:9px 18px;font-family:'Outfit',sans-serif;font-size:.78rem;color:var(--muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .18s;display:inline-flex;align-items:center;gap:5px;}
.boq-rtab:hover{color:var(--ink);}
.boq-rtab.on{color:var(--gold);border-bottom-color:var(--gold);font-weight:500;}
.boq-rtab .rtc{background:var(--bg2);color:var(--muted);padding:1px 6px;border-radius:100px;font-size:.6rem;}
.boq-rtab.on .rtc{background:var(--gold);color:white;}
.boq-sheet{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;overflow:visible;box-shadow:0 2px 16px rgba(28,26,23,.06);margin-top:0;}
.boq-tbl-scroll{overflow-x:auto;border-radius:14px;}
.boq-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.boq-table th{background:var(--ink2);color:rgba(255,255,255,.85);padding:10px 12px;text-align:left;font-size:.62rem;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;white-space:nowrap;}
.boq-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.boq-table tr:last-child td{border-bottom:none;}
.boq-table tr:hover td{background:var(--bg);}
.boq-table tr.misc-row td{background:rgba(184,136,74,.04);font-style:italic;}
.boq-table tr.total-row td{background:var(--ink2);color:white;font-weight:600;border-bottom:none;}
.boq-cell-inp{width:100%;background:transparent;border:none;font-family:'Outfit',sans-serif;font-size:.78rem;color:var(--ink);outline:none;min-width:60px;}
.boq-cell-inp:focus{background:rgba(184,136,74,.07);border-radius:4px;padding:2px 4px;}
.boq-cell-inp::placeholder{color:var(--muted2);}
.boq-act-btns{display:flex;gap:4px;}
.boq-drag-handle{cursor:grab;color:var(--muted2);font-size:.75rem;padding:0 4px;user-select:none;opacity:.4;}
.boq-drag-handle:hover{opacity:1;color:var(--muted);}
.boq-drag-ghost{opacity:.4;background:var(--gold-bg)!important;}
@media(hover:none),(pointer:coarse){
  .boq-act-btns .boq-act-del{opacity:1!important;}
  .boq-act{width:34px!important;height:34px!important;font-size:.85rem!important;}
  .ord-pill{padding:6px 12px!important;font-size:.7rem!important;}
  .ph2-modal{max-width:100%;border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh;}
  .ph2-ovl{align-items:flex-end;padding:0;}
  .rh-item{min-height:100px;}
}
.boq-act{width:24px;height:24px;border:none;border-radius:5px;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.boq-act-del{background:rgba(168,77,58,.1);color:#A84D3A;}.boq-act-del:hover{background:#A84D3A;color:white;}
.boq-act-bill{background:rgba(58,107,138,.1);color:#3A6B8A;}.boq-act-bill:hover{background:#3A6B8A;color:white;}
.ord-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:.62rem;font-weight:600;cursor:pointer;border:none;font-family:'Outfit',sans-serif;transition:all .18s;}
.ord-pending{background:rgba(184,136,74,.12);color:#B8884A;}
.ord-placed{background:rgba(58,107,138,.12);color:#3A6B8A;}
.ord-delivered{background:rgba(94,114,96,.12);color:#5E7260;}
.ord-cancelled{background:rgba(168,77,58,.1);color:#A84D3A;}
.boq-add-row{display:flex;align-items:center;gap:8px;padding:11px 14px;cursor:pointer;color:var(--muted);font-size:.76rem;border-top:1px dashed var(--border2);transition:all .18s;background:transparent;width:100%;font-family:'Outfit',sans-serif;border:none;border-top:1px dashed var(--border2);}
.boq-add-row:hover{color:var(--gold);background:var(--gold-bg);}
.boq-chart-wrap{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:0 2px 16px rgba(28,26,23,.06);margin-bottom:22px;}
.boq-chart-title{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:400;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.boq-chart-inner{display:grid;grid-template-columns:240px 1fr;gap:28px;align-items:center;}
.boq-legend{display:flex;flex-direction:column;gap:7px;}
.boq-leg-item{display:flex;align-items:center;gap:9px;font-size:.74rem;}
.boq-leg-dot{width:11px;height:11px;border-radius:3px;flex-shrink:0;}
.boq-leg-name{flex:1;color:var(--ink2);}
.boq-leg-val{font-weight:600;color:var(--ink);font-family:'Fraunces',serif;}
.boq-leg-pct{color:var(--muted);font-size:.68rem;min-width:36px;text-align:right;}
.bill-preview{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.bill-thumb{width:72px;height:54px;border-radius:6px;object-fit:cover;border:1px solid var(--border);cursor:pointer;}
.ac-wrap{position:relative;}
.ac-drop{position:absolute;top:100%;left:0;right:0;background:#FDFCFA;border:1px solid var(--border2);border-radius:8px;box-shadow:0 8px 24px rgba(28,26,23,.12);z-index:50;max-height:160px;overflow-y:auto;display:none;}
.ac-drop.open{display:block;}
.ac-item{padding:7px 12px;font-size:.76rem;cursor:pointer;transition:background .12s;}
.ac-item:hover{background:var(--gold-bg);color:var(--gold);}
.boq-ai-btn{background:linear-gradient(135deg,#2E2B26,#4A3828);color:#D4AA72;border:1px solid rgba(184,136,74,.3);font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:500;padding:8px 18px;border-radius:100px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .22s;}
.boq-ai-btn:hover{background:linear-gradient(135deg,#3D2B1F,#5A4030);box-shadow:0 4px 16px rgba(184,136,74,.2);}
.boq-ai-btn:disabled{opacity:.4;cursor:not-allowed;}
.boq-gen-wrap{text-align:center;padding:48px 24px;color:var(--muted);}
.boq-gen-orb{width:44px;height:44px;border:3px solid var(--border);border-top-color:#B8884A;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 14px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* PHASE 3b: PAYMENTS */
.boq-main-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:22px;overflow-x:auto;}
.boq-mtab{padding:10px 20px;font-family:'Outfit',sans-serif;font-size:.81rem;color:var(--muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .18s;}
.boq-mtab:hover{color:var(--ink);}
.boq-mtab.on{color:var(--gold);border-bottom-color:var(--gold);font-weight:500;}
.boq-mpane{display:none;}.boq-mpane.on{display:block;animation:fadeup .22s ease;}
.pay-timeline{display:flex;flex-direction:column;gap:0;}
.pay-item{display:grid;grid-template-columns:120px 1fr;gap:0;}
.pay-line{display:flex;flex-direction:column;align-items:center;padding:0 18px;}
.pay-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:4px;}
.pay-connector{flex:1;width:2px;background:var(--border2);margin:3px 0;}
.pay-content{background:#FDFCFA;border:1px solid var(--border);border-radius:10px;padding:13px 16px;margin-bottom:10px;box-shadow:0 2px 10px rgba(28,26,23,.05);}
.pay-lbl{font-size:.6rem;letter-spacing:1.8px;text-transform:uppercase;font-weight:600;margin-bottom:4px;}
.pay-amt{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:300;line-height:1.1;}
.pay-meta{font-size:.69rem;color:var(--muted);margin-top:3px;}
.client-account{background:linear-gradient(135deg,var(--ink2),#3D2B1F);border-radius:14px;padding:20px 24px;color:#F7F4EF;margin-bottom:20px;}
.ca-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-top:14px;}
.ca-item{text-align:center;}
.ca-num{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:300;line-height:1.1;}
.ca-lbl{font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:3px;}
.vl-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.vl-table th{background:var(--ink2);color:rgba(255,255,255,.8);padding:9px 12px;font-size:.61rem;letter-spacing:1.1px;text-transform:uppercase;text-align:left;}
.vl-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.vl-table tr:hover td{background:var(--bg);}
.vl-table tr:last-child td{border-bottom:none;}
.due-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:100px;font-size:.65rem;font-weight:600;}
.due-pos{background:rgba(168,77,58,.1);color:#A84D3A;}
.due-zero{background:rgba(94,114,96,.1);color:#5E7260;}
.due-neg{background:rgba(58,107,138,.1);color:#3A6B8A;}
.vp-log{background:var(--bg2);border-radius:7px;padding:10px 13px;margin-top:6px;}
.vp-log-item{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid var(--border);font-size:.72rem;}
.vp-log-item:last-child{border-bottom:none;}
.vp-tag{padding:2px 7px;border-radius:100px;font-size:.6rem;font-weight:600;}
.vp-int{background:rgba(184,136,74,.12);color:#B8884A;}
.vp-cli{background:rgba(58,107,138,.12);color:#3A6B8A;}
.add-pay-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1.5px dashed var(--border2);border-radius:8px;padding:6px 14px;font-size:.74rem;color:var(--muted);cursor:pointer;transition:all .18px;font-family:'Outfit',sans-serif;}
.add-pay-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}
@media(max-width:640px){.pay-item{grid-template-columns:80px 1fr;}.ca-grid{grid-template-columns:1fr 1fr;}}

/* PHASE 4: PROJECT DETAIL */
.pd-hero{background:linear-gradient(135deg,var(--ink2),#3D2B1F);border-radius:16px;padding:24px 28px;color:#F7F4EF;margin-bottom:24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.pd-hero-left{flex:1;}
.pd-hero-icon{font-size:2.2rem;margin-bottom:6px;}
.pd-hero-name{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:300;letter-spacing:-.5px;line-height:1.1;}
.pd-hero-meta{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:5px;display:flex;gap:12px;flex-wrap:wrap;}
.pd-hero-pct{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:300;color:#D4AA72;line-height:1;}
.pd-quick-btns{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;}
.pd-qbtn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);font-family:'Outfit',sans-serif;font-size:.72rem;padding:6px 13px;border-radius:100px;cursor:pointer;transition:all .18s;}
.pd-qbtn:hover{background:rgba(255,255,255,.18);}
.pd-two{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;}
.pd-sh{display:flex;align-items:center;justify-content:space-between;margin:0 0 13px;}
.pd-sh-title{font-family:'Fraunces',serif;font-size:1rem;font-weight:400;display:flex;align-items:center;gap:7px;}
.pd-sh-badge{background:var(--gold-bg);color:var(--gold);font-size:.6rem;font-family:'Outfit',sans-serif;padding:2px 8px;border-radius:100px;font-weight:500;}
.pd-card{background:#FDFCFA;border:1px solid var(--border);border-radius:13px;padding:18px;box-shadow:0 2px 14px rgba(28,26,23,.06);}
.notif-bell-wrap{position:relative;margin-left:8px;}
.notif-bell{cursor:pointer;width:34px;height:34px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:all .2s;}
.notif-bell:hover{background:var(--gold-bg);border-color:var(--gold);}
.notif-badge{position:absolute;top:-3px;right:-3px;background:#A84D3A;color:white;font-size:.52rem;font-weight:700;min-width:16px;height:16px;border-radius:100px;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);display:none;}
.notif-badge.on{display:flex;animation:pulse 2s ease-in-out infinite;}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.15);}}
.notif-item{display:flex;align-items:flex-start;gap:11px;padding:11px 13px;border-radius:9px;border:1px solid var(--border);background:#FDFCFA;margin-bottom:7px;cursor:pointer;transition:all .18s;}
.notif-item:hover{border-color:var(--border2);transform:translateX(2px);}
.notif-item.unread{border-left:3px solid var(--gold);}
.notif-item.notif-overdue{border-left:3px solid #A84D3A;background:rgba(168,77,58,.03);}
.notif-item.notif-today{border-left:3px solid #B8884A;background:rgba(184,136,74,.03);}
.ni-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;}
.ni-body{flex:1;min-width:0;}
.ni-title{font-size:.77rem;font-weight:500;color:var(--ink);}
.ni-meta{font-size:.65rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ni-time{font-size:.61rem;color:var(--muted2);white-space:nowrap;flex-shrink:0;}
.todo-item{display:flex;align-items:flex-start;gap:9px;padding:10px 12px;border-radius:9px;border:1px solid var(--border);background:#FDFCFA;margin-bottom:6px;transition:all .18s;}
.todo-item:hover{border-color:var(--border2);}
.todo-item.done-todo{opacity:.45;}
.todo-item.done-todo .todo-text{text-decoration:line-through;color:var(--muted);}
.todo-item.overdue-todo{border-left:3px solid #A84D3A;}
.todo-item.today-todo{border-left:3px solid #B8884A;}
.todo-cb{width:17px;height:17px;border-radius:4px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.62rem;transition:all .18s;margin-top:1px;}
.todo-cb.checked{background:var(--sage);border-color:var(--sage);color:white;}
.todo-text{flex:1;font-size:.78rem;line-height:1.45;}
.todo-date-lbl{font-size:.61rem;white-space:nowrap;padding-top:1px;}
.todo-date-lbl.lbl-overdue{color:#A84D3A;font-weight:500;}
.todo-date-lbl.lbl-today{color:#B8884A;font-weight:500;}
.todo-date-lbl.lbl-future{color:var(--muted2);}
.proc-item{background:#FDFCFA;border:1px solid var(--border);border-radius:11px;padding:13px 15px;margin-bottom:8px;box-shadow:0 1px 8px rgba(28,26,23,.04);}
.proc-item.proc-partial{border-left:3px solid #B8884A;}
.proc-item.proc-done{border-left:3px solid #5E7260;}
.proc-item.proc-overdue{border-left:3px solid #A84D3A;}
.proc-name{font-size:.81rem;font-weight:500;}
.proc-vendor{font-size:.66rem;color:var(--muted);margin-top:1px;}
.proc-bar{height:5px;background:var(--bg2);border-radius:10px;overflow:hidden;margin:8px 0;}
.proc-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,#5E7260,#7A9E7C);}
.proc-stats{display:flex;gap:12px;font-size:.68rem;color:var(--muted);flex-wrap:wrap;}
.proc-stats b{color:var(--ink);}
.proc-exp-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:100px;font-size:.64rem;border:1px solid;cursor:pointer;margin-top:5px;transition:all .18s;}
.proc-exp-tag.exp-future{background:rgba(184,136,74,.06);border-color:rgba(184,136,74,.2);color:#B8884A;}
.proc-exp-tag.exp-today{background:rgba(94,114,96,.08);border-color:rgba(94,114,96,.2);color:#5E7260;}
.proc-exp-tag.exp-overdue{background:rgba(168,77,58,.07);border-color:rgba(168,77,58,.2);color:#A84D3A;}
@media(max-width:860px){.pd-two{grid-template-columns:1fr;}}

/* PHASE 5: SNAG LIST */
.snag-banner{background:linear-gradient(135deg,#2A1F3D,#3D2B1F);border-radius:14px;padding:16px 22px;color:#F7F4EF;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.snag-banner-role{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:100px;padding:4px 12px;font-size:.68rem;letter-spacing:.5px;text-transform:uppercase;}
.snag-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:center;}
.snag-fpill{background:var(--white);border:1px solid var(--border);border-radius:100px;padding:6px 14px;font-size:.73rem;color:var(--muted);cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:5px;white-space:nowrap;}
.snag-fpill:hover{border-color:var(--border2);color:var(--ink);}
.snag-fpill.on{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.snag-fpill.f-open.on{background:#A84D3A;border-color:#A84D3A;}
.snag-fpill.f-inprog.on{background:#B8884A;border-color:#B8884A;}
.snag-fpill.f-resolved.on{background:#5E7260;border-color:#5E7260;}
.snag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
.snag-card{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 2px 14px rgba(28,26,23,.06);transition:all .22s;}
.snag-card:hover{box-shadow:0 6px 28px rgba(28,26,23,.12);transform:translateY(-2px);}
.snag-card.sc-open{border-top:3px solid #A84D3A;}
.snag-card.sc-inprog{border-top:3px solid #B8884A;}
.snag-card.sc-resolved{border-top:3px solid #5E7260;opacity:.85;}
.snag-photos{position:relative;background:var(--bg2);min-height:180px;display:flex;gap:2px;overflow:hidden;}
.snag-photo-main{flex:1;object-fit:cover;cursor:pointer;transition:opacity .18s;min-width:0;}
.snag-photo-main:hover{opacity:.9;}
.snag-photo-count{position:absolute;bottom:8px;right:8px;background:rgba(28,26,23,.65);color:white;font-size:.62rem;padding:3px 8px;border-radius:100px;backdrop-filter:blur(4px);}
.snag-no-photo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:180px;color:var(--muted2);font-size:.75rem;cursor:pointer;}
.snag-body{padding:13px 15px;}
.snag-title{font-size:.88rem;font-weight:500;color:var(--ink);margin-bottom:3px;}
.snag-meta{font-size:.67rem;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px;}
.snag-status-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:.62rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;}
.ssp-open{background:rgba(168,77,58,.1);color:#A84D3A;}
.ssp-inprog{background:rgba(184,136,74,.1);color:#B8884A;}
.ssp-resolved{background:rgba(94,114,96,.1);color:#5E7260;}
.snag-comment-preview{font-size:.71rem;color:var(--muted);line-height:1.5;margin:6px 0;border-left:2px solid var(--border2);padding-left:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.snag-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;border-top:1px solid var(--border);background:rgba(28,26,23,.015);}
.snag-comment-count{font-size:.67rem;color:var(--muted);display:flex;align-items:center;gap:4px;}
.snag-modal-body{display:grid;grid-template-columns:1fr 380px;min-height:500px;gap:0;}
.snag-modal-photos{padding:18px;background:var(--bg2);border-right:1px solid var(--border);}
.snag-main-photo-wrap{position:relative;border-radius:10px;overflow:hidden;margin-bottom:10px;background:var(--bg);cursor:pointer;}
.snag-main-photo-wrap img{width:100%;max-height:400px;object-fit:contain;display:block;}
.snag-thumb-row{display:flex;gap:6px;flex-wrap:wrap;}
.snag-thumb{width:58px;height:58px;object-fit:cover;border-radius:7px;cursor:pointer;border:2px solid transparent;transition:all .18s;flex-shrink:0;}
.snag-thumb.active{border-color:var(--gold);}
.snag-thumb-add{width:58px;height:58px;border-radius:7px;border:2px dashed var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:var(--muted2);transition:all .18s;flex-shrink:0;}
.snag-thumb-add:hover{border-color:var(--gold);color:var(--gold);}
.snag-res-photo-zone{border:2px dashed rgba(94,114,96,.3);border-radius:9px;padding:12px;margin-top:10px;text-align:center;cursor:pointer;transition:all .18s;background:rgba(94,114,96,.03);}
.snag-res-photo-zone:hover{border-color:#5E7260;background:rgba(94,114,96,.07);}
.snag-res-photo-zone.has-photo{border-style:solid;border-color:#5E7260;}
.snag-sidebar{display:flex;flex-direction:column;max-height:580px;}
.snag-sidebar-hd{padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.snag-comments-area{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px;}
.snag-comment{border-radius:10px;padding:9px 11px;font-size:.75rem;line-height:1.5;max-width:90%;}
.snag-comment.by-interior{background:var(--ink);color:#F7F4EF;align-self:flex-end;border-bottom-right-radius:3px;}
.snag-comment.by-client{background:var(--blue-bg);border:1px solid rgba(58,107,138,.15);align-self:flex-start;border-bottom-left-radius:3px;}
.snag-comment.by-worker{background:var(--gold-bg);border:1px solid rgba(184,136,74,.15);align-self:flex-start;border-bottom-left-radius:3px;}
.snag-comment-role{font-size:.58rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;opacity:.6;margin-bottom:2px;}
.snag-comment-time{font-size:.6rem;opacity:.5;margin-top:3px;}
.snag-input-area{padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;}
.snag-resolve-bar{padding:10px 14px;border-top:1px solid var(--border);background:rgba(94,114,96,.04);flex-shrink:0;}
.snag-upload-zone{border:2px dashed var(--border2);border-radius:10px;padding:22px;text-align:center;cursor:pointer;transition:all .18s;margin-bottom:10px;}
.snag-upload-zone:hover,.snag-upload-zone.drag{border-color:var(--gold);background:var(--gold-bg);}
.snag-role-card{border:2px solid var(--border);border-radius:12px;padding:18px;text-align:center;cursor:pointer;transition:all .2s;}
.snag-role-card:hover,.snag-role-card.sel{border-color:var(--gold);background:var(--gold-bg);}
.snag-role-card .sri{font-size:2.2rem;margin-bottom:8px;}
.snag-role-card .srn{font-size:.85rem;font-weight:500;color:var(--ink);}
.snag-role-card .srs{font-size:.7rem;color:var(--muted);margin-top:3px;}
@media(max-width:760px){.snag-modal-body{grid-template-columns:1fr;}.snag-sidebar{max-height:320px;}.snag-grid{grid-template-columns:1fr;}}

/* PROFILE / PORTFOLIO */
.pending-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px 20px;}
.prof-grid{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;}
.prof-card{background:#FDFCFA;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--sh);}
.prof-avatar-wrap{position:relative;text-align:center;padding:28px 20px 20px;}
.prof-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--gold);display:block;margin:0 auto 12px;}
.prof-avatar-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--ink2),#3D2B1F);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:2.2rem;color:#F7F4EF;margin:0 auto 12px;border:3px solid var(--gold);}
.prof-name{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:300;}
.prof-company{font-size:.74rem;color:var(--muted);margin-top:3px;}
.prof-upload-av{display:block;font-size:.68rem;color:var(--gold);cursor:pointer;margin-top:8px;text-decoration:underline;}
.prof-divider{height:1px;background:var(--border);margin:0;}
.prof-links{padding:14px 18px;display:flex;flex-direction:column;gap:8px;}
.prof-link-item{display:flex;align-items:center;gap:9px;font-size:.74rem;color:var(--ink2);}
.prof-link-item a{color:var(--blue);text-decoration:none;}
.prof-link-item a:hover{text-decoration:underline;}
.prof-section{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--sh);margin-bottom:16px;}
.prof-section-title{font-size:.65rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.fav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}
.fav-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/3;background:var(--bg2);cursor:pointer;}
.fav-item img{width:100%;height:100%;object-fit:cover;transition:transform .25s;}
.fav-item:hover img{transform:scale(1.04);}
.fav-item-del{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:50%;background:rgba(168,77,58,.85);border:none;color:white;cursor:pointer;font-size:.6rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s;}
.fav-item:hover .fav-item-del{opacity:1;}
.fav-heart{position:absolute;bottom:6px;right:7px;font-size:1rem;color:#A84D3A;text-shadow:0 1px 4px rgba(0,0,0,.4);}
.port-hero{background:linear-gradient(160deg,var(--ink2) 0%,#3D2B1F 100%);border-radius:18px;padding:36px 40px;color:#F7F4EF;display:flex;align-items:center;gap:28px;margin-bottom:24px;flex-wrap:wrap;}
.port-logo{width:80px;height:80px;border-radius:14px;object-fit:cover;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;}
.port-logo img{width:80px;height:80px;border-radius:14px;object-fit:cover;}
.port-name{font-family:'Fraunces',serif;font-size:2rem;font-weight:300;letter-spacing:-.5px;}
.port-tagline{font-size:.8rem;color:rgba(255,255,255,.55);margin-top:4px;}
.port-section{background:#FDFCFA;border:1px solid var(--border);border-radius:14px;padding:24px 28px;margin-bottom:20px;box-shadow:var(--sh);}
.port-section-label{font-size:.62rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.port-founder-wrap{display:flex;gap:18px;align-items:flex-start;}
.port-founder-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex-shrink:0;}
.port-founder-placeholder{width:72px;height:72px;border-radius:50%;background:var(--ink2);display:flex;align-items:center;justify-content:center;color:#F7F4EF;font-size:1.4rem;flex-shrink:0;}
.port-proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.port-proj-card{border-radius:12px;overflow:hidden;background:#FDFCFA;border:1px solid var(--border);box-shadow:var(--sh);cursor:pointer;transition:all .22s;}
.port-proj-card:hover{transform:translateY(-3px);box-shadow:var(--shl);}
.port-proj-thumb{width:100%;height:180px;object-fit:cover;background:var(--bg2);}
.port-proj-body{padding:12px 14px;}
.port-proj-name{font-family:'Fraunces',serif;font-size:1rem;font-weight:300;}
.port-proj-meta{font-size:.68rem;color:var(--muted);margin-top:3px;}
.port-proj-photos{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap;}
.port-proj-photos img{width:44px;height:44px;object-fit:cover;border-radius:5px;}
.port-client-banner{background:linear-gradient(135deg,#2E2B26,#3D2B1F);color:#F7F4EF;padding:10px 32px;display:flex;align-items:center;gap:12px;font-size:.77rem;}
.shared-lib-badge{position:absolute;top:7px;left:7px;background:rgba(184,136,74,.9);color:white;font-size:.55rem;font-weight:700;padding:2px 7px;border-radius:100px;}
@media(max-width:800px){.prof-grid{grid-template-columns:1fr;}.port-hero{padding:24px 22px;}}

/* LIBRARY */
.lib-source-tabs{display:flex;gap:6px;margin-bottom:16px;}
.lib-stab{background:var(--white);border:1px solid var(--border);border-radius:100px;padding:6px 16px;font-size:.72rem;cursor:pointer;transition:all .18s;color:var(--muted);}
.lib-stab.on{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.pexels-result{position:relative;border-radius:10px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--bg2);}
.pexels-result img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.pexels-result:hover img{transform:scale(1.04);}
.pexels-attr{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(28,26,23,.7));padding:20px 8px 7px;font-size:.58rem;color:rgba(255,255,255,.8);}
.pexels-badge{position:absolute;top:7px;right:7px;background:rgba(5,191,113,.9);color:white;font-size:.56rem;font-weight:700;padding:2px 6px;border-radius:100px;}

/* ANALYTICS CHARTS MOBILE */
@media(max-width:600px){.analytics-charts-row{grid-template-columns:1fr!important;}}

/* BLINK ANIMATION */
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}

/* ═══════════════════════════════════════════════════════════
   DESIGNMIND — NEW FEATURE STYLES
   Analytics tabs · Fees card · Broadcast popup · Admin panel
   Expense project link · Password reset · Filter bar
═══════════════════════════════════════════════════════════ */

/* ── Analytics tab bar ── */
.an-tab { font-family:'Outfit',sans-serif; font-size:.78rem; font-weight:500; color:var(--muted); background:none; border:none; border-bottom:2px solid transparent; padding:8px 16px 10px; cursor:pointer; transition:color .2s,border-color .2s; margin-bottom:-1px; white-space:nowrap; }
.an-tab:hover { color:var(--ink); }
.an-tab.on { color:var(--gold); border-bottom-color:var(--gold); }

/* ── Admin panel tabs ── */
.admin-tab { font-family:'Outfit',sans-serif; font-size:.74rem; padding:8px 14px; border:none; border-bottom:2px solid transparent; background:none; cursor:pointer; color:var(--muted); transition:color .2s,border-color .2s; margin-bottom:-1px; white-space:nowrap; }
.admin-tab:hover { color:var(--ink); }
.admin-tab.on { color:var(--gold); border-bottom-color:var(--gold); }

/* ── Expense project link tag ── */
.exp-proj-tag { font-size:.58rem; background:rgba(184,136,74,.1); color:#B8884A; border-radius:100px; padding:1px 7px; margin-left:4px; display:inline-block; }

/* ── Fees & commissions entry ── */
.pd-fee-entry { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; padding:10px 0; border-bottom:1px solid var(--border); }
.pd-fee-entry:last-child { border-bottom:none; }

/* ── Broadcast popup ── */
#dm-broadcast-popup { animation:fadeIn .3s ease; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

/* ── PDF export button hover ── */
#an-pdf-btn:hover { background:var(--gold); color:#fff; border-color:var(--gold); }

/* ── Analytics pane animation ── */
#an-pane-overview, #an-pane-expsummary, #an-pane-fees { animation:fadeup .2s ease; }

/* ── Fees body animation ── */
#pd-fees-body { animation:fadeup .2s ease; }

/* ── Filter bar ── */
#an-filter-bar select:hover, #an-filter-bar select:focus { border-color:var(--gold); outline:none; }
#an-unit-l, #an-unit-c { font-family:'Outfit',sans-serif; font-size:.7rem; font-weight:500; padding:5px 13px; border:none; cursor:pointer; transition:background .15s,color .15s; }

/* ── Expense inline edit ── */
.exp-entry.editing { flex-direction:column; gap:8px; background:rgba(184,136,74,.04); border:1px solid rgba(184,136,74,.2); border-radius:10px; padding:10px; margin-bottom:4px; }

/* ── Analytics summary table ── */
.an-sum-table { width:100%; border-collapse:collapse; font-size:.78rem; }
.an-sum-table th { padding:9px 16px; text-align:left; font-size:.65rem; font-weight:600; letter-spacing:.8px; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--border); background:var(--bg2); }
.an-sum-table td { padding:10px 16px; border-bottom:1px solid rgba(0,0,0,.04); color:var(--ink); }
.an-sum-table tr:last-child td { border-bottom:none; }
.an-sum-table tr:hover td { background:rgba(184,136,74,.03); }

/* ── Mobile: analytics filter bar ── */
@media (max-width:600px) {
  #an-filter-bar { gap:6px; }
  #an-filter-bar select { font-size:.68rem; padding:4px 10px; }
  .an-tab { font-size:.7rem; padding:7px 10px 9px; }
}

/* ═══════════════════════════════════════════════════════════════
   PHASE 0 — Demo, Pricing, Waitlist, Feedback
═══════════════════════════════════════════════════════════════ */

/* Feedback FAB */
#dm-feedback-fab { transition: transform .2s, box-shadow .2s; }
#dm-feedback-fab:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.22); }
#dm-feedback-fab:active { transform: scale(.97); }

/* Plan card hover */
.plan-card-hover { transition: border-color .2s, transform .15s; cursor: pointer; }
.plan-card-hover:hover { border-color: var(--gold); transform: translateY(-2px); }

/* Waitlist / feedback type buttons */
.fb-type-btn { transition: background .15s, border-color .15s; }

/* Demo badge in nav */
.demo-badge {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .8px;
  text-transform: uppercase;
  background: rgba(94,114,96,.12);
  color: #5E7260;
  border-radius: 100px;
  padding: 2px 8px;
  margin-left: 6px;
}

/* Plan awareness modal grid responsive */
@media (max-width: 480px) {
  #dm-plan-modal .plan-grid-2 { grid-template-columns: 1fr !important; }
}
