@font-face { font-family:'Fields';     src:url('../fonts/fields-black.otf') format('opentype'); font-weight:900; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url('../fonts/Montserrat-Regular.ttf') format('truetype'); font-weight:400; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url('../fonts/Montserrat-SemiBold.ttf') format('truetype'); font-weight:600; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url('../fonts/Montserrat-Bold.ttf') format('truetype'); font-weight:700; font-display:swap; }

  :root {
    --green:#3C8A4C; --green-d:#195852; --green-l:#ADCC54;
    --ink:#14201A; --muted:#6B7670; --line:#E8E9E4;
    --bg:#FAFAF5; --white:#fff; --red:#dc2626;
    --r:14px; --ease:cubic-bezier(.4,0,.2,1);
    --pad:clamp(16px,4vw,40px);
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
  html{scroll-behavior:smooth;}
  body{font-family:'Montserrat',sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;}
  img{display:block;max-width:100%;height:auto;}
  a{color:inherit;text-decoration:none;}
  button{font:inherit;cursor:pointer;border:none;background:none;}
  input,select,textarea{font:inherit;}

  /* ── HEADER ── */
  header{background:var(--white);border-bottom:1px solid var(--line);padding:14px var(--pad);}
  .nav-row{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:16px;}
  .logo-link{display:flex;align-items:center;gap:10px;}
  .logo-link img{height:38px;width:auto;}
  .logo-link .word{font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;letter-spacing:.04em;color:var(--green);line-height:1.1;}
  .logo-link .word small{display:block;font-weight:400;color:var(--muted);font-size:9px;letter-spacing:.16em;text-transform:uppercase;margin-top:2px;}
  .nav-back{margin-left:auto;font-size:13px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:6px;}
  .nav-back:hover{color:var(--green);}

  /* ── AUTH SCREEN ── */
  .auth-wrap{min-height:calc(100vh - 68px);display:flex;align-items:center;justify-content:center;padding:32px var(--pad);}
  .auth-card{background:var(--white);border-radius:20px;padding:clamp(28px,5vw,48px);width:100%;max-width:420px;box-shadow:0 4px 32px rgba(20,32,26,.09);}

  .auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
  .auth-brand-img{height:40px;width:auto;}
  .auth-brand-name{font-weight:700;font-size:13px;color:var(--green-d);line-height:1.2;}
  .auth-brand-tagline{font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;}

  .auth-title{font-family:'Fields',serif;font-size:clamp(22px,5vw,28px);font-weight:900;color:var(--ink);margin-bottom:4px;}
  .auth-sub{font-size:14px;color:var(--muted);margin-bottom:24px;}

  .btn-google{width:100%;padding:13px 16px;border-radius:10px;border:1.5px solid var(--line);background:var(--white);display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:600;color:var(--ink);transition:border-color .2s,box-shadow .2s;margin-bottom:4px;}
  .btn-google:hover{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1);}

  .btn-text-link{width:100%;padding:10px;font-size:13px;color:var(--muted);text-align:center;margin-top:8px;transition:color .2s;}
  .btn-text-link:hover{color:var(--green);}

  .auth-switch{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);font-size:13px;color:var(--muted);}
  .auth-switch-link{font-size:13px;font-weight:700;color:var(--green);transition:color .2s;}
  .auth-switch-link:hover{color:#2d6e3a;}

  /* ── FORM ── */
  .form-group{margin-bottom:16px;}
  .form-group label{display:block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
  .form-group input,.form-group select{
    width:100%;padding:13px 16px;border-radius:10px;
    border:1.5px solid var(--line);background:var(--bg);
    font-size:15px;color:var(--ink);outline:none;
    transition:border-color .2s;
  }
  .form-group input:focus,.form-group select:focus{border-color:var(--green);}
  .form-group input.err{border-color:var(--red);}
  .field-err{font-size:12px;color:var(--red);margin-top:4px;display:none;}

  .pass-rules{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:5px;}
  .pass-rules li{font-size:12px;color:var(--muted);padding-left:18px;position:relative;transition:color .2s;}
  .pass-rules li::before{content:'○';position:absolute;left:0;font-size:10px;transition:color .2s;}
  .pass-rules li.ok{color:var(--green);}
  .pass-rules li.ok::before{content:'✓';color:var(--green);}
  .field-err.show{display:block;}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .pass-wrap{position:relative;}
  .pass-wrap input{padding-right:44px;}
  .pass-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted);display:grid;place-items:center;padding:4px;}
  .pass-toggle:hover{color:var(--ink);}

  .btn-primary{
    width:100%;padding:14px;border-radius:999px;
    background:var(--green);color:#fff;font-weight:700;font-size:15px;
    transition:background .2s;margin-top:4px;
  }
  .btn-primary:hover{background:#2d6e3a;}
  .btn-primary:disabled{opacity:.55;pointer-events:none;}
  .btn-primary.loading::after{content:' ···';}

  .auth-msg{font-size:13px;text-align:center;margin-top:16px;padding:10px;border-radius:8px;display:none;}
  .auth-msg.err{background:#fef2f2;color:var(--red);display:block;}
  .auth-msg.ok{background:#f0fdf4;color:var(--green-d);display:block;}

  .divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:12px;}
  .divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--line);}

  /* ── DASHBOARD ── */
  #dashboard{display:none;}
  .dash-header{background:var(--green-d);color:#fff;padding:24px var(--pad);}
  .dash-header .inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:14px;}
  .dash-avatar{width:48px;height:48px;border-radius:50%;background:var(--green-l);color:var(--green-d);font-weight:700;font-size:18px;display:grid;place-items:center;flex-shrink:0;}
  .dash-name{font-family:'Fields',serif;font-size:clamp(18px,3vw,24px);font-weight:900;color:#fff;}
  .dash-email{font-size:12px;color:rgba(255,255,255,.6);margin-top:2px;}
  .dash-logout{margin-left:auto;padding:8px 18px;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:600;transition:background .2s;flex-shrink:0;}
  .dash-logout:hover{background:rgba(255,255,255,.22);}

  .dash-tabs{background:var(--white);border-bottom:2px solid var(--line);overflow-x:auto;scrollbar-width:none;}
  .dash-tabs::-webkit-scrollbar{display:none;}
  .dash-tabs-inner{display:flex;max-width:900px;margin:0 auto;padding:0 var(--pad);}
  .dash-tab{padding:14px 18px;font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;cursor:pointer;}
  .dash-tab.active{color:var(--green);border-bottom-color:var(--green);}

  .dash-body{max-width:900px;margin:0 auto;padding:24px var(--pad);}
  .dash-section{display:none;}
  .dash-section.active{display:block;}

  /* ── SECTION HEADER ── */
  .sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
  .sec-title{font-family:'Fields',serif;font-size:clamp(20px,3vw,26px);font-weight:900;}
  .btn-add{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:999px;background:var(--green);color:#fff;font-size:13px;font-weight:700;transition:background .2s;}
  .btn-add:hover{background:#2d6e3a;}

  /* ── CARDS ── */
  .item-card{background:var(--white);border-radius:var(--r);padding:18px 20px;margin-bottom:12px;box-shadow:0 1px 4px rgba(20,32,26,.07);display:flex;align-items:flex-start;gap:14px;}
  .item-card-icon{width:40px;height:40px;border-radius:10px;background:var(--bg);display:grid;place-items:center;flex-shrink:0;color:var(--green);}
  .item-card-info{flex:1;min-width:0;}
  .item-card-title{font-weight:700;font-size:15px;margin-bottom:3px;}
  .item-card-sub{font-size:13px;color:var(--muted);line-height:1.4;}
  .item-card-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--green-l);color:var(--green-d);margin-top:5px;display:inline-block;}
  .item-card-actions{display:flex;gap:8px;flex-shrink:0;}
  .icon-action{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;color:var(--muted);transition:background .2s,color .2s;}
  .icon-action:hover{background:var(--bg);color:var(--ink);}
  .icon-action.danger:hover{background:#fef2f2;color:var(--red);}

  /* ── ORDER HISTORY ── */
  .order-hist{background:var(--white);border-radius:var(--r);padding:16px 18px;margin-bottom:10px;box-shadow:0 1px 4px rgba(20,32,26,.06);}
  .order-hist-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
  .order-hist-id{font-weight:700;font-size:13px;color:var(--muted);}
  .order-hist-date{font-size:12px;color:var(--muted);margin-left:auto;}
  .status-pill{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
  .s-pendiente{background:#fef3c7;color:#92400e;}
  .s-preparando{background:#dbeafe;color:#1e40af;}
  .s-recogido{background:#fde68a;color:#78350f;}
  .s-en-camino{background:#d1fae5;color:#065f46;}
  .s-entregado{background:#f0fdf4;color:var(--muted);}
  .s-cancelado{background:#fee2e2;color:var(--red);}
  .order-hist-items{font-size:13px;color:var(--muted);margin-bottom:8px;}
  .order-hist-footer{display:flex;align-items:center;justify-content:space-between;font-size:13px;}
  .order-hist-total{font-weight:700;color:var(--green);}

  /* ── TRACKING TIMELINE ── */
  .track-steps{display:flex;align-items:flex-start;margin:14px 0 6px;position:relative;}
  .track-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;}
  .track-step:not(:last-child)::after{content:'';position:absolute;top:9px;left:50%;width:100%;height:2px;background:var(--line);z-index:0;}
  .track-step:not(:last-child).done::after{background:var(--green);}
  .track-dot{width:20px;height:20px;border-radius:50%;background:var(--line);border:2px solid var(--line);z-index:1;flex-shrink:0;transition:background .3s,border-color .3s;}
  .track-dot.done{background:var(--green);border-color:var(--green);}
  .track-dot.active{background:var(--green);border-color:var(--green);box-shadow:0 0 0 4px rgba(60,138,76,.18);}
  .track-lbl{font-size:9px;font-weight:600;color:var(--muted);text-align:center;margin-top:5px;line-height:1.3;text-transform:uppercase;letter-spacing:.03em;}
  .track-lbl.active{color:var(--green);}
  .track-lbl.done{color:var(--green-d);}

  /* ── MODAL ── */
  .modal-bg{position:fixed;inset:0;background:rgba(20,32,26,.5);z-index:500;display:none;align-items:center;justify-content:center;padding:20px;}
  .modal-bg.open{display:flex;}
  .modal{background:var(--white);border-radius:20px;padding:28px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;}
  .modal-title{font-family:'Fields',serif;font-size:22px;font-weight:900;margin-bottom:20px;}
  .modal-actions{display:flex;gap:10px;margin-top:20px;}
  .btn-ghost-sm{flex:1;padding:12px;border-radius:999px;border:1.5px solid var(--line);font-weight:600;font-size:14px;transition:border-color .2s;}
  .btn-ghost-sm:hover{border-color:var(--ink);}
  .btn-save{flex:2;padding:12px;border-radius:999px;background:var(--green);color:#fff;font-weight:700;font-size:14px;transition:background .2s;}
  .btn-save:hover{background:#2d6e3a;}

  /* ── PAGO PRIVADO ── */
  .privacy-banner{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:14px 16px;display:flex;gap:12px;margin-bottom:20px;}
  .privacy-banner svg{flex-shrink:0;margin-top:2px;color:var(--green);}
  .privacy-banner p{font-size:13px;color:var(--green-d);line-height:1.5;}
  .privacy-banner strong{font-weight:700;}

  /* ── EMPTY STATE ── */
  .empty{text-align:center;padding:48px 20px;color:var(--muted);}
  .empty svg{margin:0 auto 16px;opacity:.35;}
  .empty p{font-size:14px;}
  .empty .empty-cta{display:inline-block;margin-top:14px;padding:10px 22px;border-radius:999px;background:var(--green);color:#fff;font-size:13px;font-weight:700;}

  /* ── SPINNER ── */
  .spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--green);animation:spin .7s linear infinite;margin:40px auto;}
  @keyframes spin{to{transform:rotate(360deg);}}

  /* ── RESPONSIVE ── */
  @media(max-width:480px){.form-row{grid-template-columns:1fr;}.modal{padding:20px;}}
