:root{
  --bg:#eef5f1;
  --bg2:#f8fbf9;
  --panel:rgba(255,255,255,.86);
  --panelSolid:#ffffff;
  --ink:#0b1f16;
  --muted:#68766f;
  --line:#dce7e1;
  --green:#0f6b43;
  --greenDark:#083522;
  --green2:#1c8b57;
  --mint:#dff8eb;
  --gold:#d9a339;
  --gold2:#fff2cf;
  --red:#dc2626;
  --blue:#2563eb;
  --shadow:0 24px 70px rgba(10,31,22,.12);
  --shadow2:0 12px 32px rgba(10,31,22,.09);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 15% 0%, rgba(49,167,104,.18), transparent 32%),
    radial-gradient(circle at 90% 10%, rgba(217,163,57,.18), transparent 28%),
    linear-gradient(135deg,#f7fbf8 0%,#eef5f1 52%,#e8f2ed 100%);
  min-height:100vh;
}
body:before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:-1;
  background-image:linear-gradient(rgba(15,107,67,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,107,67,.035) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:linear-gradient(to bottom,black,transparent 82%);
}
.sidebar{
  position:fixed; left:18px; top:18px; bottom:18px; width:280px;
  background:linear-gradient(165deg,rgba(10,62,39,.96),rgba(5,31,21,.96));
  color:white; padding:20px 16px; border-radius:30px;
  box-shadow:0 30px 80px rgba(7,42,28,.34);
  border:1px solid rgba(255,255,255,.10);
  overflow:auto;
}
.brand{display:flex;gap:14px;align-items:center;margin:4px 6px 28px;padding:10px;border-radius:22px;background:rgba(255,255,255,.06)}
.logo{
  width:54px;height:54px;border-radius:18px;
  background:linear-gradient(145deg,#f3c75d,#d89b1d);
  display:grid;place-items:center;font-weight:1000;color:#10261a;
  box-shadow:0 12px 24px rgba(216,155,29,.26)
}
.brand strong{font-size:17px;letter-spacing:-.02em}.brand span{display:block;color:#cfe5d8;font-size:12px;margin-top:2px}
nav a{
  display:flex;align-items:center;gap:11px;color:#effff5;text-decoration:none;
  padding:13px 14px;border-radius:18px;margin:7px 0;font-weight:850;font-size:14px;
  transition:.18s ease;border:1px solid transparent;
}
nav a:before{width:22px;text-align:center;opacity:.95;filter:drop-shadow(0 3px 8px rgba(0,0,0,.18))}
nav a:nth-child(1):before{content:"⌂"}nav a:nth-child(2):before{content:"＋"}nav a:nth-child(3):before{content:"◉"}nav a:nth-child(4):before{content:"$"}nav a:nth-child(5):before{content:"◌"}nav a:nth-child(6):before{content:"▦"}nav a:nth-child(7):before{content:"☻"}nav a:nth-child(8):before{content:"⚙"}nav a:nth-child(9):before{content:"↪"}
nav a:hover{background:rgba(255,255,255,.12);transform:translateX(3px);border-color:rgba(255,255,255,.09)}
nav a.active{background:rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 12px 24px rgba(0,0,0,.14)}
.main{margin-left:318px;padding:26px 32px 50px;max-width:1680px}
.top{display:flex;justify-content:space-between;align-items:flex-start;margin:0 0 22px;gap:18px}
.top h1{margin:0;font-size:clamp(30px,3vw,46px);letter-spacing:-.055em;line-height:.94;color:#092117}
.top p{margin:9px 0 0;color:var(--muted);font-size:15px}.user{background:rgba(255,255,255,.78);backdrop-filter:blur(18px);padding:12px 16px;border-radius:999px;box-shadow:var(--shadow2);border:1px solid rgba(255,255,255,.8);white-space:nowrap}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.grid[style*="2fr"]{align-items:stretch}
.card{
  background:var(--panel);backdrop-filter:blur(18px);border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.82);overflow-x:auto;
}
.card h3{margin:0 0 12px;font-size:19px;letter-spacing:-.02em}.card p{color:var(--muted)}
.stat{font-size:clamp(32px,4vw,52px);font-weight:1000;color:var(--green);letter-spacing:-.06em;line-height:1}.stat:after{content:"";display:block;width:42px;height:5px;border-radius:99px;background:linear-gradient(90deg,var(--gold),transparent);margin-top:10px}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin:15px 0}.btn,button,input[type=submit]{border:0;border-radius:16px;background:linear-gradient(135deg,var(--green2),var(--green));color:white;padding:12px 17px;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;box-shadow:0 12px 24px rgba(15,107,67,.18);transition:.16s ease;font-size:14px}
.btn:hover,button:hover,input[type=submit]:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(15,107,67,.24)}.btn.gold{background:linear-gradient(135deg,#f5c85d,#d69a20);color:#142016}.btn.red{background:linear-gradient(135deg,#ef4444,#b91c1c)}.btn.light{background:#e8f1ec;color:#123c28;box-shadow:none;border:1px solid #d8e5de}.btn.small{padding:8px 11px;font-size:12px;border-radius:12px}
.table{width:100%;border-collapse:separate;border-spacing:0 10px;min-width:760px}.table th{text-align:left;color:#718078;font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:8px 10px;font-weight:950}.table td{background:rgba(255,255,255,.88);padding:14px 10px;border-top:1px solid #e6eee9;border-bottom:1px solid #e6eee9;vertical-align:middle}.table tr:hover td{background:#fbfffd}.table td:first-child{border-left:1px solid #e6eee9;border-radius:18px 0 0 18px;font-weight:850}.table td:last-child{border-right:1px solid #e6eee9;border-radius:0 18px 18px 0}
.form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form .full{grid-column:1/-1}label{font-weight:900;font-size:13px;color:#2f463b;margin-bottom:6px;display:block}input,select,textarea{width:100%;padding:13px 14px;border:1px solid #d8e5df;border-radius:16px;background:rgba(255,255,255,.92);font:inherit;outline:0;transition:.15s ease}input:focus,select:focus,textarea:focus{border-color:#7bc69b;box-shadow:0 0 0 4px rgba(28,139,87,.13)}textarea{min-height:100px}.money-input{width:130px;padding:10px 12px;border-radius:14px}.editable-table input,.editable-table select{padding:9px;border-radius:12px;min-width:100px}
.alert,.notice.success{padding:14px 16px;border-radius:18px;background:#dcfce7;color:#166534;margin:12px 0;border:1px solid #a7f3d0;font-weight:800}.alert.err{background:#fee2e2;color:#991b1b;border-color:#fecaca}.badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;font-weight:950;font-size:12px;white-space:nowrap}.badge.ok,.badge.green{background:#dcfce7;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.badge.red{background:#fee2e2;color:#991b1b}.badge.blue{background:#dbeafe;color:#1e40af}.badge.gray{background:#f1f5f9;color:#475569}
.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 30% 0%,rgba(245,200,93,.28),transparent 28%),linear-gradient(135deg,#061e14,#14744b 70%,#0b3b27);padding:24px}.loginbox{width:min(500px,92vw);background:rgba(255,255,255,.9);backdrop-filter:blur(24px);border-radius:34px;padding:42px;box-shadow:0 35px 100px rgba(0,0,0,.34);border:1px solid rgba(255,255,255,.75)}.loginbox h1{font-size:48px;margin:0 0 8px;letter-spacing:-.06em}.loginbox p{color:var(--muted)}
.map{position:relative;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.95);border-radius:28px;min-height:620px;overflow:auto;padding:24px;box-shadow:var(--shadow)}.lot-grid{display:grid;grid-template-columns:repeat(15,64px);gap:9px}.lot{border:1px solid #234032;border-radius:14px;min-height:46px;display:grid;place-items:center;font-weight:1000;background:white;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.06)}.lot:hover{transform:translateY(-1px)}.lot.res{background:#ffad95}.lot.avail{background:#dbfbe7}.lot.season{background:#ffe99a}
.totalBox{background:linear-gradient(135deg,#fff9e8,#fff3c9);border:1px solid #ecd37d;border-radius:20px;padding:16px;line-height:1.9;box-shadow:0 12px 26px rgba(217,163,57,.10)}.fee-input{margin-top:7px}.muted,.small{color:#64756d;font-size:14px}.date-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px}.compact{grid-template-columns:repeat(4,minmax(0,1fr))}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.inline-pay-form{display:flex;gap:8px;align-items:center}.invoice-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start}.invoice-no{font-size:20px;text-align:right;background:#eef8f1;border:1px solid #cfe5d6;border-radius:20px;padding:17px}.print-card{max-width:1040px;margin:auto}.invoice-table td:last-child,.invoice-table th:last-child{text-align:right}.protocol-invoice{font-size:14px;margin:4px 0;color:var(--green);font-weight:800}
/* Protocole d'entente */
.protocol,.protocol-exact{background:#fff;color:#111;padding:22px;border:1px solid #cfd8d2}.protocol-exact{max-width:1380px;margin:auto;border:2px solid #444;font-family:Arial,Helvetica,sans-serif;font-size:12px;line-height:1.22;border-radius:0;box-shadow:none}.protocol h2{text-align:center;margin:0}.protocol-head{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:center;margin-bottom:8px}.proto-logo{height:92px;background:#222;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:4px;letter-spacing:2px;font-size:14px}.proto-logo strong{font-size:22px}.proto-title{text-align:center}.proto-title h2{font-size:22px;margin:0;text-align:center}.proto-title h3{font-size:15px;margin:4px 0}.proto-title h1{font-size:22px;margin:6px 0 4px}.proto-title p{font-size:15px;margin:0}.proto-columns{display:grid;grid-template-columns:1.04fr 1fr;gap:14px}.proto-form{width:100%;border-collapse:collapse;margin-bottom:8px}.proto-form th{background:#d5d5d5;border:1px solid #888;text-align:center;padding:5px;font-size:13px}.proto-form td{border:1px solid #999;padding:5px;min-height:24px;vertical-align:top}.proto-form td:nth-child(odd){font-weight:700;background:#f3f3f3}.money-table td:nth-child(odd){background:#fff;font-weight:400}.money-table td:first-child{font-weight:700;background:#f3f3f3}.center{text-align:center}.bigbox{font-size:18px;font-weight:800;vertical-align:middle}.cancel-box{font-size:12px;text-align:center;background:#fafafa!important}.interest-box{border:1px solid #999;background:#f3f3f3;padding:10px;min-height:70px;margin-top:8px}.initials{float:right;border:1px solid #999;background:#ddd;padding:14px;margin-left:8px}.proto-right{border:1px solid #999;padding:8px}.proto-right h4{text-align:center;background:#d5d5d5;margin:-8px -8px 6px;padding:6px;border-bottom:1px solid #999}.legal-text{margin:0;padding-left:18px;font-size:10.5px;line-height:1.16}.legal-text li{margin-bottom:4px}.next-season,.signatures{border-top:1px solid #999;margin-top:8px;padding-top:8px;font-size:11px}.signatures{min-height:95px}.protocol-exact .table td,.protocol-exact .table th{border-radius:0!important}
@media(max-width:1100px){.sidebar{position:static;width:auto;margin:14px;border-radius:24px}.main{margin-left:0;padding:16px}.grid,.grid[style*="2fr"]{grid-template-columns:1fr 1fr!important}.form,.compact,.two-col{grid-template-columns:1fr}.top{flex-direction:column}.user{white-space:normal}}
@media(max-width:700px){.grid,.grid[style*="2fr"]{grid-template-columns:1fr!important}.date-pair{grid-template-columns:1fr}.loginbox{padding:28px}.top h1{font-size:34px}.sidebar{padding:14px}.invoice-head{display:block}.table{min-width:680px}}
@media print{body{background:#fff}.sidebar,.top,.actions,.no-print{display:none!important}.main{margin:0;padding:0}.card{box-shadow:none;border:0;background:white}.print-card{box-shadow:none;border:0}.protocol{border:0}.protocol-exact{border:0;max-width:100%;padding:8px;font-size:10px}.protocol-head{grid-template-columns:210px 1fr}.proto-logo{height:75px}.legal-text{font-size:8.9px}.proto-form td,.proto-form th{padding:3px}.proto-title h2{font-size:18px}.proto-title h1{font-size:18px}.proto-title p{font-size:12px}.date-pair,.two-col{grid-template-columns:1fr 1fr}}

/* Daisy Town UI fix - readability for lists and amounts */
.table th,
.table td{
  white-space: nowrap;
}
.table td{
  line-height: 1.25;
}
.table td strong,
.stat{
  white-space: nowrap;
}
.btn.small,
button.btn.small,
input[type=submit].btn.small{
  color:#ffffff !important;
  background:linear-gradient(135deg,#16834f,#0b5f3b) !important;
  min-width:118px;
  padding:10px 14px;
  font-size:13px;
  opacity:1 !important;
}
.btn.light.small{
  color:#123c28 !important;
  background:#e8f1ec !important;
}
.money-input{
  width:150px;
  min-width:150px;
  font-weight:800;
  color:#10261a;
}
.table input,
.table select{
  white-space: nowrap;
}
.table th:nth-child(5),
.table th:nth-child(6),
.table th:nth-child(7),
.table th:nth-child(8),
.table td:nth-child(5),
.table td:nth-child(6),
.table td:nth-child(7),
.table td:nth-child(8){
  min-width:110px;
}
@media(max-width:900px){
  .table{min-width:980px;}
}

/* Historique client */
.client-link{display:flex;flex-direction:column;gap:3px;color:var(--ink);text-decoration:none}
.client-link span{font-size:12px;color:var(--green);font-weight:900}
.client-link:hover strong{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.client-hero{display:flex;justify-content:space-between;gap:22px;align-items:stretch}
.client-hero h2{margin:4px 0 6px;font-size:42px;letter-spacing:-.055em;line-height:.95}
.eyebrow{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--mint);color:var(--green);font-weight:950;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.client-last-lot{min-width:230px;border-radius:24px;background:linear-gradient(135deg,#0f6b43,#083522);color:#fff;padding:20px;display:flex;flex-direction:column;justify-content:center;box-shadow:var(--shadow2)}
.client-last-lot span{opacity:.78;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.client-last-lot strong{font-size:54px;line-height:.95;letter-spacing:-.06em;margin:8px 0}
.client-last-lot small{color:#dff8eb;font-weight:800}
.history-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:16px}
.mini-stat span{display:block;color:var(--muted);font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.mini-stat strong{display:block;font-size:30px;letter-spacing:-.04em;white-space:nowrap;color:var(--green)}
@media(max-width:1000px){.client-hero{flex-direction:column}.history-grid{grid-template-columns:1fr 1fr}}
@media(max-width:650px){.history-grid{grid-template-columns:1fr}.client-hero h2{font-size:34px}}
@media print{.client-hero{box-shadow:none;border:0}.history-grid{grid-template-columns:repeat(4,1fr)}.client-last-lot{background:#f1f5f9!important;color:#111;box-shadow:none}.client-last-lot small{color:#333}}


/* =========================================================
   Daisy Town 2026 Premium Responsive UI
   Desktop • TV • iPadOS • iOS • Android • Tablets
   ========================================================= */
:root{
  --tv-scale:1;
  --safe-x:max(18px, env(safe-area-inset-left));
  --safe-r:max(18px, env(safe-area-inset-right));
  --safe-t:max(18px, env(safe-area-inset-top));
  --safe-b:max(18px, env(safe-area-inset-bottom));
}
body{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
.mobile-menu-btn,.menu-backdrop{display:none}
.top{
  position:sticky;
  top:14px;
  z-index:20;
  padding:14px 0 10px;
  backdrop-filter:blur(10px);
}
.top:before{
  content:"";
  position:absolute;
  inset:0 -10px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(245,250,247,.88),rgba(245,250,247,.45));
  z-index:-1;
  pointer-events:none;
}
.card{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{
  transform:translateY(-1px);
  border-color:rgba(15,107,67,.16);
}
.table-wrap,.table-scroll{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:22px;
}
.card > .table{margin-top:4px}
.table{
  font-variant-numeric:tabular-nums;
}
.table th{
  position:sticky;
  top:0;
  z-index:5;
  background:rgba(246,251,248,.96);
}
.table td,
.table th{
  vertical-align:middle;
}
.table td:last-child{
  min-width:150px;
}
.table td strong,
.table td .money,
.money,
.amount,
.total,
.stat,
.mini-stat strong{
  white-space:nowrap !important;
  font-variant-numeric:tabular-nums;
}
.actions .btn,.actions button{
  min-height:44px;
}
.btn,.btn.small,button,input[type=submit]{
  text-align:center;
  text-shadow:none;
}
.btn.small,
button.btn.small,
input[type=submit].btn.small{
  color:#fff!important;
  background:#0f6b43!important;
  border:1px solid rgba(255,255,255,.2)!important;
  box-shadow:0 10px 22px rgba(15,107,67,.20)!important;
}
.btn.small:hover{background:#0b5636!important}
.btn.gold.small{color:#172016!important;background:#f3bf48!important}
.btn.red.small{color:#fff!important;background:#dc2626!important}
input,select,textarea,button,.btn{
  min-height:44px;
}
input[type="checkbox"],input[type="radio"]{min-height:auto;width:auto;transform:scale(1.15);accent-color:var(--green)}
select{
  appearance:auto;
}
.form,.date-pair,.two-col,.compact{
  align-items:end;
}
.form > div,.date-pair > div,.two-col > div{
  min-width:0;
}
.money-input,
.editable-table input[type="number"]{
  min-width:155px!important;
  text-align:right;
  font-variant-numeric:tabular-nums;
}
/* modern scrollbars */
*::-webkit-scrollbar{height:12px;width:12px}
*::-webkit-scrollbar-track{background:rgba(15,107,67,.07);border-radius:999px}
*::-webkit-scrollbar-thumb{background:rgba(15,107,67,.35);border-radius:999px;border:3px solid rgba(255,255,255,.55)}
*::-webkit-scrollbar-thumb:hover{background:rgba(15,107,67,.55)}

/* Large desktop and TV layout */
@media (min-width:1600px){
  body{font-size:17px}
  .sidebar{width:318px;padding:24px 20px}
  .main{margin-left:360px;padding:34px 42px 70px;max-width:none}
  .top h1{font-size:56px}
  .grid{gap:24px}
  .card{padding:28px;border-radius:30px}
  .table th{font-size:13px}
  .table td{font-size:16px;padding:16px 14px}
  input,select,textarea{font-size:16px;padding:15px 16px}
  .btn,button,input[type=submit]{font-size:15px;padding:14px 20px}
}
@media (min-width:2200px){
  body{font-size:20px}
  .sidebar{left:28px;top:28px;bottom:28px;width:370px;border-radius:38px;padding:30px 24px}
  .brand strong{font-size:22px}.brand span{font-size:15px}.logo{width:68px;height:68px;font-size:22px}
  nav a{font-size:18px;padding:17px 18px;border-radius:24px;margin:10px 0}
  .main{margin-left:430px;padding:48px 60px 90px}
  .top h1{font-size:72px}.top p{font-size:20px}.user{font-size:18px;padding:16px 22px}
  .grid{gap:30px}.card{padding:36px;border-radius:36px}
  .card h3{font-size:28px}.stat{font-size:78px}
  .table{border-spacing:0 14px}.table th{font-size:15px;padding:12px 16px}.table td{font-size:20px;padding:22px 16px}
  input,select,textarea{font-size:20px;padding:18px 20px;border-radius:20px}
  label{font-size:16px}.btn,button,input[type=submit]{font-size:18px;padding:18px 24px;border-radius:22px;min-height:58px}
  .btn.small{font-size:16px;min-width:150px}
}

/* iPad / tablet landscape */
@media(max-width:1280px){
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .compact{grid-template-columns:repeat(2,minmax(0,1fr))}
  .main{padding-right:24px}
}

/* Tablet and mobile: off-canvas premium menu */
@media(max-width:1100px){
  .mobile-menu-btn{
    display:inline-flex;
    position:fixed;
    left:var(--safe-x);
    top:var(--safe-t);
    z-index:1001;
    align-items:center;
    justify-content:center;
    gap:8px;
    border:1px solid rgba(255,255,255,.65);
    color:#fff;
    background:linear-gradient(135deg,#0f6b43,#083522);
    border-radius:999px;
    padding:12px 16px;
    font-weight:950;
    box-shadow:0 18px 46px rgba(7,42,28,.30);
  }
  .menu-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(3,18,12,.46);
    backdrop-filter:blur(5px);
    z-index:998;
    opacity:0;
    pointer-events:none;
    transition:.2s ease;
  }
  .sidebar{
    position:fixed!important;
    left:var(--safe-x)!important;
    top:calc(var(--safe-t) + 58px)!important;
    bottom:var(--safe-b)!important;
    width:min(360px,calc(100vw - 36px))!important;
    margin:0!important;
    z-index:999;
    transform:translateX(calc(-100% - 30px));
    transition:transform .24s ease;
  }
  body.menu-open .sidebar{transform:translateX(0)}
  body.menu-open .menu-backdrop{opacity:1;pointer-events:auto}
  .main{
    margin-left:0!important;
    padding:calc(var(--safe-t) + 66px) var(--safe-r) 46px var(--safe-x)!important;
    max-width:none;
  }
  .top{
    top:calc(var(--safe-t) + 0px);
    padding-top:4px;
  }
  .top h1{padding-left:0}
  .card:hover{transform:none}
}

/* phones */
@media(max-width:760px){
  body{background:linear-gradient(180deg,#f7fbf8,#edf6f1)}
  .main{padding-left:14px!important;padding-right:14px!important}
  .top{gap:10px;margin-bottom:12px}
  .top:before{inset:-4px -6px;border-radius:22px}
  .top h1{font-size:30px!important;line-height:1.02;letter-spacing:-.04em}
  .top p{font-size:13px}.user{font-size:12px;padding:9px 12px}
  .grid,.grid[style*="2fr"],.history-grid{grid-template-columns:1fr!important;gap:12px!important}
  .card{padding:16px;border-radius:22px;box-shadow:0 14px 34px rgba(10,31,22,.09)}
  .card h3{font-size:18px}
  .stat{font-size:38px}
  .form,.date-pair,.two-col,.compact{grid-template-columns:1fr!important;gap:12px}
  .actions{gap:8px}.actions .btn,.actions button{flex:1 1 auto;min-width:140px}
  .table{min-width:900px!important;border-spacing:0 8px}
  .table th{font-size:11px;padding:8px 10px}.table td{font-size:13px;padding:12px 10px}
  .money-input{min-width:145px!important;width:145px!important}
  .loginbox{border-radius:26px;padding:26px}.loginbox h1{font-size:36px}
  .client-hero h2{font-size:30px}.client-last-lot strong{font-size:42px}
}

/* very small phones */
@media(max-width:390px){
  .mobile-menu-btn{padding:10px 13px;font-size:13px}
  .top h1{font-size:27px!important}
  .card{padding:14px}
  input,select,textarea{font-size:16px; /* prevents iOS zoom */}
}

/* touch-friendly devices */
@media (hover:none){
  .btn:hover,button:hover,input[type=submit]:hover,nav a:hover,.lot:hover,.card:hover{transform:none}
  nav a,.btn,button,input,select{min-height:48px}
}

/* print remains clean */
@media print{
  .mobile-menu-btn,.menu-backdrop{display:none!important}
  .top{position:static!important;backdrop-filter:none!important}
}

/* =========================================================
   FIX MENU + PRINT/PDF — Daisy Town
   - Desktop/laptop: normal sidebar, no Menu button
   - iPhone/iPad/Android/tablet: working off-canvas menu
   - Print/PDF: no cut content, readable tables
   ========================================================= */
.mobile-menu-btn{display:none!important;}
.menu-backdrop{display:none!important;}
body.menu-open{overflow:hidden;}

/* Desktop and most laptops */
@media (min-width:1025px){
  .mobile-menu-btn,.menu-backdrop{display:none!important;}
  .sidebar{
    position:fixed!important;
    left:18px!important; top:18px!important; bottom:18px!important;
    width:280px!important;
    transform:none!important;
    z-index:60!important;
  }
  .main{margin-left:318px!important;}
}

/* Tablets + phones */
@media (max-width:1024px){
  .mobile-menu-btn{
    display:inline-flex!important;
    position:fixed!important;
    left:var(--safe-x)!important;
    top:var(--safe-t)!important;
    z-index:5000!important;
    align-items:center!important;
    justify-content:center!important;
    gap:8px!important;
    color:#fff!important;
    background:linear-gradient(135deg,#0f6b43,#063822)!important;
    border:1px solid rgba(255,255,255,.35)!important;
    border-radius:999px!important;
    padding:12px 16px!important;
    min-height:48px!important;
    font-weight:1000!important;
    box-shadow:0 18px 48px rgba(7,42,28,.35)!important;
  }
  .menu-backdrop{
    display:block!important;
    position:fixed!important;
    inset:0!important;
    z-index:4990!important;
    background:rgba(2,15,10,.52)!important;
    backdrop-filter:blur(6px)!important;
    opacity:0!important;
    pointer-events:none!important;
    transition:opacity .2s ease!important;
  }
  .sidebar{
    position:fixed!important;
    left:var(--safe-x)!important;
    top:calc(var(--safe-t) + 62px)!important;
    bottom:var(--safe-b)!important;
    width:min(380px, calc(100vw - 32px))!important;
    margin:0!important;
    z-index:4995!important;
    transform:translateX(calc(-100% - 40px))!important;
    transition:transform .24s ease!important;
    overflow-y:auto!important;
  }
  body.menu-open .sidebar{transform:translateX(0)!important;}
  body.menu-open .menu-backdrop{opacity:1!important;pointer-events:auto!important;}
  .main{
    margin-left:0!important;
    padding:calc(var(--safe-t) + 70px) var(--safe-r) 46px var(--safe-x)!important;
  }
  .top{position:relative!important;top:auto!important;z-index:10!important;}
}

/* Prevent older mobile rule from forcing sidebar static */
@media (max-width:1100px) and (min-width:1025px){
  .sidebar{position:fixed!important;width:280px!important;margin:0!important;border-radius:30px!important;}
  .main{margin-left:318px!important;padding:26px 32px 50px!important;}
}

/* Better print/PDF documents */
@page{size:Letter portrait;margin:9mm;}
@media print{
  html,body{width:auto!important;height:auto!important;overflow:visible!important;background:#fff!important;color:#111!important;}
  body:before,.sidebar,.mobile-menu-btn,.menu-backdrop,.top,.actions,.no-print{display:none!important;}
  .main{margin:0!important;padding:0!important;max-width:none!important;width:100%!important;}
  .card,.invoice,.print-card,.protocol,.protocol-exact{
    width:100%!important;max-width:none!important;overflow:visible!important;
    box-shadow:none!important;border:0!important;background:#fff!important;
    padding:0!important;margin:0!important;border-radius:0!important;
    transform:none!important;backdrop-filter:none!important;
  }
  .invoice-head,.two-col,.date-pair{display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;align-items:start!important;}
  .invoice h1{font-size:22px!important;margin:0 0 6px!important;}
  .invoice h3{font-size:14px!important;margin:12px 0 6px!important;page-break-after:avoid!important;}
  .invoice p,.invoice td,.invoice th{font-size:10.5px!important;line-height:1.25!important;}
  table,.table,.invoice-table{
    width:100%!important;min-width:0!important;max-width:100%!important;
    border-collapse:collapse!important;border-spacing:0!important;table-layout:fixed!important;
    page-break-inside:auto!important;
  }
  .table tr{page-break-inside:avoid!important;page-break-after:auto!important;}
  .table th,.table td{
    white-space:normal!important;word-break:break-word!important;overflow-wrap:anywhere!important;
    padding:5px 4px!important;border:1px solid #999!important;border-radius:0!important;background:#fff!important;color:#111!important;
  }
  .table th{background:#efefef!important;color:#111!important;font-weight:800!important;}
  .invoice-table th:nth-child(1),.invoice-table td:nth-child(1){width:28%!important;}
  .invoice-table th:nth-child(2),.invoice-table td:nth-child(2){width:15%!important;}
  .invoice-table th:nth-child(3),.invoice-table td:nth-child(3){width:15%!important;}
  .invoice-table th:nth-child(4),.invoice-table td:nth-child(4){width:15%!important;}
  .invoice-table th:nth-child(5),.invoice-table td:nth-child(5){width:14%!important;}
  .invoice-table th:nth-child(6),.invoice-table td:nth-child(6){width:13%!important;}
  .invoice-no{border:1px solid #999!important;background:#f4f4f4!important;color:#111!important;padding:10px!important;font-size:14px!important;}
  .small{font-size:9.5px!important;color:#333!important;}
  .protocol-exact{font-size:9px!important;line-height:1.1!important;}
  .protocol-head{grid-template-columns:170px 1fr!important;gap:8px!important;}
  .proto-logo{height:58px!important;font-size:10px!important}.proto-logo strong{font-size:16px!important}
  .proto-title h2,.proto-title h1{font-size:15px!important}.proto-title h3{font-size:12px!important}.proto-title p{font-size:10px!important}
  .proto-columns{grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .proto-form td,.proto-form th{font-size:8.5px!important;padding:2.5px!important;word-break:break-word!important;}
  .legal-text{font-size:7.2px!important;line-height:1.08!important;}
  a{color:#111!important;text-decoration:none!important;}
}
