/*
 * ============================================================
 * ZOHO DESIGN SYSTEM - CSS Custom Properties
 * ============================================================
 * Palette: Official Zoho (P1S4) — LOCKED 2026-03-19
 * Source:  Zoho UI Standards P1S4, zoho.com/branding, Deskblocks
 *
 * Usage: @import 'zoho-design-tokens.css'; or copy :root block.
 * ============================================================
 */

:root {

  /* --------------------------------------------------------
   * BRAND COLORS (Official from zoho.com/branding)
   * Reserved for logo and product icons — NOT general UI.
   * -------------------------------------------------------- */

  --zoho-red:            #E42527;   /* PANTONE 485 C  */
  --zoho-green:          #089949;   /* PANTONE 347 C  */
  --zoho-blue:           #226DB4;   /* PANTONE 660 C — NOT for UI actions */
  --zoho-yellow:         #F9B21D;   /* PANTONE 136 C  */


  /* --------------------------------------------------------
   * NEUTRAL SCALE — S SERIES (Light Mode)
   * From Zoho UI Standards P1S4
   * -------------------------------------------------------- */

  --s-0:    #FFFFFF;
  --s-50:   #F5F5F5;
  --s-100:  #E9E9E9;
  --s-200:  #DCDCDC;
  --s-300:  #C4C4C4;
  --s-400:  #ABABAB;
  --s-500:  #939393;
  --s-600:  #7A7A7A;
  --s-700:  #626262;
  --s-800:  #494949;
  --s-900:  #313131;
  --s-950:  #181818;
  --s-1000: #0C0C0C;


  /* --------------------------------------------------------
   * NEUTRAL SCALE — T SERIES (Dark Mode)
   * Slight cool tint — not pure grey.
   * -------------------------------------------------------- */

  --t-0:    #07080A;   /* Night mode base */
  --t-50:   #141516;
  --t-100:  #202123;
  --t-200:  #39393B;
  --t-300:  #525354;
  --t-400:  #6A6B6C;
  --t-500:  #838485;
  --t-600:  #9C9C9D;
  --t-700:  #B5B5B6;
  --t-800:  #CDCECE;
  --t-900:  #E7E7E7;
  --t-950:  #F2F2F3;
  --t-1000: #FFFFFF;


  /* --------------------------------------------------------
   * ACCENT — COBALT
   * Primary UI action color. NOT brand blue (#226DB4).
   * -------------------------------------------------------- */

  --color-accent:        #2C66DD;
  --color-accent-hover:  #225CCF;


  /* --------------------------------------------------------
   * LINK COLORS
   * Accessibility-tested against their respective backgrounds.
   * -------------------------------------------------------- */

  --color-link-light:    #006AFF;   /* 4.66:1 on white   */
  --color-link-dark:     #00A6FF;   /* 6.06:1 on #0E1015 */


  /* --------------------------------------------------------
   * STATUS COLORS — Light Mode
   * -------------------------------------------------------- */

  --color-success-bg:    #E8F3E8;
  --color-success-text:  #198019;
  --color-warning-bg:    #F7F0E6;
  --color-warning-text:  #AC6602;
  --color-error-bg:      #FCE8E8;
  --color-error-text:    #DD1616;
  --color-info-text:     #0098C5;
  --color-info-bg:       #E6F5F9;   /* P1S5 info banner light */


  /* --------------------------------------------------------
   * STATUS COLORS — Dark Mode
   * -------------------------------------------------------- */

  --color-success-bg-dark:    #115911;
  --color-success-text-dark:  #A5D6A7;
  --color-warning-bg-dark:    #6A3F01;
  --color-warning-text-dark:  #FFE0B2;
  --color-error-bg-dark:      #850D0D;
  --color-error-text-dark:    #FFCDD2;
  --color-info-bg-dark:       #006A8A;   /* P1S5 info banner dark */


  /* --------------------------------------------------------
   * SURFACE MODES
   * Three theme backgrounds from P1S4.
   * -------------------------------------------------------- */

  --surface-light:  #FFFFFF;
  --surface-dark:   #0E1015;
  --surface-night:  #07080A;


  /* --------------------------------------------------------
   * TYPOGRAPHY
   * Official typeface: Zoho Puvi (proprietary)
   * -------------------------------------------------------- */

  --font-family-primary: "Zoho Puvi", "Puvi", "Roboto Flex", "Roboto", "Lato", "Inter", system-ui, -apple-system, sans-serif;
  --font-family-mono:    "SF Mono", "JetBrains Mono", "Zoho Puvi Mono", monospace;
  --font-family-fallback: "Lato", "Roboto", "Inter", system-ui, -apple-system, sans-serif;

  --font-size-xs:        0.75rem;    /* 12px */
  --font-size-sm:        0.8125rem;  /* 13px */
  --font-size-base:      0.875rem;   /* 14px - Zoho default */
  --font-size-md:        1rem;       /* 16px */
  --font-size-lg:        1.125rem;   /* 18px */
  --font-size-xl:        1.25rem;    /* 20px */
  --font-size-2xl:       1.5rem;     /* 24px */
  --font-size-3xl:       2rem;       /* 32px */
  --font-size-4xl:       2.5rem;     /* 40px */
  --font-size-5xl:       3rem;       /* 48px */

  --font-weight-light:    300;
  --font-weight-regular:  400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;

  --line-height-tight:    1.2;
  --line-height-base:     1.5;
  --line-height-relaxed:  1.75;
  --line-height-loose:    2;

  --letter-spacing-tight: -0.01em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide:  0.02em;


  /* --------------------------------------------------------
   * SPACING SCALE (4px base unit)
   * -------------------------------------------------------- */

  --space-0:   0;
  --space-1:   0.25rem;   /* 4px  */
  --space-2:   0.5rem;    /* 8px  */
  --space-3:   0.75rem;   /* 12px */
  --space-4:   1rem;      /* 16px */
  --space-5:   1.25rem;   /* 20px */
  --space-6:   1.5rem;    /* 24px */
  --space-8:   2rem;      /* 32px */
  --space-10:  2.5rem;    /* 40px */
  --space-12:  3rem;      /* 48px */
  --space-16:  4rem;      /* 64px */
  --space-20:  5rem;      /* 80px */
  --space-24:  6rem;      /* 96px */


  /* --------------------------------------------------------
   * BORDER RADIUS
   * -------------------------------------------------------- */

  --radius-none:  0;
  --radius-sm:    2px;
  --radius-base:  4px;
  --radius-md:    6px;
  --radius-lg:    8px;
  --radius-xl:    12px;
  --radius-2xl:   16px;
  --radius-full:  9999px;


  /* --------------------------------------------------------
   * SHADOWS
   * -------------------------------------------------------- */

  --shadow-sm:    0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-base:  0 2px 4px rgba(0, 0, 0, 0.08);
  --shadow-md:    0 4px 8px rgba(0, 0, 0, 0.1);
  --shadow-lg:    0 8px 16px rgba(0, 0, 0, 0.12);
  --shadow-xl:    0 12px 24px rgba(0, 0, 0, 0.15);
  --shadow-card:  0 2px 8px rgba(0, 0, 0, 0.08);


  /* --------------------------------------------------------
   * TRANSITIONS
   * -------------------------------------------------------- */

  --transition-fast:    150ms ease;
  --transition-base:    250ms ease;
  --transition-slow:    350ms ease;
  --transition-smooth:  300ms cubic-bezier(0.4, 0, 0.2, 1);


  /* --------------------------------------------------------
   * Z-INDEX SCALE
   * -------------------------------------------------------- */

  --z-dropdown:  100;
  --z-sticky:    200;
  --z-fixed:     300;
  --z-overlay:   400;
  --z-modal:     500;
  --z-popover:   600;
  --z-toast:     700;
  --z-tooltip:   800;
}


/* ============================================================
 * SEMANTIC TOKENS — LIGHT THEME (default)
 * ============================================================ */

:root, [data-theme="light"] {
  --color-bg-primary:     var(--s-0);
  --color-bg-secondary:   var(--s-50);
  --color-bg-tertiary:    var(--s-100);

  --color-text-primary:   var(--s-1000);
  --color-text-secondary: var(--s-700);
  --color-text-tertiary:  var(--s-500);
  --color-text-disabled:  var(--s-300);
  --color-text-inverse:   var(--s-0);
  --color-text-link:      var(--color-link-light);
  --color-text-link-hover:#0055CC;

  --color-border-default: var(--s-200);
  --color-border-subtle:  var(--s-100);
  --color-border-strong:  var(--s-400);
  --color-border-focus:   var(--color-accent);

  --color-interactive-bg:         var(--color-accent);
  --color-interactive-bg-hover:   var(--color-accent-hover);
  --color-interactive-text:       #FFFFFF;

  --color-surface-card:   var(--s-0);
  --color-surface-input:  var(--s-0);
  --color-surface-overlay:rgba(0, 0, 0, 0.5);

  --color-status-success-bg:   var(--color-success-bg);
  --color-status-success-text: var(--color-success-text);
  --color-status-warning-bg:   var(--color-warning-bg);
  --color-status-warning-text: var(--color-warning-text);
  --color-status-error-bg:     var(--color-error-bg);
  --color-status-error-text:   var(--color-error-text);
  --color-status-info-bg:      var(--color-info-bg);
  --color-status-info-text:    var(--color-info-text);

  --color-accent-subtle:       rgba(44, 102, 221, 0.08);

  --shadow-card-themed: 0 2px 8px rgba(0, 0, 0, 0.08);
  --focus-ring: 0 0 0 2px var(--s-0), 0 0 0 4px var(--color-accent);
}


/* ============================================================
 * SEMANTIC TOKENS — DARK THEME
 * ============================================================ */

[data-theme="dark"] {
  --color-bg-primary:     #0E1015;
  --color-bg-secondary:   var(--t-50);
  --color-bg-tertiary:    var(--t-100);

  --color-text-primary:   var(--t-950);
  --color-text-secondary: var(--t-600);
  --color-text-tertiary:  var(--t-400);
  --color-text-disabled:  var(--t-200);
  --color-text-inverse:   var(--t-0);
  --color-text-link:      var(--color-link-dark);
  --color-text-link-hover:#7EC8FF;

  --color-border-default: var(--t-200);
  --color-border-subtle:  var(--t-100);
  --color-border-strong:  var(--t-400);
  --color-border-focus:   var(--color-accent);

  --color-interactive-bg:         var(--color-accent);
  --color-interactive-bg-hover:   #3A74E8;
  --color-interactive-text:       #FFFFFF;

  --color-surface-card:   var(--t-50);
  --color-surface-input:  var(--t-0);
  --color-surface-overlay:rgba(0, 0, 0, 0.7);

  --color-status-success-bg:   var(--color-success-bg-dark);
  --color-status-success-text: var(--color-success-text-dark);
  --color-status-warning-bg:   var(--color-warning-bg-dark);
  --color-status-warning-text: var(--color-warning-text-dark);
  --color-status-error-bg:     var(--color-error-bg-dark);
  --color-status-error-text:   var(--color-error-text-dark);
  --color-status-info-bg:      var(--color-info-bg-dark);
  --color-status-info-text:    var(--color-info-text);

  --color-accent-subtle:       rgba(44, 102, 221, 0.12);

  --shadow-card-themed: 0 2px 8px rgba(0, 0, 0, 0.4);
  --focus-ring: 0 0 0 2px #0E1015, 0 0 0 4px var(--color-accent);
}


/* ============================================================
 * SEMANTIC TOKENS — NIGHT THEME
 * Deeper dark, T-0 base. Minimal blue tint.
 * ============================================================ */

[data-theme="night"] {
  --color-bg-primary:     var(--t-0);
  --color-bg-secondary:   #0C0D10;
  --color-bg-tertiary:    var(--t-50);

  --color-text-primary:   var(--t-950);
  --color-text-secondary: var(--t-600);
  --color-text-tertiary:  var(--t-400);
  --color-text-disabled:  var(--t-200);
  --color-text-inverse:   var(--t-0);
  --color-text-link:      var(--color-link-dark);
  --color-text-link-hover:#7EC8FF;

  --color-border-default: var(--t-100);
  --color-border-subtle:  #0C0D10;
  --color-border-strong:  var(--t-300);
  --color-border-focus:   var(--color-accent);

  --color-interactive-bg:         var(--color-accent);
  --color-interactive-bg-hover:   #3A74E8;
  --color-interactive-text:       #FFFFFF;

  --color-surface-card:   #0C0D10;
  --color-surface-input:  var(--t-0);
  --color-surface-overlay:rgba(0, 0, 0, 0.8);

  --color-status-success-bg:   var(--color-success-bg-dark);
  --color-status-success-text: var(--color-success-text-dark);
  --color-status-warning-bg:   var(--color-warning-bg-dark);
  --color-status-warning-text: var(--color-warning-text-dark);
  --color-status-error-bg:     var(--color-error-bg-dark);
  --color-status-error-text:   var(--color-error-text-dark);
  --color-status-info-bg:      var(--color-info-bg-dark);
  --color-status-info-text:    var(--color-info-text);

  --color-accent-subtle:       rgba(44, 102, 221, 0.12);

  --shadow-card-themed: 0 2px 8px rgba(0, 0, 0, 0.5);
  --focus-ring: 0 0 0 2px var(--t-0), 0 0 0 4px var(--color-accent);
}


/* ============================================================
 * COMPONENT TOKENS
 * ============================================================
 * Third layer: primitives → semantics → components.
 * These reference semantic tokens, so theming is automatic.
 * Exception: --tooltip-bg needs per-theme overrides (below).
 * ============================================================ */

:root {

  /* --------------------------------------------------------
   * BUTTON
   * P1S5: 32px height, 4px radius, Cobalt bg for primary.
   * -------------------------------------------------------- */

  --btn-height:                 var(--space-8);              /* 32px */
  --btn-sm-height:              var(--space-6);              /* 24px */
  --btn-padding-x:              var(--space-4);              /* 16px */
  --btn-sm-padding-x:           var(--space-2);              /* 8px  */
  --btn-radius:                 var(--radius-base);          /* 4px  */
  --btn-font-size:              var(--font-size-base);       /* 14px */
  --btn-gap:                    var(--space-2);              /* 8px between buttons */

  --btn-primary-bg:             var(--color-interactive-bg);
  --btn-primary-bg-hover:       var(--color-interactive-bg-hover);
  --btn-primary-text:           var(--color-interactive-text);
  --btn-primary-font-weight:    var(--font-weight-medium);   /* 500 */

  --btn-secondary-bg:           transparent;
  --btn-secondary-bg-hover:     var(--color-bg-secondary);
  --btn-secondary-text:         var(--color-text-secondary);
  --btn-secondary-border:       var(--color-border-default);
  --btn-secondary-font-weight:  var(--font-weight-regular);  /* 400 */

  --btn-ghost-bg:               transparent;
  --btn-ghost-bg-hover:         var(--color-bg-secondary);
  --btn-ghost-text:             var(--color-interactive-bg);  /* accent color as text */

  --btn-disabled-bg:            var(--color-bg-tertiary);
  --btn-disabled-text:          var(--color-text-disabled);
  --btn-disabled-border:        var(--color-border-subtle);

  --btn-focus-ring:             var(--focus-ring);


  /* --------------------------------------------------------
   * CARD
   * P1S4: 1px border S-100. P1S5: 8px radius, 24px padding.
   * -------------------------------------------------------- */

  --card-bg:                    var(--color-surface-card);
  --card-border:                var(--color-border-subtle);
  --card-border-selected:       var(--color-interactive-bg);  /* accent */
  --card-border-width:          1px;
  --card-radius:                var(--radius-lg);             /* 8px  */
  --card-padding:               var(--space-6);               /* 24px */
  --card-padding-compact:       var(--space-4);               /* 16px */
  --card-shadow:                var(--shadow-card-themed);
  --card-gap:                   var(--space-4);               /* 16px internal */


  /* --------------------------------------------------------
   * INPUT
   * P1S5/S6: 32px height, 4px radius, 1px border.
   * -------------------------------------------------------- */

  --input-height:               var(--space-8);              /* 32px */
  --input-sm-height:            var(--space-6);              /* 24px */
  --input-bg:                   var(--color-surface-input);
  --input-text:                 var(--color-text-primary);
  --input-placeholder:          var(--color-text-tertiary);
  --input-border:               var(--color-border-default);
  --input-border-hover:         var(--color-border-strong);
  --input-border-focus:         var(--color-border-focus);    /* accent */
  --input-border-error:         var(--color-status-error-text);
  --input-border-width:         1px;
  --input-radius:               var(--radius-base);          /* 4px  */
  --input-padding-x:            var(--space-2);              /* 8px  */
  --input-font-size:            var(--font-size-base);       /* 14px */

  --input-disabled-bg:          var(--color-bg-secondary);
  --input-disabled-text:        var(--color-text-disabled);
  --input-disabled-border:      var(--color-border-subtle);

  --input-label-font-size:      var(--font-size-xs);         /* 12px */
  --input-label-font-weight:    var(--font-weight-medium);   /* 500  */
  --input-label-color:          var(--color-text-secondary);
  --input-label-gap:            var(--space-1);              /* 4px  */


  /* --------------------------------------------------------
   * TABLE
   * No P1 spec — derived from Zoho product patterns.
   * -------------------------------------------------------- */

  --table-header-bg:            var(--color-bg-secondary);
  --table-header-text:          var(--color-text-secondary);
  --table-header-font-size:     var(--font-size-xs);         /* 12px */
  --table-header-font-weight:   var(--font-weight-semibold); /* 600  */
  --table-header-padding-x:     var(--space-3);              /* 12px */
  --table-header-padding-y:     var(--space-2);              /* 8px  */

  --table-row-bg-hover:         var(--color-bg-secondary);
  --table-row-bg-selected:      var(--color-accent-subtle);
  --table-row-bg-stripe:        var(--color-bg-secondary);
  --table-cell-padding-x:       var(--space-3);              /* 12px */
  --table-cell-padding-y:       var(--space-2);              /* 8px  */
  --table-cell-font-size:       var(--font-size-base);       /* 14px */
  --table-border:               var(--color-border-subtle);
  --table-border-width:         1px;


  /* --------------------------------------------------------
   * ALERT — Banner + Dialog
   * P1S5: banner 48px/4px, dialog 8px/24px padding.
   * -------------------------------------------------------- */

  --alert-banner-height:        var(--space-12);             /* 48px */
  --alert-banner-padding:       var(--space-4);              /* 16px */
  --alert-banner-radius:        var(--radius-base);          /* 4px  */

  --alert-dialog-padding:       var(--space-6);              /* 24px */
  --alert-dialog-radius:        var(--radius-lg);            /* 8px  */
  --alert-dialog-title-size:    var(--font-size-lg);         /* 18px */
  --alert-dialog-title-weight:  var(--font-weight-semibold);
  --alert-dialog-body-size:     var(--font-size-md);         /* 16px */
  --alert-dialog-gap:           var(--space-4);              /* 16px */
  --alert-dialog-element-gap:   var(--space-2);              /* 8px  */

  --alert-info-bg:              var(--color-status-info-bg);
  --alert-info-icon:            var(--color-status-info-text);
  --alert-success-bg:           var(--color-status-success-bg);
  --alert-success-icon:         var(--color-status-success-text);
  --alert-warning-bg:           var(--color-status-warning-bg);
  --alert-warning-icon:         var(--color-status-warning-text);
  --alert-error-bg:             var(--color-status-error-bg);
  --alert-error-icon:           var(--color-status-error-text);


  /* --------------------------------------------------------
   * TOOLTIP
   * P1S5: 32px box / 40px callout, 4px radius, 8px padding.
   * NOTE: --tooltip-bg has per-theme overrides below.
   * -------------------------------------------------------- */

  --tooltip-bg:                 var(--s-950);                /* #181818 */
  --tooltip-text:               #FFFFFF;
  --tooltip-radius:             var(--radius-base);          /* 4px  */
  --tooltip-padding:            var(--space-2);              /* 8px  */
  --tooltip-font-size:          var(--font-size-base);       /* 14px */
  --tooltip-min-height:         var(--space-8);              /* 32px */
  --tooltip-callout-min-height: var(--space-10);             /* 40px */
  --tooltip-pointer-size:       8px;
  --tooltip-z-index:            var(--z-tooltip);            /* 800  */


  /* --------------------------------------------------------
   * BADGE
   * Status indicators + neutral count badges.
   * -------------------------------------------------------- */

  --badge-padding-x:            var(--space-1);              /* 4px  */
  --badge-padding-y:            2px;
  --badge-radius:               var(--radius-base);          /* 4px  */
  --badge-font-size:            var(--font-size-xs);         /* 12px */
  --badge-font-weight:          var(--font-weight-semibold); /* 600  */

  --badge-success-bg:           var(--color-status-success-bg);
  --badge-success-text:         var(--color-status-success-text);
  --badge-warning-bg:           var(--color-status-warning-bg);
  --badge-warning-text:         var(--color-status-warning-text);
  --badge-error-bg:             var(--color-status-error-bg);
  --badge-error-text:           var(--color-status-error-text);
  --badge-info-bg:              var(--color-status-info-bg);
  --badge-info-text:            var(--color-status-info-text);
  --badge-neutral-bg:           var(--color-bg-tertiary);
  --badge-neutral-text:         var(--color-text-secondary);
}


/* --- Tooltip: theme-specific bg overrides --- */

[data-theme="dark"]  { --tooltip-bg: var(--t-300); /* #525354 */ }
[data-theme="night"] { --tooltip-bg: var(--t-300); /* #525354 */ }
